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进制数了