在之前的文章中,我们将用户的密码使用SharedPreferences存储,我们打开/data/data/com.wuyudong.mobilesafe/shared_prefs文件夹下的 config.xml 文件,导入到本地,查看内容:
XML/HTML代码
- <?xml version='1.0' encoding='utf-8' standalone='yes' ?>
- <map>
- <string name="mobile_safe_psd">123</string>
- <boolean name="open_update" value="false" />
- </map>
密码居然使用的是明文,这样是非常不安全的。这里采用md5加密
编写Md5Util工具类,代码如下:
Java代码
- package com.wuyudong.mobilesafe.Utils;
- /**
- * Created by wuyudong on 2016/10/9.
- */
- import java.security.MessageDigest;
- import java.security.NoSuchAlgorithmException;
- public class Md5Util {
- /**
- * 给指定字符串按照md5算法去加密
- *
- * @param psd 需要加密的密码 加盐处理
- * @return md5后的字符串
- */
- public static String encoder(String psd) {
- try {
- //加盐处理
- psd = psd + "mobilesafe";
- //1,指定加密算法类型
- MessageDigest digest = MessageDigest.getInstance("MD5");
- //2,将需要加密的字符串中转换成byte类型的数组,然后进行随机哈希过程
- byte[] bs = digest.digest(psd.getBytes());
- //3,循环遍历bs,然后让其生成32位字符串,固定写法
- //4,拼接字符串过程
- StringBuffer stringBuffer = new StringBuffer();
- for (byte b : bs) {
- int i = b & 0xff;
- //int类型的i需要转换成16机制字符
- String hexString = Integer.toHexString(i);
- if (hexString.length() < 2) {
- hexString = "0" + hexString;
- }
- stringBuffer.append(hexString);
- }
- //5,打印测试
- System.out.println(stringBuffer.toString());
- return stringBuffer.toString();
- } catch (NoSuchAlgorithmException e) {
- e.printStackTrace();
- }
- return "";
- }
- }
md5加密:将字符串转换成 32位的字符串(16进制字符(0~f)) 不可逆
例如:123加密后:202cb962ac59075b964b07152d234b70
接下来直接调用加密类即可,分别在“设置密码”和“确认密码”两个对话框进行加密比对,具体代码如下:
Java代码
- /**
- * 确认密码对话框
- */
- private void showConfirmPsdDialog() {
- //需要自己去定义对话框的显示样式,所以要调用dialog.setView(view);
- Builder builder = new Builder(this);
- final AlertDialog dialog = builder.create();
- final View view = inflate(this, R.layout.dialog_confirm_psd, null);
- //让对话框显示一个自己定义的对话框界面效果
- dialog.setView(view);
- dialog.show();
- Button bt_submit = (Button) view.findViewById(R.id.bt_submit);
- Button bt_cancel = (Button) view.findViewById(R.id.bt_cancel);
- bt_submit.setOnClickListener(new OnClickListener() {
- @Override
- public void onClick(View v) {
- EditText et_confirm_psd = (EditText) view.findViewById(R.id.et_confirm_psd);
- String confirmPsd = et_confirm_psd.getText().toString();
- if (!TextUtils.isEmpty(confirmPsd)) {
- //将存储在sp中32位的密码,获取出来,然后将输入的密码同样进行md5,然后与sp中存储密码比对
- String psd = SpUtil.getString(getApplicationContext(), ConstantValue.MOBILE_SAFE_PSD, "");
- if (psd.equals(Md5Util.encoder(confirmPsd))) {
- //进入用户手机防盗模块,开启一个新的activity
- Intent intent = new Intent(getApplicationContext(), testActivity.class);
- startActivity(intent);
- //跳转到新的界面以后需要去隐藏对话框
- dialog.dismiss();
- } else {
- ToastUtil.show(getApplicationContext(), "输入密码错误");
- }
- } else {
- //提示用户密码输入为空的情况
- ToastUtil.show(getApplicationContext(), "请输入密码");
- }
- }
- });
- bt_cancel.setOnClickListener(new OnClickListener() {
- @Override
- public void onClick(View view) {
- dialog.dismiss();
- }
- });
- }
- /**
- * 设置密码对话框
- */
- private void showSetPsdDialog() {
- //需要自己去定义对话框的显示样式,所以要调用dialog.setView(view);
- Builder builder = new Builder(this);
- final AlertDialog dialog = builder.create();
- final View view = inflate(this, R.layout.dialog_set_psd, null);
- //让对话框显示一个自己定义的对话框界面效果
- dialog.setView(view);
- dialog.show();
- Button bt_submit = (Button) view.findViewById(R.id.bt_submit);
- Button bt_cancel = (Button) view.findViewById(R.id.bt_cancel);
- bt_submit.setOnClickListener(new OnClickListener() {
- @Override
- public void onClick(View v) {
- EditText et_set_psd = (EditText) view.findViewById(R.id.et_set_psd);
- EditText et_confirm_psd = (EditText) view.findViewById(R.id.et_confirm_psd);
- String psd = et_set_psd.getText().toString();
- String confirmPsd = et_confirm_psd.getText().toString();
- if (!TextUtils.isEmpty(psd) && !TextUtils.isEmpty(confirmPsd)) {
- //进入用户手机防盗模块
- if (psd.equals(confirmPsd)) {
- Intent intent = new Intent(getApplicationContext(), testActivity.class);
- startActivity(intent);
- //跳转到新的界面以后需要去隐藏对话框
- dialog.dismiss();
- SpUtil.putString(getApplicationContext(), ConstantValue.MOBILE_SAFE_PSD, Md5Util.encoder(psd));
- } else {
- ToastUtil.show(getApplicationContext(), "密码不一致");
- }
- } else {
- //提示用户密码输入为空的情况
- ToastUtil.show(getApplicationContext(), "请输入密码");
- }
- }
- });
- bt_cancel.setOnClickListener(new OnClickListener() {
- @Override
- public void onClick(View view) {
- dialog.dismiss();
- }
- });
- }
本文发布:Android开发网
发表评论:
◎欢迎参与讨论,请在这里发表您的看法、交流您的观点。