md5加密解密校验工具

MD5是一种全球公开的加密算法,无论输入字长如何,该算法都会生成32个字符的十六进制字符串,称为哈希或者密文。例如123456加密后是e10adc3949ba59abbe56e057f20f883e。此算法是单向的不可逆,通常无法从MD5中找到原始单词,这是不可破解的。但可以通过穷举字符组合的方式,创建一个庞大的明文密文一一对应查询数据库,以便最大程度地破解原始单词。

字符串的加密结果 (全大写 / 全小写)
16位加密结果:
32位加密结果:
md5加密解密

md5是什么

MD5,Message Digest Algorithm 5,是一种被广泛使用的信息摘要算法,可以将给定的任意长度数据通过一定的算法计算得出一个 128 位固定长度的散列值。如百科介绍,MD5 具有如下特点:

压缩性:任意长度的原数据,其 MD5 值都是固定的,即 128 位;
易计算:计算原数据的 MD5 值是一个比较容易的过程;
抗修改:原数据的任意改动,所得到的 MD5 值都是迥然不同的;
防碰撞:这一点要特别介绍一下。MD5 使用的是散列函数(也称哈希函数),一定概率上也存在哈希冲突(也称哈希碰撞),即多个不同的原数据对应一个相同的 MD5 值。不过,经过 MD4、MD3 等几代算法的优化,MD5 已经充分利用散列的分散性高度避免碰撞的发生。

可以看出,MD5 是一种不可逆的算法,也就说,你无法通过得到的 MD5 值逆向算出原数据内容。正是凭借这些特点,MD5 被广泛使用。

比如,客户端与服务器的 HTTP 通信,通信双方可以将报文内容做一个 MD5 计算,并将计算所得 MD5 值一并传递给彼此,这样,接收方可以通过对报文内容再次做 MD5 计算得到一个 MD5 值,与传递报文中的 MD5 值做比较,验证数据是否完整,或者是否中途被拦截篡改过。

再比如,网络云盘中的文件秒传功能也运用到 MD5 算法。服务器存储文件的时候,同时记录每一个文件的 MD5 值,不同文件对应着不同的 MD5 值。这样,遇到用户上传文件时,将上传文件的 MD5 值与服务器上所有存储的 MD5 值做比较,如果相同,则说明用户上传的文件已经在服务器存有。这样,只需要在数据库表中添加一个记录,映射到对应的文件,而不用重复上传,实现所谓秒传的功能。

当然,这只是常见的两个例子,MD5 的用途大有所在。值得注意的是,严格意义上来讲,MD5 以及 SHA1 并不属于加密算法,也不属于签名算法,而是一种摘要算法,用于数据完整性校验等。