加密MessageDigest类的使用

 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,所以变成负数就会有增加他的长度,所以我们要对负数进行处理
 

你可能感兴趣的:(加密)