因为Android 平台支持 java.security.MessageDigest这个包,所以MD5在Android加密中可以像在JavaSE中一样使用,
MD5是一种不可逆的加密算法,我一直想搞清楚为什么不可逆,但是发现水很深,干脆就当场没有反函数的函数理解。作为应用开发,我觉得是我们先学会用。下面写出了个详细方法:
/**
* @param 传回MD5加密字符串
* @return
* @throws NoSuchAlgorithmException
*/
public static String getMD5(String val) throws NoSuchAlgorithmException {
MessageDigest md5 = MessageDigest.getInstance("MD5");
md5.update(val.getBytes());
byte[] byteStr = md5.digest();// 加密
StringBuffer sb = new StringBuffer();
int bytelength = byteStr.length;
for (int i = 0; i < bytelength; i++) {
sb.append(byteStr[i]);
}
return sb.toString();
}
后续,不过据说2004年被山东大学一位王小云教授破解了,而且这老爷子还破解了HAVAL-128、 MD4和RIPEMD算法的报告,公布了MD系列算法的破解结果,本屌丝只能对此赞不绝口,牛逼!!!不过我觉得MD5的安全性还是挺高的,世界上本来就没有绝对安全牛逼不可破解的方式,是软件总会存安全漏洞,就像人会有生老病死,MD5的安全性已经可以满足我们的使用了,足够对付我们的想对付的了。使用时把登录用户传回的MD5加密字符串与数据库之前存的MD5加密字符串匹配一下一样就OK,不放心可以再默认加个前缀后缀啥的就更OK了。