編輯:關於android開發
在之前的文章中,我們將用戶的密碼使用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();
}
});
}
RecyclerView,androidrecyclerview
RecyclerView,androidrecyclerview1.簡介 RecyclerView是一種新的視圖組,目標是為任何基於適配器的視圖提供相似的渲染方式。它
GreenDao3.0新特性解析(配置、注解、加密),greendao3.0新特性
GreenDao3.0新特性解析(配置、注解、加密),greendao3.0新特性Greendao3.0release與7月6日發布,其中最主要的三大改變就是:1.換包名
【java學習系列】 Android第一本書《第一行代碼》,第一行代碼android
【java學習系列】 Android第一本書《第一行代碼》,第一行代碼android 開始Java的學習,從Android,開始吧。《第一代碼》開始閱讀和調試demo例
Android RecyclerView 和 CardView簡單使用,recyclerview簡單用法
Android RecyclerView 和 CardView簡單使用,recyclerview簡單用法Android 5.0之後Android新增加的兩個UI控件Rec
如何處理 android 方法總數超過 65536 . the number of method references in a .dex file exceed 64k,android.dex
如何處理 android 方法總數超過 65536 . the numb