听说这玩意可以防篡改

您所在的位置:网站首页 单向散列函数具备的特征有哪些呢图片 听说这玩意可以防篡改

听说这玩意可以防篡改

2024-07-17 02:36| 来源: 网络整理| 查看: 265

这是我要的文件吗?

  由于某些原因,访问国外网站的速度较慢,所以我们常使用镜像网站下载文件。假设你正通过镜像网站从网络上下载一款软件,但是如何保证你下载的软件是正版,没有被恶意篡改过呢?怎么保证我的软件的完整性呢?

单向散列函数

  要解决上述问题就需要用到单向散列函数,单向散列函数相当于为数据增加一个数据指纹,我们使用一个函数计算出数据的指纹,这个指纹是独一无二的,相同数据生成指纹相同,不同数据生成指纹不同(即使一小点改动最终生成的指纹都完全不同),通过对比指纹验证数据是否被篡改过。

如下图所示: 在这里插入图片描述

  单向散列函数有一个输入和一个固定长度的输出。输入称为消息,输出称为散列值。输入可以是一个文件,一个视频,一段程序等等(本质都是二进制数据流),输入不限长度,输出散列值的长度跟消息的长度无关,不论多大长度的消息,都会计算出固定长度的散列值。

单向散列函数性质 对于任何长度的输入数据块都能产生固定长度的输出散列值。能快速计算散列值。消息不同散列值不同,一点点的变动都会引起整个散列值的巨大变化。(因为散列值的长度是固定的,所以有可能会出现不同的消息产生相同散列值的情况,这种情况叫做碰撞)单向性(不能通过散列值反算出消息)。 常用单向散列函数 消息摘要算法(Message Digest)

  MD4 和 MD5 是由 Rivest 分别在 1990 年和 1992 年设计的,现在已经不再安全了。它们接受任意长度数据流后可以产生出一个 128bits(16字节) 的散列值。1996 年后该算法被证实存在弱点,可以被破解,对于需要高度安全性的数据,建议改用其他算法,如下面的 SHA-2。

安全散列算法(Secure Hash Algorithm)

  SHA 算法是一种密码散列函数算法标准,由美国国家安全局研发,SHA 算法经过了 SHA-1,SHA-2,SHA-3。

SHA-1:一种能够产生 160bits(20字节) 散列值的单向散列函数,已经不安全,现在不推荐使用。SHA-2:是 SHA-1 的后继者,其下又可再分为六个不同的算法标准,包括:SHA-224、SHA-256(常用)、SHA-384、SHA-512、SHA-512/224、SHA-512/256。SHA-3:第三代安全散列算法(之前名为 Keccak),这个算法比起其他算法计算速度明显更快。 应用 检测数据是否被篡改(防篡改)基于口令的加密消息认证码数字签名伪随机生成器一次性口令


【本文地址】


今日新闻


推荐新闻


CopyRight 2018-2019 办公设备维修网 版权所有 豫ICP备15022753号-3