ch52数字签名与认证散列算法.ppt

上传人:牧羊曲112 文档编号:5421410 上传时间:2023-07-05 格式:PPT 页数:18 大小:221.49KB
返回 下载 相关 举报
ch52数字签名与认证散列算法.ppt_第1页
第1页 / 共18页
ch52数字签名与认证散列算法.ppt_第2页
第2页 / 共18页
ch52数字签名与认证散列算法.ppt_第3页
第3页 / 共18页
ch52数字签名与认证散列算法.ppt_第4页
第4页 / 共18页
ch52数字签名与认证散列算法.ppt_第5页
第5页 / 共18页
点击查看更多>>
资源描述

《ch52数字签名与认证散列算法.ppt》由会员分享,可在线阅读,更多相关《ch52数字签名与认证散列算法.ppt(18页珍藏版)》请在三一办公上搜索。

1、第八讲 思考题 1 P141(7)安全的散列函数有哪些特征?第八讲教学要求:(1)掌握单向散列函数概念;(2)了解MD5算法程;(3)了解SHA 安全散列算法;,3.2单向散列函数 单向散列函数,也称hash函数,它可以提供判断电子信息完整性的依据,是防止信息被篡改的一种有效方法。单向散列函数在数据加密、数据签名和软件保护等领域中有着广泛的应用。3.2.1 单向散列函数特点 hash函数的作用是当向hash函数输入一任意长度的的信息M时,hash函数将输出一固定长度为m的散列值h。即:h=h(M),思考题1:安全的hash函数的特点是:1hash函数能从任意长度的M中产生固定长度的散列值h。2

2、已知M时,利用h(M)很容易计算出h。3已知h时,要想从h(M)中计算出M是很困难的。4已知M时,要找出另一信息M,使h(M)=h(M)是很困难的。最常用的hash算法有MD5、SHA算法等。,MD5,MD5(Message-DigestAlgorithm5)是由RonaldL.Rivest(RSA算法中的“R”)这90年代初开发出来的,经MD2、MD3和MD4发展而来。它比MD4复杂,但设计思想类似,同样生成一个128位的信息散列值。其中,MD2是为8位机器做过设计优化的,而MD4和MD5却是面向32位的计算机。2004年8月,在美国召开的国际密码学会议(Crypto2004)上,王小云教授

3、给出破解MD5、HAVAL-128、MD4和RIPEMD算法的报告。给出了一个非常高效的寻找碰撞的方法,可以在数个小时内找到MD5的碰撞。,MD5算法步骤,1)填充消息:任意长度的消息首先需要进行填充处理,使得填充后的消息总长度与448模512同余(即填充后的消息长度448 mod 512)。填充的方法是在消息后面添加一位“1”,后续都是“0”。2)添加原始消息长度:在填充后的消息后面再添加一个64位的二进制整数表示填充前原始消息的长度。这时经过处理后的消息长度正好是512位的倍数。3)初始值(IV)的初始化:MD5中有四个32位缓冲区,用(A,B,C,D)表示,用来存储散列计算的中间结果和最

4、终结果,缓冲区中的值被称为链接变量。首先将其分别初始化为为:A=0 x01234567,B=0 x89abcdef,C=0 xfedcba98,D=0 x76543210。,3.2.2 MD5算法4)以512位的分组为单位对消息进行循环散列计算:经过处理的消息,以512位为单位,分成N个分组,用M0,M1,.,MN-1。MD5对每个分组进行散列处理。每一轮的处理会对(A,B,C,D)进行更新。5)输出散列值:所有的N个分组消息都处理完后,最后一轮得到的四个缓冲区的值即为整个消息的散列值。,MD5算法步骤-续,最后的输出就是A、B、C、D的级联,即A作为低位,D作为高位,共128位输出。MD5被

5、广泛用于加密和解密技术中,可以用来保护密码、生成软件注册码等。MD5典型应用:在很多操作系统中,用户的密码是以MD5值的方式保存的.,3.2.3 SHA算法,SHA-1散列算法过程如下:1SHA-1对输入明文的预处理过程和MD5相同,但SHA输出为160位,并分别存储于五个32位变量中,这五个变量初始值为:A0 x67452301 B0 xefedab89 C0 x98badefe D0 x10325476 E0 xc3d2elf0 和MD5算法一样,SHA-1一次处理512位信息,主循环的次数就是信息中512位分组的数目。,3.2.4 SHA-1与MD5比较,1 安全性 SHA-1摘要比MD

