java中MessageDigest类是一个加密算法的抽象类,所以使用它的时候,要获取它的示例
第一步:
通过 MessageDigest md = MessageDigest.getInstance("MD5"); 获取MD5加密算法的实例.
第二 步:
因为MD5加密算法是需要信息的长度减去448能被512整除即str mob 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,所以变成负数就会有增加他的长度,所以我们要对负数进行处理