近期在项目中遇到一个,MD5加密出现错误,出现了有可能是31位的情况,仔细一对比,两个加密后的字符串差别不大,只是前面少了一个0 。
首先看错误的加密方式
public static String getMD5String(String str) {
try {
// 生成一个MD5加密计算摘要
MessageDigest md = MessageDigest.getInstance("MD5");
// 计算md5函数
md.update(str.getBytes("UTF-8"));
// digest()最后确定返回md5 hash值,返回值为8位字符串。因为md5 hash值是16位的hex值,实际上就是8位的字符
// BigInteger函数则将8位的字符串转换成16位hex值,用字符串来表示;得到字符串形式的hash值
//一个byte是八位二进制,也就是2位十六进制字符(2的8次方等于16的2次方)
byte[] digest = md.digest();
for (byte b : digest) {
/** 为什么要打印这里主要是看是否有错误,查看后确实是这里有一定的问题
* 特别是第一个加密串, 只有一位,为什么会这样呢因为加密处理确实只有一位,如果正
* 常的话应该是 0+某个数字。但是却被省略了。当然可以自己加上0,再处理就行。