MessageDigest 类的用法

本文介绍如何使用Java的MessageDigest类实现MD5及SHA等算法的安全报文摘要功能,包括实例化、更新摘要对象及计算摘要的过程,并提供两个示例程序。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

MessageDigest

MessageDigest 是一个引擎,它是了提供 SHA1 MD5 等密上安全的文摘要功能而设计的。密上安全的文摘要可接受任意大小的入(一个字),并生固定大小的出,该输出称一个摘要或散列。

//MD516,SHA20

摘要具有以下属性:

  • 无法通过计算找到两个散列成相同值的报文。
  • 摘要不反映任何与输入有关的内容。

使用文摘要可以生成数据唯一且可靠的标识符。有被称数据的数字指

MessageDigest

算摘要的第一文摘要例。象所有的引擎取某类报文摘要算法的 MessageDigest 象的途径是 MessageDigest 中的 getInstance factory 方法:

    public static MessageDigest getInstance(String algorithm)

注意:算法名不区分大小写。例如,以下所有用都是相等的:

    MessageDigest.getInstance("SHA")     MessageDigest.getInstance("sha")     MessageDigest.getInstance("sHa")

用程序可选择指定提供者名称,以保所要求的算法是由已命名提供者实现的:

    public static MessageDigest getInstance(String algorithm, String provider)

getInstance将返回已初始化文摘要象。因此,它不需要的初始化。

更新文摘要

算数据的摘要的第二是向已初始化的文摘要象提供数据。将通一次或多次用以下某个 update(更新)方法来完成:

    public void update(byte input)     public void update(byte[] input)     public void update(byte[] input, int offset, int len)

算摘要

过调update方法提供数据后,程序就用以下某个 digest(摘要)方法来算摘要:

    public byte[] digest()     public byte[] digest(byte[] input)     public int digest(byte[] buf, int offset, int len)

前两个方法返回算出的摘要。后一个方法把算出的摘要存在所提供的 buf冲区中,起点是 offsetlenbuf中分配给该摘要的字数。方法返回实际buf中的字数。

接受入字组变量的 digest方法的用等价于用指定的用:

    public void update(byte[] input)

,接着用不参数的 digest方法.

示例一:

程思路:

java.security
包中的MessageDigest提供了算消息摘要的方法,首先生成象,行其update( )方法可

以将原始数据传递给该对象,然后行其digest( )方法即可得到消息摘要。具体步骤如下:


1)生成MessageDigest

MessageDigest m=MessageDigest.getInstance("MD5");

分析:和2.2.1KeyGeneratorMessageDigest也是一个工厂,其构造器是受保的,不允

直接使用new MessageDigist( )象,而必其静方法getInstance( )生成MessageDigest象。

其中入的参数指定算消息摘要所使用的算法,常用的有"MD5""SHA"等。若MD5算法的细节趣可参考

http://www.ietf.org/rfc/rfc1321.txt


2入需要算的字符串

m.update(x.getBytes("UTF8" ));

分析:x需要算的字符串,update入的参数是字节类型或字节类型数于字符串,需要先使用

getBytes( )
方法生成字符串数

3算消息摘要

byte s[ ]=m.digest( );

分析:MessageDigest象的digest( )方法完成算,算的果通节类型的数返回。

4

必要的可以使用如下代s转换为字符串。

String result="";
for (int i = 0; i < s.length; i++) {
   
result+=Integer.toHexString((0x000000ff & s[i]) | 0xffffff00).substring(6);
}
与分析:
完整程序如下:
import java.security.*;
public class DigestPass{
    public static void main(String args[ ]) throws Exception{
        String x=args[0];
        MessageDigest m=MessageDigest.getInstance("MD5");
        m.update(x.getBytes("UTF8"));
        byte s[ ]=m.digest( );
        String result="";
        for (int i = 0; i < s.length; i++) {
            result+=Integer.toHexString((0x000000ff & s[i]) | 0xffffff00).substring(6);
        }
        System.out.println(result);
    }
}

运行程序

java DigestCalc abc来运行程序,其中命令行参数abc是原始数据,屏幕算后的消息摘要:

900150983cd24fb0d6963f7d28e17f72
 

 

示例二:


public String EncoderByMd5(String str) throws NoSuchAlgorithmException

UnsupportedEncodingException...{
        //确定算方
        MessageDigest md5=MessageDigest.getInstance("MD5");
        BASE64Encoder base64en new BASE64Encoder();
        //加密后的字符串
        String newstr=base64en.encode(md5.digest(str.getBytes("utf-8")));
        return newstr;
    }

用函数:String str="0123456789"

 System.out.println(EncoderByMd5(str));

 出:eB5eJF1ptWaXm4bijSPyxw==

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值