一般的手機沒有root許可權,進不去data/data目錄,當手機刷機了後,擁有root許可權,就可以進入data/data目錄,查看我們保存的密碼文件,因此我們需要對存入的密碼進行MD5加密 獲取MessageDigest信息摘要器對象,調用MessageDigest.getInstance(“md5 ...
一般的手機沒有root許可權,進不去data/data目錄,當手機刷機了後,擁有root許可權,就可以進入data/data目錄,查看我們保存的密碼文件,因此我們需要對存入的密碼進行MD5加密
獲取MessageDigest信息摘要器對象,調用MessageDigest.getInstance(“md5”),參數:規則
調用MessageDigest對象的digest(bytes)方法,得到加密的byte[] 數組,參數:byte[] 數組,調用String對象的getBytes()方法獲取到位元組數組
用每一個byte去和11111111八個二進位位做與運算並且得到的是int類型:byte & 11111111
for(byte b : xxxxx) 迴圈中
運行 byte & 0xff得到 int值
調用Integer.toHexString(number),得到16進位並返回String類型
判斷String的長度是1的,在它的前面拼接上0
迴圈外面定義一個StringBuffer對象,調用StringBuffer對象的append()拼接起來字元串
調用StringBuffer對象的toString()方法,得到加密後的標準字元串結果
MD5可以被破解,包括md5(md5(md5()))這種形式,對所有可能性進行加密存入資料庫,然後與你的md5密碼比對,可以進行md5加鹽
軟體需要先卸載再測試,清除掉之前保存的sp文件
package com.qingguow.mobilesafe.utils; import java.security.MessageDigest; public class Md5Util { /** * 獲取MD5加密字元串 * @param pass * @return */ public static String md5Password(String pass){ MessageDigest messageDigest; try { messageDigest = MessageDigest.getInstance("md5"); byte[] bytes=messageDigest.digest(pass.getBytes()); StringBuffer sb=new StringBuffer(); for(byte b:bytes){ int number=b & 0xff; String str=Integer.toHexString(number); if(str.length()==1){ sb.append("0"); } sb.append(str); } return sb.toString(); } catch (Exception e) { e.printStackTrace(); } return ""; } }