MessageDigest简要

MessageDigest简要本文博客原參考文章:http://blog.sina.com.cn/s/blog_4f36423201000c1e.html一、概述java.security.MessageDigest类用于为应用程序提供信息摘要算法的功能,如MD5或SHA算法。简单点说就是用于生成散列码。信息摘要是安全的单向哈希函数,它接收随意大小的数据。输出固定长度的哈希值。关…

大家好,又见面了,我是你们的朋友全栈君。

本文博客

參考文章:
http://blog.sina.com.cn/s/blog_4f36423201000c1e.html

一、概述
java.security.
MessageDigest
类用于为应用程序提供信息摘要算法的功能,如 MD5 或 SHA 算法。简单点说就是用于生成
散列码

信息摘要是安全的单向哈希函数,它接收随意大小的数据。输出固定长度的哈希值。关于信息摘要散列码请參照《数字证书简单介绍

MessageDigest 通过其getInstance系列静态函数来进行实例化和初始化。

MessageDigest 对象通过使用 update 方法处理数据。

不论什么时候都能够调用 reset 方法重置摘要。

一旦全部须要更新的数据都已经被更新了。应该调用 digest 方法之中的一个完毕哈希计算并返回结果。

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

MessageDigest 的实现可任意选择是否实现 Cloneable 接口。client应用程能够通过尝试复制和捕获 CloneNotSupportedException 測试可复制性:

 MessageDigest md = MessageDigest.getInstance(“SHA”);

 try {

     md.update(toChapter1);

     MessageDigest tc1 = md.clone();

     byte[] toChapter1Digest = tc1.digest();

     md.update(toChapter2);

     etc.

 } catch (CloneNotSupportedException cnse) {

     throw new DigestException(“couldn’t make digest of partial content”);

 }

注意1:即时给定MessageDigest的实现是不可复制的。则仍然可以通过getInstance方法实例化几个实例计算来同一时候进行摘要信息的计算。

注意2:因为历史原因,此类是抽象的,是从 MessageDigestSpi 扩展的。应用程序开发者仅仅应该注意在此 MessageDigest 类中定义的方法;超类中的全部方法是供希望提供自己的信息摘要算法实现的加密服务提供者使用的。 

注意3MessageDigest并非单实例的。例如以下代码所看到的:

       try

            {

                MessageDigest mdTemp1 = MessageDigest.getInstance(“MD5”);

                MessageDigest mdTemp2= MessageDigest.getInstance(“MD5”);

                MessageDigest mdTemp3= MessageDigest.getInstance(“MD5”);

                System.out.println(“mdTemp1==mdTemp2?

:”+(mdTemp1==mdTemp2));

                System.out.println(“mdTemp2==mdTemp3?

:”+(mdTemp2==mdTemp3));

            } catch (NoSuchAlgorithmException e)

            {

                // TODO Auto-generated catch block

                e.printStackTrace();

            }

执行结果

mdTemp1==mdTemp2?:false

mdTemp2==mdTemp3?:false

构造方法摘要
protected MessageDigest(String algorithm) 
          创建具有指定算法名称的MessageDigest 实例对象

 

方法摘要
 Object clone() 
          假设实现是可复制的,则返回一个副本。
 byte[] digest() 
          通过运行诸如填充之类的终于操作完毕哈希计算。
 byte[] digest(byte[] input) 
          使用指定的字节数组对摘要进行最后更新。然后完毕摘要计算。
 int digest(byte[] buf, int offset, int len) 
          通过运行诸如填充之类的终于操作完毕哈希计算。

 String getAlgorithm() 
          返回标识算法的独立于实现细节的字符串。
 int getDigestLength() 
          返回以字节为单位的摘要长度,假设提供程序不支持此操作而且实现是不可复制的。则返回 0。
static MessageDigest getInstance(String algorithm) 
          生成实现指定摘要算法的 MessageDigest 对象。

static MessageDigest getInstance(String algorithm, Provider provider) 
          生成实现指定提供程序提供的指定算法的 MessageDigest 对象,假设该算法可从指定的提供程序得到的话。

static MessageDigest getInstance(String algorithm, String provider) 
          生成实现指定提供程序提供的指定算法的 MessageDigest 对象,假设该算法可从指定的提供程序得到的话。
 Provider getProvider() 
          返回此信息摘要对象的提供程序。
