消息摘要计算一例

一、什么是消息摘要

    一个消息摘要就是一个数据块的数字指纹。即对一个任意长度的一个数据块进行计算,产生一个唯一指印(对于SHA1是产生一个20字节的二进制数组)。

二、消息摘要有两个基本属性:

1、两个不同的报文难以生成相同的摘要;
2、绝不能从消息摘要生成原数据

三、消息摘要的应用

1、消息摘要主要用于验证数据的完整性,我们经常听到的校验和就是消息摘要的一个特例。
2、MAC:消息认证码,使用秘密密钥和消息摘要算法来创建消息摘要。
    
   我们可能经常会疑问,我们有了消息摘要为什么还要认证码呢消息摘要的算法可以确保消息摘要和具体的消息之间的一一对应,也就是只要你有相同的消息,采用相同的算法肯定能产生相同的消息摘要,但有时为了特殊的目的我们需要只有特定的人才能生成这个摘要,这时候我们可以通过在生成消息摘要的过程中加入相应的密钥,从而使生成的消息摘要在没有密钥的情况下难以生成。
   鉴于消息摘要的一一对应,经常在一些保护用户密码的地方我们采用了这种算法。例如,在银行系统,为了不让管理数据库的员工把你的密码看到,系统本身在你的密码存入库中之前就做了消息摘要的提取,这样库中别人看到的是一串奇怪的串,他也没法逆向获得你的明文密码。当然,如果银行的安全系统被控制,那什么事情都可以做。

四、消息摘要的计算

  Java.security包中的MessageDigest类提供了计算消息摘要的方法, 首先生成对象,执行其update()方法可以将原始数据传递给该对象,然后执行其digest()方法即可得到消息摘要。具体步骤如下:

1、首先用生成一个MessageDigest类,确定计算方法
    java.security.MessageDigest alga=java.security.MessageDigest.getInstance("SHA-1");

    MessageDigest类也是一个工厂类,其构造器是受保护的,不允许直接使用new MessageDigist( )来创建对象,而必须通过其静态方法getInstance()生成MessageDigest对象。其中传入的参数指定计算消息摘要所使用的算法,常用的有"MD5","SHA","SHA-1"等

2、添加要进行计算摘要的信息
    alga.update(myinfo.getBytes());

3、计算出摘要
   byte[] digesta=alga.digest();

  把你的信息和摘要发送给其他人,其他人用相同的方法初始化,添加信息,最后进行比较摘要是否相同。

4、algb.isEqual(digesta,algb.digest())

相关AIP

java.security.MessageDigest 类

static getInstance(String algorithm)
  返回一个MessageDigest对象,它实现指定的算法,参数:算法名,如 SHA-1 或MD5

void update (byte input)
void update (byte[] input)
void update(byte[] input, int offset, int len)
   添加要进行计算摘要的信息

byte[] digest()
   完成计算,返回计算得到的摘要(对于MD5是16位,SHA是20位)

void reset()
   复位

static boolean isEqual(byte[] digesta, byte[] digestb)
   比效两个摘要是否相同

五、代码:

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();
    }
}

运行结果:

C:\java>java myDigest
本信息摘要是:4D:8C:34:1F:EF:37:B2:1F:7F:1D:66:7B:47:A0:FE:ED:E9:9B:CB:98
信息检查正常


Zz :http://www.java3z.com/cwbwebhome/article/article5/5794.html



评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值