欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页

MD5算法常见坑

程序员文章站 2024-03-19 09:50:28
...

问题1.MD5算法设置返回32位加密字符,结果返回31位字符

原因:一般是少0,就是少了一个0,具体原因是:Integer.toHexString(t & 0xFF)t14时,十六进制就是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");

相关标签: md5 算法