使用okHttp登录、Md5密码加密
使用okHttp3登录:
使用okHttp3之前要在build.gradle引入okHttp3的依赖(顺便引入解析数据的gson)
implementation 'com.squareup.okhttp3:okhttp:3.4.1' //okhttp3
implementation 'com.google.code.gson:gson:2.7' //导入gson
在AndroidManifest.xml中加入网络请求权限
<uses-permission android:name="android.permission.INTERNET" />
我在这里封装好了okHttp3的登录类:
package com.example.login; import android.util.Log;
import android.widget.Toast; import org.json.JSONException;
import org.json.JSONObject;
import okhttp3.MediaType;
import okhttp3.OkHttpClient;
import okhttp3.Request;
import okhttp3.RequestBody; public class OkHttp {
private static MediaType mediaType; //登录
public static void Login(String url,String number,String password,okhttp3.Callback callback){
try {
OkHttpClient client = new OkHttpClient();
JSONObject jsonObject =new JSONObject();
jsonObject.put("number",number.toString());
jsonObject.put("password",password.toString());
mediaType = MediaType.parse("application/json;charset=utf-8");
RequestBody requestBody = RequestBody.create(mediaType,jsonObject.toString());
Request request = new Request.Builder().url(url).post(requestBody).build();
client.newCall(request).enqueue(callback);
} catch (JSONException e) {
e.printStackTrace();
}
}
}
然后使用(在线程中使用):
String number = edt_number.getText().toString(); //获取文本框输入的账号
String password = edt_number.getText().toString(); //获取文本框输入的密码
String url = "http://XXX/login"; //获取url,这里加上自己的登录url
OkHttp.Login(url,number,password, new okhttp3.Callback() {
@Override
public void onFailure(Call call, IOException e) {
Log.d("失败","错误");
} @Override
public void onResponse(Call call, final Response response) throws IOException {
if(response.code() == 200){
Gson gson = new Gson();
String data = response.body().string();
final Emp emp = gson.fromJson(data,Emp.class); //新加了一个人员类
Log.d("成功","姓名:" + emp.getName());
runOnUiThread(new Runnable() {
@Override
public void run() {
btn_login.setText(emp.getName());
}
});
}else{
Log.d("成功","获取失败");
}
}
});
Md5密码加密(两种加密,看个人需求,普通Md5加密、自定义Md5加密):
Md5加密(代码):
public String md5Decode(String content) {
byte[] hash;
try {
hash = MessageDigest.getInstance("MD5").digest(content.getBytes("UTF-8"));
} catch (NoSuchAlgorithmException e) {
throw new RuntimeException("NoSuchAlgorithmException", e);
} catch (UnsupportedEncodingException e) {
throw new RuntimeException("UnsupportedEncodingException", e);
}
//对生成的16字节数组进行补零操作
StringBuilder hex = new StringBuilder(hash.length * 2);
for (byte b : hash) {
if ((b & 0xFF) < 0x10) {
hex.append("0");
}
hex.append(Integer.toHexString(b & 0xFF));
}
return hex.toString();
}
普通加密使用(直接在获取文本框密码中加密):
String password = md5Decode(edt_password.getText().toString()); //加密 //获取文本框输入的密码
自定义加密使用(在后面加了一段乱码,后台中的加密同时也要加上这段乱码):
String password = md5Decode(edt_password.getText().toString() +"dabsdafaqj23ou89ZXcj@#$@#$#@KJdjklj;D../dSF.,");
完整代码(MainActivity的代码):
package com.example.login; import androidx.appcompat.app.AppCompatActivity; import android.os.Bundle;
import android.util.Log;
import android.view.View;
import android.widget.Button;
import android.widget.EditText;
import android.widget.Toast; import com.google.gson.Gson; import java.io.IOException;
import java.io.UnsupportedEncodingException;
import java.security.MessageDigest;
import java.security.NoSuchAlgorithmException; import okhttp3.Call;
import okhttp3.Response; public class MainActivity extends AppCompatActivity implements View.OnClickListener {
private EditText edt_number,edt_password;
private Button btn_login;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
initView();
} private void initView(){
edt_number = (EditText)findViewById(R.id.edt_number);
edt_password = (EditText)findViewById(R.id.edt_password);
btn_login = (Button)findViewById(R.id.btn_login);
btn_login.setOnClickListener(this);
} @Override
public void onClick(View view) {
String number = edt_number.getText().toString(); //获取文本框中的账号
//获取文本框中的密码,MD5加密
String password = md5Decode(edt_password.getText().toString() +"dabsdafaqj23ou89ZXcj@#$@#$#@KJdjklj;D../dSF.,");
String url = ""; //登录的url
OkHttp.Login(url,number,password, new okhttp3.Callback() {
@Override
public void onFailure(Call call, IOException e) {
Log.d("失败","错误");
} @Override
public void onResponse(Call call, final Response response) throws IOException {
if(response.code() == 200){
Gson gson = new Gson();
String data = response.body().string();
final Emp emp = gson.fromJson(data,Emp.class);
Log.d("成功","姓名:" + emp.getName());
runOnUiThread(new Runnable() {
@Override
public void run() {
btn_login.setText(emp.getName());
}
});
}else{
Log.d("成功","获取失败");
}
}
});
} public String md5Decode(String content) {
byte[] hash;
try {
hash = MessageDigest.getInstance("MD5").digest(content.getBytes("UTF-8"));
} catch (NoSuchAlgorithmException e) {
throw new RuntimeException("NoSuchAlgorithmException", e);
} catch (UnsupportedEncodingException e) {
throw new RuntimeException("UnsupportedEncodingException", e);
}
//对生成的16字节数组进行补零操作
StringBuilder hex = new StringBuilder(hash.length * 2);
for (byte b : hash) {
if ((b & 0xFF) < 0x10) {
hex.append("0");
}
hex.append(Integer.toHexString(b & 0xFF));
}
return hex.toString();
} }
MainActivity的布局代码:
<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:app="http://schemas.android.com/apk/res-auto"
xmlns:tools="http://schemas.android.com/tools"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:orientation="vertical"
android:paddingTop="10dp"
android:paddingRight="10dp"
android:paddingLeft="10dp"
tools:context=".MainActivity">
<EditText
android:id="@+id/edt_number"
android:gravity="center_horizontal|center_vertical"
android:lines="1"
android:maxLength="12"
android:layout_width="match_parent"
android:layout_height="40dp"
android:hint="请输入账号"
tools:ignore="MissingConstraints" />
<EditText
android:id="@+id/edt_password"
android:gravity="center_horizontal|center_vertical"
android:lines="1"
android:maxLength="12"
android:layout_width="match_parent"
android:layout_height="40dp"
android:hint="请输入密码"
android:inputType="textPassword"
tools:ignore="MissingConstraints" />
<Button
android:id="@+id/btn_login"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:text="登录"/> </LinearLayout>
OkHttp封装类代码:
package com.example.login; import android.util.Log;
import android.widget.Toast; import org.json.JSONException;
import org.json.JSONObject;
import okhttp3.MediaType;
import okhttp3.OkHttpClient;
import okhttp3.Request;
import okhttp3.RequestBody; public class OkHttp {
private static MediaType mediaType; //登录
public static void Login(String url,String number,String password,okhttp3.Callback callback){
try {
OkHttpClient client = new OkHttpClient();
JSONObject jsonObject =new JSONObject();
jsonObject.put("number",number.toString());
jsonObject.put("password",password.toString());
mediaType = MediaType.parse("application/json;charset=utf-8");
RequestBody requestBody = RequestBody.create(mediaType,jsonObject.toString());
Request request = new Request.Builder().url(url).post(requestBody).build();
client.newCall(request).enqueue(callback);
} catch (JSONException e) {
e.printStackTrace();
}
}
}
Emp人员类:
package com.example.login;
public class Emp {
private String number;
private String name;
public Emp(String number,String name){
this.number = number;
this.name = name;
}
public String getNumber() {
return number;
}
public void setNumber(String number) {
this.number = number;
}
public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
}
}
项目案例(点击获取,提取码:oi87),项目中有两个案例app的是页面传值,login是本章的登录
使用okHttp登录、Md5密码加密的更多相关文章
- Django -MD5密码加密与登录
直接贴代码 login_reg.py from django.shortcuts import render, redirect from web.forms.login_reg import Reg ...
- Shiro自定义realm实现密码验证及登录、密码加密注册、修改密码的验证
一:先从登录开始,直接看代码 @RequestMapping(value="dologin",method = {RequestMethod.GET, RequestMethod. ...
- Apach Shiro MD5密码加密过程(明文生成密码过程)详细解析
前言: 最近再项目当中使用的ApachShiro安全框架,对于权限和服务器资源的保护都有一个很好的管理.前期主要参考的文章有 项目中设计密码的加盐处理以及二次加密问题,跟着断点 一步步揭开Apach ...
- 015 Android md5密码加密及其工具类
1.md5加密介绍 MD5算法是广泛使用的杂凑函数,也就是哈希函数,英文全拼是:Message Digest Algorithm,对应的中文名字是消息摘要算法. MD5加密:将字符串转换成 32位的字 ...
- spring mvc自定义注解--登录时密码加密注解
1,定义注解名称接口 /** * 使用该注解不用再MD5转换了 * * @author adonis * */ @Target(ElementType.PARAMETER) @Retention(Re ...
- MD5密码加密
using System; using System.Security.Cryptography; using System.Text; namespace DimoNetwork.Common.DE ...
- 添加MD5 密码加密
编辑 /etc/grub/grub.conf 配置文件 password = 123456 password --md5 $5$H.........SS grub-crypt --md5 ...
- web登录密码加密
文章:如何实现登录页面密码加密 文章:用RSA加密实现Web登录密码加密传输 文章:web登录用户名密码加密 知乎文章:Web前端密码加密是否有意义? 文章:记录一次黑客模拟攻击 成功拿到淘宝账号和密 ...
- Spring-Security (学习记录五)--配置登录时,密码采用md5加密,以及获取登录信息属性监听同步自己想要的登录信息
目录 1. PasswordEncoder 采用密码加密 2. 获取当前的用户信息 1. PasswordEncoder 采用密码加密 使用前面的例子.可以看出我们数据库密码是采用明文的,我们在登录的 ...
随机推荐
- 一个测试文件与源文件位于不同模块时Jacoco覆盖率配置的例子
问题描述: 我们有个多模块项目,由于种种原因(更常见的可能是需要集成测试)测试文件和源文件不在一个模块,Jacoco的覆盖率无法正确显示,查询了一些资料,发现中文的例子比较少,就把我自己的Demo贴一 ...
- Flutter学习笔记(10)--容器组件、图片组件
如需转载,请注明出处:Flutter学习笔记(10)--容器组件.图片组件 上一篇Flutter学习笔记(9)--组件Widget我们说到了在Flutter中一个非常重要的理念"一切皆为组件 ...
- 移动端开发用touch事件还是click事件
前端开发现在包含了跨浏览器,跨平台(不同操作系统)和跨设备(不同尺寸的设备)开发. 在移动开发的过程中,到底选取touch事件还是click事件?对了,请不要鄙视click,click在移动端开发用着 ...
- SSD+HDD 安装ubuntu16.04+win7双系统
本人电脑是联想天逸100 前段时间把光驱拆了加了一个128G的SSD 顺便把SSD装上了win7 机械硬盘500G放资料和一般软件之类的 后来想要用到ubuntu 就在官网下载ubuntu1 ...
- 如何在Vue项目中使用vw实现移动端适配
有关于移动端的适配布局一直以来都是众说纷纭,对应的解决方案也是有很多种.在< 使用Flexible实现手淘H5页面的终端适配>提出了Flexible的布局方案,随着 viewport 单位 ...
- Filebeat6.3文档—Log input配置
Filebeat6.3文档-Log input配置 paths 日志加载的路径.例如加载某一子目录级别下面路径的日志:/var/log/*/*.log.这表示会去加载以.log结尾的/var/log下 ...
- 【Java例题】7.5 文件题2-学生成绩统计
5.学生成绩统计.已有一个学生成绩文件,含有多位学生的各三门课的成绩:读取这个文件中的每位学生的三门课成绩,然后计算均分:最后对这些均分按照大于或小于75分的界限,分别写到另两个文件中. packag ...
- 缓存的有效期和淘汰策略【Redis和其他缓存】【刘新宇】
缓存有效期与淘汰策略 有效期 TTL (Time to live) 设置有效期的作用: 节省空间 做到数据弱一致性,有效期失效后,可以保证数据的一致性 Redis的过期策略 过期策略通常有以下三种: ...
- Java高级面试题解析(二):百度Java面试题前200页(精选)
基本概念 操作系统中 heap 和 stack 的区别 heap是堆,stack是栈,是两种不同的数据结构.堆是队列优先,先进先出:栈是先进后出. 在java多线程中,每个线程都有自己的栈:不同的线程 ...
- C#使用代理IP发送请求
https://www.cnblogs.com/benbenfishfish/p/5830149.html 获取可代理的IP https://www.cnblogs.com/ShalenChe/p ...