深入浅析Android手机卫士保存密码时进行md5加密
程序员文章站
2024-02-27 16:57:57
推荐阅读:
浅析android手机卫士自定义控件的属性
浅析android手机卫士关闭自动更新
详解android 手机卫士设置向导页面
一般的手机没有root权限...
推荐阅读:
一般的手机没有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 ""; } }
以上内容是小编给大家介绍的android手机卫士保存密码时进行md5加密的相关知识,希望对大家有所帮助!