书香 发表于 2024-4-6 03:28

【md5的不可逆性】

md5的运算规则就是取数据摘要,比如我们设计一个规则,排除第2个字符
那么123运算后的结果是13,我们无法通过13得出原来的数据是123,因为也可以是1a3

md5就是以上面这种类型的规则为核心去创建的,因此从原则上来说,md5是无法还原的,因为可以有无数种数据的md5相同

那有的人可能会问了,既然有无数种数据的md5相同,那为什么还可以使用md5来验证数据的合法性?

这是因为需求的原因,比如我加载我自己的DLL我会验证md5是否一致,以此判断我的DLL是否被你修改过,虽然你可以找到一段数据的md5和我DLL的md5相同,但是你这段数据还是DLL吗,还能被我的程序加载吗?

所以,使用md5来验证数据的合法性,并不代表着每一个md5对应着唯一的一个数据,而在于对方几乎不可能找出一个又能使用md5又相同的数据


(点击返回课程目录:https://www.52hb.com/thread-58658-1-1.html)

学编程的闹钟 发表于 2024-4-6 12:01

大佬,出一个sm3的教程

优雅 发表于 2024-5-1 23:15

666666666666666666666666666
页: [1]
查看完整版本: 【md5的不可逆性】