MD5算法常见坑
程序员文章站
2024-03-19 09:50:28
...
问题1.MD5算法设置返回32位加密字符,结果返回31位字符
原因:一般是少0,就是少了一个0,具体原因是:Integer.toHexString(t & 0xFF)
当t
为14
时,十六进制就是0e
,转化成字符串会忽略掉前导零
解决办法:
String s = Integer.toHexString(t & 0xFF);
if (s.length() == 1) {
s = "0" + s;
}
问题2: MD5加密字符串中,有中文的时候,同样的加密字符串,但每次返回的摘要信息不一样
原因:
public static String toMd5(String str) {
String re = null;
byte encrypt[];
try {
byte[] tem = str.getBytes();
MessageDigest md5 = MessageDigest.getInstance("md5");
md5.reset();
md5.update(tem);
encrypt = md5.digest();
StringBuilder sb = new StringBuilder();
for (byte t : encrypt) {
sb.append(Integer.toHexString(t & 0xFF));
}
re = sb.toString();
} catch (NoSuchAlgorithmException e) {
e.printStackTrace();
}
return re;
}
上图中的byte[] tem = str.getBytes();这一句,字符串转字符数组时未指定字符集
解决办法:转换的时候加上字符集就可,一般是utf-8,如:
byte[]
tem = str.getBytes("UTF-8");