java 中MessageDigest的使用

                     java中MessageDigest类是一个加密算法的抽象类,所以使用它的时候,要获取它的示例

第一步

           

                MessageDigest md = MessageDigest.getInstance("MD5");

获取MD5加密算法的实例

因为MD5加密算法是需要信息的长度减去448能被512整除即str  mod  512=448 所以第二步是对信息的填充和打乱

                            md.update(str);

接着就是最重要的一步对摘要后的信息进行哈希计算得到一个16字节的字节数组

                            

               byte b[] = md.digest();

对MD5算法简要的叙述可以为:MD5以512位分组来处理输入的信息,且每一分组又被划分为16个32位子分组,经过了一系列的处理后,算法的输出由四个32位分组组成,将这四个32位分组级联后将生成一个128位散列值。

为了使得最后得出的结果是定长,还要对数据经行进一步处理,我们知道每个字节8位,转化为整型再转化为16进制时一般情况下是两位的16进制,(md5算法最后是以16进制显示)但是转化为整形的时候,会产生负数的情况,我们知道整形是4个字节,就要对原来一个字节的信息进行填充3个字节的0,所以变成负数就会有增加他的长度,所以我们要对负数进行处理

                          

              if (i < 0)
                i += 256;

还有一种情况是这个数小于16,那么就只有1位16进制,不符合要求,所以再处理

                         if (i < 16)

                              buf.append("0");

这样这16个字节就可以变成32位的16进制数了

源码         https://download.csdn.net/download/qq_33543634/10552944

猜你喜欢

转载自blog.csdn.net/qq_33543634/article/details/81126637