`
san_yun
  • 浏览: 2676713 次
  • 来自: 杭州
文章分类
社区版块
存档分类
最新评论

md5算法

 
阅读更多

MD5简介:

MD5的全称是Message-Digest Algorithm 5,在90年代初由MIT的计算机科学实验室和RSA Data Security Inc发明,经MD2、MD3和MD4发展而来。

Message-Digest泛指字节串(Message)的Hash变换,就是把一个任意长度的字节串变换成一定长的大整数。请注意我使用了“字节串”而不是“字符串”这个词,是因为这种变换只与字节的值有关,与字符集或编码方式无关。

MD5将任意长度的“字节串”变换成一个128bit的大整数,并且它是一个不可逆的字符串变换算法,(我刚开始还愚蠢的认为MD5是可逆的算法感谢Stkman大哥的讲解)换句话说就是,即使你看到源程序和算法描述,也无法将一个MD5的值变换回原始的字符串,从数学原理上说,是因为原始的字符串有无穷多个,这有点象不存在反函数的数学函数。

 

MD5是输入不定长度信息,输出固定长度128-bits的算法。经过程序流程,生成四个32位数据,最后联合起来成为一个128-bits散列。基本方式为,求余、取余、调整长度、与链接变量进行循环运算。得出结果。

F(X,Y,Z) = (X\wedge{Y}) \vee (\neg{X} \wedge{Z})
G(X,Y,Z) = (X\wedge{Z}) \vee (Y \wedge \neg{Z})
H(X,Y,Z) = X \oplus Y \oplus Z
I(X,Y,Z) = Y \oplus (X \vee \neg{Z})

\oplus, \wedge, \vee, \negXOR, AND, OR , NOT 的符号。


MD5的典型应用是对一段Message(字节串)产生fingerprint(指纹),以防止被“篡改”。举个例子,你将一段话写在一个叫readme.txt文件中,并对这个readme.txt产生一个MD5的值并记录在案,然后你可以传播这个文件给别人,别人如果修改了文件中的任何内容,你对这个文件重新计算MD5时就会发现。如果再有一个第三方的认证机构,用MD5还可以防止文件作者的“抵赖”,这就是所谓的数字签名应用。

MD5还广泛用于加密和解密技术上,在很多操作系统中,用户的密码是以MD5值(或类似的其它算法)的方式保存的,用户Login的时候,系统是把用户输入的密码计算成MD5值,然后再去和系统中保存的MD5值进行比较,而系统并不“知道”用户的密码是什么。

一些黑客破获这种密码的方法是一种被称为“跑字典”的方法。有两种方法得到字典,一种是日常搜集的用做密码的字符串表,另一种是用排列组合方法生成的,先用MD5程序计算出这些字典项的MD5值,然后再用目标的MD5值在这个字典中检索。

即使假设密码的最大长度为8,同时密码只能是字母和数字,共26+26+10=62个字符,排列组合出的字典的项数则是P(62,1)+P(62,2)….+P(62,8),那也已经是一个很天文的数字了,存储这个字典就需要TB级的磁盘组,而且这种方法还有一个前提,就是能获得目标账户的密码MD5值的情况下才可以

 

python里使用md5:

import hashlib
m = hashlib.md5()
m.update('flkdsjfldsjf')
m.hexdigest()

 

 

参考:

http://blog.chenlb.com/2009/06/java-md5.html

http://blog.chenlb.com/2009/06/solr-sint-hashcode-conflict-cause-solr-memcached-bug.html

 

分享到:
评论

相关推荐

    matlab实现md5算法,md5算法详解,matlab

    总结来说,MATLAB实现MD5算法涉及的主要知识点包括:MD5算法的背景和用途,哈希函数的基本概念,MD5算法的四轮循环结构,FF、GG、HH、II四个非线性函数的作用,以及MATLAB中位运算和数组操作的应用。通过学习这个...

    MD5算法封装DLL MD5算法封装DLL MD5算法封装DLL

    MD5算法封装DLL是指将MD5算法封装到动态链接库(DLL)文件中,供其他程序调用。DLL是一种可重用代码的模块,它可以包含执行特定任务的函数或其他可执行代码。通过这种方式,开发人员无需在每个项目中实现MD5算法,...

    MD5算法BCB模块

    这对于快速实现MD5计算功能非常方便,尤其适合那些不熟悉MD5算法底层实现的开发者。 Borland C++ Builder(简称BCB)是Embarcadero Technologies开发的一款集成开发环境,主要用于编写C++应用程序。Bcb6是其第六个...

    md5算法流程图

    ### MD5算法详解 #### 一、概述 MD5(Message-Digest Algorithm 5)是一种广泛使用的散列函数,能够将任意长度的消息压缩成一个固定长度(128位)的散列值,通常用于数据完整性的校验、密码存储等场景。MD5算法的...

    MD5算法详细流程(pdf)

    ### MD5算法详解 #### 一、MD5算法概述 MD5(Message-Digest Algorithm 5)是一种广泛使用的散列函数,它可以将任意长度的消息转换成一个固定长度的散列值,通常用来验证数据的完整性。MD5算法的核心在于它能够快速...

    5_基于MD5的文件完整性检测程序_完整性_md5算法_

    然而,需要注意的是,MD5算法虽然高效且实用,但由于存在碰撞攻击的可能性(即不同的输入可能会得到相同的MD5摘要),所以在安全性要求较高的场景,MD5已经逐渐被SHA-256等更安全的哈希算法所取代。 在使用"基于MD5...

    C语言MD5算法STM32单片机亲测可用

    总的来说,C语言实现的MD5算法在STM32单片机上的应用,需要对C语言编程、嵌入式系统开发以及MD5算法本身有深入理解。通过 lwIP协议栈中的MD5功能,可以增强系统的安全性和可靠性,特别是在网络通信和数据保护方面。

    C++实现MD5算法程序设计与实现.zip

    MD5算法是一种广泛使用的 Hash 算法,常用于确保信息传输的完整性与一致性。对于输入的任一不定长度信息, MD5算法在对最后一块进行填充后用512个比特对其进行分组,使用压缩函数将其生成4个32比特的数据,合并为128...

    MD5 算法详解以及代码

    MD5 算法详解及 Java 实现 在信息安全领域中,MD5 算法是一种常用的摘要算法,用于生成信息的数字指纹。MD5 全称为 Message-Digest Algorithm 5,即信息-摘要算法 5。它可以将任意长度的信息转换为一个固定长度的...

    md5算法实例

    在本项目中,"md5算法实例"可能是实现了一个简单的MD5计算功能,用户可以通过输入任何值,程序会返回这个值经过MD5算法处理后的哈希结果。这样的实例通常涉及以下编程知识点: 1. **哈希函数**:理解哈希函数的基本...

    基于MD5算法的文件完整性检查工具

    文件完整性检查工具,如"MD5 Checksum Verifier v3.9-CRD",是利用MD5算法来验证文件是否保持原样的实用程序。它的工作原理是先计算原始文件的MD5哈希值,然后在文件传输或操作后再次计算该值,对比两次哈希值是否...

    md5_MD5ppt下载_md5算法_

    标题中的“MD5ppt下载”可能指的是包含MD5算法讲解的PPT教学材料,这种材料通常会深入浅出地介绍MD5的工作原理、计算过程以及其在实际中的应用。在描述中提到“与学校老师教学PPT上的讲解有所更改”,这可能意味着这...

    MD5算法java篇

    ### MD5算法在Java中的实现 #### 一、概述 MD5(Message-Digest Algorithm 5)是一种广泛使用的散列函数,它能够将任意长度的数据转换为一个固定长度(通常是128位)的十六进制字符串。由于其计算速度快且结果不...

    md5算法.可以对文件和字符串计算md5值

    2. **编写MD5头文件(Md5.h)**:这个头文件通常包含MD5算法的结构体定义,如MD5_CTX,用于存储中间计算结果。还会声明MD5的初始化函数(如MD5_Init)、更新函数(如MD5_Update)和最终化函数(如MD5_Final),它们...

    c语言实现md5算法

    在提供的压缩包文件"MD5算法"中,可能包含了实现MD5算法的C语言源代码、测试用例、以及可能的算法分析文档。通过阅读和理解这些文件,你可以深入学习MD5算法的实现细节,并且能够应用到实际项目中,如数据完整性校验...

    MD5算法代码

    在学习MD5算法时,可以参考提供的"MD5算法代码及测试参考"文件。这份文件可能包含了MD5算法的实现,可能是用某种编程语言如Python、Java或C++编写。通过阅读和理解代码,你可以了解MD5的具体计算过程,包括如何将...

    MD5 算法 示例程序

    在提供的文件列表中,`md5.cpp`和`test.cpp`可能是实现MD5算法的源代码,`md5lib.h`可能是包含MD5函数声明的头文件,而`md5.h`可能包含了更具体的MD5实现细节或相关辅助函数。`md5.rar`是一个压缩文件,可能包含了...

    md5算法与数字签名

    ### MD5算法与数字签名 #### 一、引言 随着互联网技术的飞速发展,信息安全问题日益凸显,其中信息的完整性保护变得尤为重要。传统的加密技术、访问控制技术和认证技术等虽能有效防止未授权访问,但对于信息一旦被...

    MD5算法源码;加密算法

    1. **MD5的基本结构**:MD5算法由四个不同的处理函数(F, G, H, I)和一系列的位操作组成,包括左移、异或等。这些函数和操作用于迭代处理输入数据的512位块,最终生成四个128位的中间结果,组合成最终的128位摘要。...

Global site tag (gtag.js) - Google Analytics