在之前的文章中,我們將用戶的密碼使用SharedPreferences存儲,我們打開/data/data/com.wuyudong.mobilesafe/shared_prefs文件夾下的 config.xml 文件,導入到本地,查看內容: 密碼居然使用的是明文,這樣是非常不安全的。這裡採用md5加 ...
在之前的文章中,我們將用戶的密碼使用SharedPreferences存儲,我們打開/data/data/com.wuyudong.mobilesafe/shared_prefs文件夾下的 config.xml 文件,導入到本地,查看內容:
<?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加密
本文地址:http://www.cnblogs.com/wuyudong/p/5941131.html,轉載請註明出處。
編寫Md5Util工具類,代碼如下:
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
接下來直接調用加密類即可,分別在“設置密碼”和“確認密碼”兩個對話框進行加密比對,具體代碼如下:
/** * 確認密碼對話框 */ 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(); } }); }