MessageDigest的功能及用法(加密解密) SHA

MessageDigest的功能及用法

MessageDigest 类为应用程序提供信息摘要算法的功能,如 MD5 或 SHA 算法。信息摘要是安全的单向哈希函数,它接收任意大小的数据,并输出固定长度的哈希值。

 

MessageDigest 对象开始被初始化。该对象通过使用 update()方法处理数据。任何时候都可以调用 reset()方法重置摘要。一旦所有需要更新的数据都已经被更新了,应该调用digest() 方法之一完成哈希计算。

 

对于给定数量的更新数据,digest 方法只能被调用一次。在调用 digest 之后,MessageDigest 对象被重新设置成其初始状态。

 

1、public static MessageDigest getInstance(String algorithm)

                                 throws NoSuchAlgorithmException

   返回实现指定摘要算法的 MessageDigest 对象。

   algorithm - 所请求算法的名称

2、public static MessageDigest getInstance(String algorithm,

                                        String provider)

                                 throws NoSuchAlgorithmException,

                                        NoSuchProviderException

  返回实现指定摘要算法的 MessageDigest 对象。

  algorithm - 所请求算法的名称

  provider - 提供者的名称。

3、public void update(byte[] input)

  使用指定的 byte 数组更新摘要。

4、public byte[] digest()

  通过执行诸如填充之类的最终操作完成哈希计算。在调用此方法之后,摘要被重置。

5、public static boolean isEqual(byte[] digesta,

                              byte[] digestb)

比较两个摘要的相等性。做简单的字节比较。

  

 

  

 

注意:Provider可以通过 Java.security.Security.getProviders() 方法获取已注册提供者列表。比较常用的有“SUN”

 

SUN提供的常用的算法名称有:MD2

MD5

                        SHA-1

                        SHA-256

                        SHA-384

                        SHA-512

 

  

 

Code举例:

 

import java.security.*;

public class myDigest {

  public static void main(String[] args)  {

    myDigest my=new myDigest();

    my.testDigest();

  }

  public void testDigest()

  {

   try {

     String myinfo="我的测试信息";

    //java.security.MessageDigest alg=java.security.MessageDigest.getInstance("MD5");

      java.security.MessageDigest alga=java.security.MessageDigest.getInstance("SHA-1");

      alga.update(myinfo.getBytes());

      byte[] digesta=alga.digest();

      System.out.println("本信息摘要是:"+byte2hex(digesta));

      //通过某中方式传给其他人你的信息(myinfo)和摘要(digesta) 对方可以判断是否更改或传输正常

      java.security.MessageDigest algb=java.security.MessageDigest.getInstance("SHA-1");

      algb.update(myinfo.getBytes());

      if (algb.isEqual(digesta,algb.digest())) {

         System.out.println("信息检查正常");

       }

       else

        {

          System.out.println("摘要不相同");

         }

   }

   catch (java.security.NoSuchAlgorithmException ex) {

     System.out.println("非法摘要算法");

   }

  }

  public String byte2hex(byte[] b) //二行制转字符串

    {

     String hs="";

     String stmp="";

     for (int n=0;n<b.length;n++)

      {

       stmp=(java.lang.Integer.toHexString(b[n] & 0XFF));

       if (stmp.length()==1) hs=hs+"0"+stmp;

       else hs=hs+stmp;

       if (n<b.length-1)  hs=hs+":";

      }

     return hs.toUpperCase();

    }

内容版权声明:除非注明,否则皆为本站原创文章。

转载注明出处:https://www.heiqu.com/ba9f904f0772e9b2299b9103d56ccd49.html