6、5摘要长32比特,强行攻击及伪造签名更难2 速度 SHA-1比MD5的运行步骤多16个,占用的缓存多了32位,所以速度慢25%3简单性 总体上SHA-1对每一步的操作描述比MD5简单,数字签名,数字签名也是一种认证机制,它是公钥密码学发展过程中的一个重要组成部分,是公钥密码算法的典型应用。数字签名的应用过程是,数据源发送方使用自己的私钥对数据校验和或其他与数据内容有关的信息进行处理,完成对数据的合法“签名”,数据接收方则利用发送方的公钥来验证收到的消息上的“数字签名”,以确认签名的合法性。,数字签名,数字签名需要满足以下条件:签名的结果必须是与被签名的消息相关的二进制位串;签名必须使用发送方某

7、些独有的信息(发送者的私钥),以防伪造和否认;产生数字签名比较容易;识别和验证签名比较容易;给定数字签名和被签名的消息,伪造数字签名在计算上是不可行的。保存数字签名的拷贝,并由第三方进行仲裁是可行的。,数字签名,(1)消息发送方式与散列函数对消息进行计算,得到消息的散列值。(2)发送方使用自己的私钥对消息散列值进行计算,得到一个较短的数字签名串。(3)这个数字签名将和消息一起发送给接收方。(4)接收方首先从接收到的消息中用同样的散列函数计算出一个消息摘要,然后使用这个消息摘要、发送者的公钥以及收到的数字签名,进行数字签名合法性的验证。,盲签名,盲签名是Chaum在1982年首次提出的,并利用盲

8、签名技术提出了第一个电子现金方案。盲签名因为具有盲性这一特点,可以有效的保护所签名的消息的具体内容,所以在电子商务等领域有着广泛的应用。盲签名允许消息发送者先将消息盲化,而后让签名者对盲化的消息进行签名,最后消息拥有者对签名除去盲因子,得到签名者关于原消息的签名。,盲签名的性质,它除了满足一般的数字签名条件外,还必须满足下面的两条性质:1.签名者不知道其所签名的消息的具体内容。2.签名消息不可追踪,即当签名消息被公布后,签名者无法知道这是他哪次的签署的。,盲签名的步骤,A期望获得对消息m的签名,B对消息m的盲签名的实现描述如下:盲化:A对于消息进行处理,使用盲因子合成新的消息M并发生给B;签名

9、:B对消息M签名后,将签名(M,sign(M)返回给给A;去盲:A去掉盲因子,从对M的签名中得到B对m的签名。,好的盲签名的性质,不可伪造性:除了签名者本人外,任何人都不能以他的名义生成有效的盲签名。不可抵赖性:签名者一旦签署了某个消息,他无法否认自己对消息的签名。盲性:签名者虽然对某个消息进行了签名,但他不可能得到消息的具体内容。不可跟踪性:一旦消息的签名公开后,签名者不能确定自己何时签署的这条消息。,盲签名机制,当用户从银行提款时,他先为硬币随机生成一个很大的编码,然后利用盲签名机制,银行可用代表不同面值的密钥对这枚硬币签名,从而标定硬币的币值。由于编码很大(大于200位数字),重复的概率

10、可以忽略不计,再加上盲签名让银行无法知道硬币编号,从而不能将其记录下来。为了防止电子现金的复制,Chaum引入一种盲记录机制,第一次使用电子硬币时无法进行跟踪,而如果重复使用,就有足够多的信息能查出使用者的帐户信息,从而采取相应的处罚措施。对电子硬币的检验同普通的签名检验一样,商家收到用户支付的电子硬币时,可以检验该硬币的真实性,之后再将其发给银行去核实其唯一性。当一个消费者想从金融机构提取一笔电子现金时,金融机构产生电子货币的数据,包含随机的货币序号,同时任取一个随机数,也称盲因子,对电子现金进行盲变换。金融机构将这些数据送给消费者,消费者去掉盲因子后,就可以使用经过金融机构验证有效的电子货币。但金融机构以后并不能得到这笔钱被如何使用的记录。,

展开阅读全文
相关资源
猜你喜欢
相关搜索

当前位置:首页 > 生活休闲 > 在线阅读


备案号:宁ICP备20000045号-2

经营许可证:宁B2-20210002

宁公网安备 64010402000987号