`
bcyy
  • 浏览: 1824480 次
文章分类
社区版块
存档分类
最新评论

SHA-1,MD5简单介绍

 
阅读更多

MD5(RFC1321)是Rivest于1991年对MD4的改进版本。它对输入仍以512位分组,其输出是4个32位字的级联,与MD4相同。MD5比MD4来得复杂,并且速度较之要慢一点,但更安全,在抗分析和抗差分方面表现更好。
MD5是一种不可逆的加密算法,目前是最牢靠的加密算法之一,尚没有能够逆运算的程序被开发出来,它对应任何字符串都可以加密成一段唯一的固定长度的代码。
那么它有什么用呢?很简单,通过它可以判断原始值是否正确(是否被更改过)。一般用于密码的加密。而我们所提供的MD5校验码就是针对安装程序的唯一对应的一段代码。你可以使用任何MD5运算器对下载的文件进行运算,运算出来的结果如果完全符合我们提供的MD5校验码,那么说明你下载的这个程序没有被中途修改过。
  这个特征码有如下特性,首先它不可逆,例如我有一段秘密的文字如:"MySecretWords",经算法变换后得到MD5码(b9944e9367d2e40dd1f0c4040d4daaf7),把这个码告诉其他人,他们根据这个MD5码是没有系统的方法可以知道你原来的文字是什么的。
  其次,这个码具有高度的离散性,也就是说,原信息的一点点变化就会导致MD5的巨大变化,例如"ABC"MD5(902fbdd2b1df0c4f70b4a5d23525e932)和"ABC"(多了一空格)MD5(12c774468f981a9487c30773d8093561)差别非常大,而且之间没有任何关系,也就是说产生的MD5码是不可预测的。
  最后由于这个码有128位那么长,所以任意信息之间具有相同MD5码的可能性非常之低,通常被认为是不可能的。
  所以一般认为MD5码可以唯一地代表原信息的特征,通常用于密码的加密存储,数字签名,文件完整性验证等。

=====================================================================================

SHA1是由NISTNSA设计为同DSA一起使用的,它对长度小于264的输入,产生长度为160bit的散列值,因此抗穷举(brute-force)性更好。SHA-1设计时基于和MD4相同原理,并且模仿了该算法。SHA-1是由美国标准技术局(NIST)颁布的国家标准,是一种应用最为广泛的hash函数算法,也是目前最先进的加密技术,被政府部门和私营业主用来处理敏感的信息。而SHA-1基于MD5,MD5又基于MD4。
论坛里提供的系统镜像文件的hash也就是微软官方提供的SHA-1值,下载后和此值对应,就说明你下载过程中文件没有被更改,属于原版。


http://blog.csdn.net/frognoble/article/details/1508845

分享到:
评论

相关推荐

    C# MD5加密 sha-1 算法

    非常简单的SHA-1算法和MD5算法,看了后就能明白. SHA-1比MD5多32位密文,所以更安全。由于同样的原因,MD5比SHA-1的运算速度更快。

    java实现的MD5和SHA-1加密源代码

    简单的对字符串进行MD5和SHA-1加密 简单的对字符串进行MD5和SHA-1加密 、简单的对字符串进行MD5和SHA-1加密 使用示例: 1. Crypt.md5("123456") = "e10adc3949ba59abbe56e057f20f883e"; 2. Crypt.sha1("123456") ...

    Java SHA-1 MD5 简单实现

    一个Java小程序 实现Hash算法 可直接运行

    openChecksum:使用多平台工具检查 MD5、SHA-1 和 SHA-256。-开源

    使用 QT 开发的多平台简易工具检查 MD5、SHA-1 和 SHA-256 校验和。

    md5和sha-1加密器

    c#做的简易加密。实现md5和sha-1加密。c#初学者必看之一

    sha1_md5校验工具HashMyFiles汉化版.rar

    本工具能够校验文件的MD5值、SHA1/CRC32/SHA-256/SHA-512/SHA-384值。软件虽然很小,但功能却很强大,集成多项校验与一身。软件使用比较简单,可以通过打开文件来进行校验,也可以将要校验的文件直接拖放到软件界面...

    ezcrypto:为 NodeJS 提供标准和安全的加密算法。 支持 MD5、SHA-1、SHA-256、RC4、Rabbit、AES、DES、PBKDF2、HMAC、OFB、CFB、CTR、CBC

    ###MD5 MD5 是一种广泛使用的哈希函数。 它已被用于各种安全应用程序,也常用于检查文件的完整性。 但是,MD5 不是抗冲突的,它不适合依赖此属性的应用程序,例如 SSL 证书或数字签名。 var digest = Crypto.MD5(...

    Java 详解单向加密--MD5、SHA和HMAC及简单实现实例

    主要介绍了Java 详解单向加密--MD5、SHA和HMAC及简单实现实例的相关资料,需要的朋友可以参考下

    MD5校验小程序

    该标签可以帮助你方便地计算文件的 MD2、MD4、MD5、CRC-32、HAVAL、RIPEMD-128、RIPEMD-256、RIPEMD-320、SHA-1、SHA-256、SHA-384、SHA-512、Tiger、Whirlpool、Adler32值。这些都是在你验证文件完整性时比较常用的...

    杂凑算法详解集V1.1 含C代码 MD5、SHA1、SHA256、SHA512

    详细整理了MD5、SHA1、SHA256、SHA512的算法,如果你有C语言基础,那么看完你就能写出代码了。 内附代码用于理解算法,只经过简单测试,仅供参考,建议自行撰写、优化。 代码使用示例: st_md5 tMD5; md5_Init(&...

    MD5、SHA1校验工具

    本工具用于计算文本或文件的校验码(计算文件的消息摘要), 目前系统支持MD5(128位)/SHA1(160位) /SHA256(256位)/SHA384(384位)/SHA512(512位)/RIPEMD160(160位)算法. 简单地理解, 可以认为, 消息摘要算法就是将一...

    暴力破解AES DES SHA MD5

    用java写的暴力破解,专门破解AES,DES,SHA,MD5. 你们可以自己再次的去完善一下,这里纯属简单版本。 用java写的暴力破解,专门破解AES,DES,SHA,MD5. 你们可以自己再次的去完善一下,这里纯属简单版本。 用java写的...

    MD5 SHA236 SHA128 等值的计算工具

    MD5 SHA236 SHA128 等值的计算工具,简单易用,十分方便,直接拖入就可使用

    登陆加密MD5+Salt+SHA1附代码

    SHA-1是一种数据加密算法,该算法的思想是接收一段明文,然后以一种不可逆的方式将它转换成一段(通常更小)密文,也可以简单的理解为取一串输入码(称为预映射或信息),并把它们转化为长度较短、位数固定的输出...

    MD5 SHA1 CRC校验值生成工具

    MD5 SHA1 CRC校验值生成工具,简单小巧

    计算md5和sha1的hash值

    这是我从sourceforge.net下载的一个计算hash值的软件,里面有我编写的一个计算sha1的简单函数,用于说明使用方法,计算其他hash的方法同sha1.该程序在VS.net和g++上编译成功.

    JPassword Recovery Tool:用于压缩档案和 md5、sha-1/2 哈希的密码恢复工具-开源

    它还可以对 Windows 和 Linux 的 MD2、MD5、SHA-1 和 SHA-2 哈希(SHA-256、SHA-384、SHA-512)、CRC16、CRC32、CRC64 和 Adler32 哈希密码进行暴力破解。 它需要 java 7u4 及更高版本,以及 7-zip v9.20 及更高...

    fastcoll伪造MD5值

    我们用HashX校验他们的MD5值,可以发现是完全一样的,但是在HashX中用“SHA-1”加密算法进行校验的时候,结果竟然是不同的(SHA-1加密算法生成的结果也是独一无二的)!可见这已经是完全不同的两个文件,但是他们的...

    Python md5与sha1加密算法用法分析

    主要介绍了Python md5与sha1加密算法,简单介绍了md5级sha1加密算法的概念、原理,并结合实例形式分析了Python使用hashlib模块实现加密功能的具体操作技巧,需要的朋友可以参考下

    fHash 文件Hash(md5 sha1 sha256 crc32)计算器

    简单快速的文件 Hash 计算器(也就是文件MD5计算器) 校验 MD5, SHA1, CRC32 还可以检测文件大小和程序版本 支持拖放 集成系统右键菜单 支持 Windows 7

Global site tag (gtag.js) - Google Analytics