static boolean isEqual(byte[] digesta, byte[] digestb) 
          比較两个摘要的相等性。
 void reset() 
          重置摘要以供再次使用。
 String toString() 
          返回此信息摘要对象的字符串表示形式。
 void update(byte input) 
          使用指定的字节更新摘要。
 void update(byte[] input) 
          使用指定的字节数组更新摘要。
 void update(byte[] input, int offset, int len) 
          使用指定的字节数组,从指定的偏移量開始更新摘要。

 void update(ByteBuffer input) 
          使用指定的 ByteBuffer 更新摘要。
二、实际实践

2.1、创建 
MessageDigest 
对象
计算信息摘(即
散列码
)要做的第一步是创建 
MessageDigest
对象 
实例。像全部的引擎类一样,获取某类报文摘要算法(即
散列算法
,比方
MD5
)的  
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 将返回已初始化过的
MessageDigest对象。因此,它不须要进一步的初始化。
2.2、向
MessageDigest
传送要计算的数据
计算数据的摘要的第二步是向已初始化的
MessageDigest对象提供传送要计算的数据。这将通过一次或多次调用下面某个 
update(更新)方法来完毕:

public

void
update
(
byte
input
);
public

void
update
(
byte
[]
input
);
public

void
update
(
byte
[]
input
,

int
offset
,

int
len
);

2.3、计算摘要
通过调用 update 方法向
MessageDigest对象
传送要计算的数据后,你就能够调用下面某个 digest(摘要)方法来计算摘要(即
生成
散列码):

public

byte
[]
digest
();
public

byte
[]
digest
(
byte
[]
input
);
public

int
digest
(
byte
[]
buf
,

int
offset
,

int
len
);

前两个方法返回计算出的摘要。后一个方法把计算出的摘要储存在所提供的 buf 缓冲区中,起点是 offset。len 是 buf 中分配给该摘要的字节数。

该方法返回实际存储在 buf 中的字节数。

对第二个接受输入字节数组变量的 digest 方法的调用等价于用指定的输入调用:

    public void update(byte[] input)

,接着调用不带參数的 digest 方法.

三、样例演示

3.1、★ 编程思路:
java.security包中的
MessageDigest类提供了计算消息摘要

即生成
散列码
的方法。首先生成对象,运行其
update( )方法可
以将原始数据传递给该对象,然后运行其
digest( )方法就可以得到消息摘要。详细过程例如以下:
(1)生成MessageDigest对象

MessageDigest m=MessageDigest.getInstance(“MD5”);

MessageDigest类也是一个工厂类,其构造器是受保护的。不同意
直接使用new MessageDigist( )来创建对象,而必须通过其静态方法
getInstance( )生成
MessageDigest对象
当中传入的參数指定计算消息摘要所使用的算法,经常使用的有”
MD5“,”
SHA“等。
(2)传入须要计算的字符串

m.update(x.getBytes(“UTF8” ));

分析:x为须要计算的字符串,update传入的參数是字节类型或字节类型数组。对于字符串,须要先使用getBytes( )方法生成字符串数组。
(3)计算消息摘要

byte s[ ]=m.digest( );

分析:运行MessageDigest对象的digest( )方法完毕计算。计算的结果通过字节类型的数组返回。
(4)处理计算结果
必要的话能够使用例如以下代码将计算结果(byte数组)转换为字符串。



static

String
convertToHexString
(
byte
data
[])

{

StringBuffer
strBuffer
=

new

StringBuffer
();

for

(
int
i
=

0
;
i
<
data
.
length
;
i
++)

{

strBuffer
.
append
(
Integer
.
toHexString
(
0xff

&
data
[
i
]));

}

return
strBuffer
.
toString
();

}

3.2、演示样例一
完整程序例如以下:

public

class

MessageDigestDemo

extends

Thread

{

public

void
run
()

{

String
text
=

“abc”
;

byte
data
[]

=

null
;

MessageDigest
m
;

try

{

data
=
text
.
getBytes
(
“UTF8”
);

m
=

MessageDigest
.
getInstance
(
“MD5”
);

m
.
update
(
data
);

byte
resultData
[]

=
m
.
digest
();

System
.
out
.
println
(
convertToHexString
(
resultData
));

}

catch

(
NoSuchAlgorithmException
e
)

{

// TODO Auto-generated catch block

e.printStackTrace();

} catch (UnsupportedEncodingException e) {

// TODO Auto-generated catch block

e.printStackTrace();

}

}

static

String
convertToHexString
(
byte
data
[])

{

StringBuffer
strBuffer
=

new

StringBuffer
();

for

(
int
i
=

0
;
i
<
data
.
length
;
i
++)

{

strBuffer
.
append
(
Integer
.
toHexString
(
0xff

&
data
[
i
]));

}

return
strBuffer
.
toString
();

}
}

★执行结果

900150983cd24fb0d6963f7d28e17f72

 3.3、演示样例二
在这里我们将对计算生成的md5使用
 sun.misc.BASE64Encoder进行简单的加密。

   
public

String
md5sumWithEncoder
(
String
text
)

throws

NoSuchAlgorithmException
,
 
UnsupportedEncodingException
{
       
/*确定计算方法*/
       
MessageDigest
md5
=
MessageDigest
.
getInstance
(
“MD5”
);
        BASE64Encoder base64en
=

new
BASE64Encoder
();
       
/*加密后的散列码字符串*/
       
String
strMd5
=
base64en
.
encode
(
md5
.
digest
(
text
.
getBytes
(
“utf-8”
)));
       
return
strMd5
;
   
}

调用函数

String
str
=
“0123456789”
 
System
.
out
.
println

md5sumWithEncoder

str
));

 输出
eB5eJF1ptWaXm4bijSPyxw==

3.4、演示样例三

关于此请參考《
一点关于计算MD5的封装

转载于:https://www.cnblogs.com/mfrbuaa/p/4585387.html

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/148480.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • stl库,基本操作代码

    stl库,基本操作代码

    2021年9月27日
    54
  • 万字长文告诉新手如何学习Python图像处理(上篇完结 四十四) | 「Python」有奖征文

    万字长文告诉新手如何学习Python图像处理(上篇完结 四十四) | 「Python」有奖征文这篇文章是图像处理的最后一篇文章,后面我们将进入新的章节。图像处理文章主要讲解的图像处理方法包括图像几何运算、图像量化采样、图像点运算、图像形态学处理、图像增强、图像平滑、图像锐化、图像特效、图像分割、傅里叶变换与霍夫变换、图像分类等。个人感觉如果你是编程初学者、Python初学者或图像处理爱好者,这个系列真心适合你学习,并且这篇文章算是Python图像处理的学习路线,希望您喜欢。

    2022年10月14日
    1
  • String、StringBuilder和StringBuffer

    String、StringBuilder和StringBuffer这三个类之间的区别主要是在两个方面,即运行速度和线程安全这两方面。首先说运行速度,或者说是执行速度,在这方面运行速度快慢为:StringBuilder &gt; StringBuffer &gt; String  String最慢的原因:  String为字符串常量,而StringBuilder和StringBuffer均为字符串变量,即String对象一旦创建之后该对象是不可更改的,但…

    2022年6月13日
    28
  • Linux下的文本编辑器介绍「建议收藏」

    Linux下的文本编辑器介绍「建议收藏」关于文本编辑器文本编辑器有很多,比如图形模式的gedit、kwrite、OpenOffice……,文本模式下的编辑器有vi、vim(vi的增强版本)和nano……vi和vim是我们在Linux中最常用的编辑器。我们有必要介绍一下vi(vim)最简单的用法,以让Linux入门级用户在最短的时间内学会使用它。 nano工具和DOS操作系统下的edit操作相似,使用简单…

    2022年7月26日
    6
  • vbs远程木马_vbs 访问webservice

    vbs远程木马_vbs 访问webservicexp、2003开3389+非net创建管理用户+Shift后门+自删除脚本+提权VBS整理收集2010年12月07日  xp、2003开3389+非net创建管理用户+Shift后门+自删除脚本  vbsonerrorresumenext  constHKEY_LOCAL_MACHINE=&H80000002  strComputer="."  Se…

    2025年11月23日
    2
  • CEGUI小结

    CEGUI小结CEGUI文件类型.scheme它是CEGUI首先调用的一个文件,内容包括要使用的imageset文件、所对应的looknfeel文件,以及将要在looknfeel定义的控件的类型、工厂、渲染器和在looknfeel中的名字。如其中windowset指定了装载模块(.dll等)的名称,和一组可以注册到系统中的widget.不同版本的CEGUI里面scheme文件的结构可能

    2022年7月23日
    7

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号