逆向一条 MD5-32 大概需要多少运算能力?

2012-03-09 13:36:14 +08:00
 zhuang
起因大家都懂得,这里只是做个简单的计算,判断什么的我不会写的。
大前提是:MD5 是迄今为止没有算法上的太大漏洞,而且要求是逆向(不是寻找碰撞)。

1. 彩虹表有用吗?

在这个特定的情形下,没有。解释如下:

MD5 是一种摘要散列算法,任意大小的原文都会转化为定长的密文。
彩虹表是一种预先计算的原文到密文的映射,如果密文在彩虹表的覆盖空间里,那么就可以反查到原文。而原文空间理论上无限大,完全运算并存储这些映射非常消耗资源,所以,彩虹表更多的是一种“空间时间消耗都可以接受”的算法加上数据集合。

很显然,某个 MD5 运算结果不可能在常见的彩虹表覆盖空间里。
(注,一个9位以内数字组合的彩虹表大概要接近 1TB 而由于算法链式验证的原因,实际计算次数要数倍于穷举运算,参见 http://project-rainbowcrack.com/table.htm

2. 爆破怎么做?

爆破就是拼运算力了。
手机号字段大概有 1e7 种组合,而后面还有随机字符串,不知道有多长,姑且算作 5 位吧,字母数字组合,就简化作 1e8 种组合好了。
现在假设你运气足够好,其他位全都猜对了,比如你知道要把 v2ex 逆序之类的,需要验证 1e15 次吧。
(这是一个非常简单的估算,纯粹估算下限)

3. GPU 通用运算能力到底有多强?

最强的通用计算单元 ATI HD6990 大概运算力是 1e10 次,cpu 相对于 gpu 小太多数量级,所以可以不考虑了。
假如你能够调用 100 显卡的某超算集群,一个小时的运算力大概是 1e15 次验证。
(参见 http://golubev.com/gpuest.htm

4. 一些细节

¥ 这个字符是 unicode 字符,而 md5 并没有针对 unicode 的特定实现。
实际的实现是先转换成 utf8/utf16/ansi 等等编码形式再进行计算。
(某些特定程序支持传入 unicode 字符串,但依旧需要内部进行编码转换)
这一条的意义是说,如果加密者的编码是 utf8 而你的运算程序是 ansi 编码,那就不用想了,永远都不会有结果。

MD5 算法是 16-byte 分段,可以认为运算时间正比于原文长度,目测待解密的原文是 32-byte 左右,即实际运算能力可能要减半。

(假设非常多的时候,参见 http://en.wikipedia.org/wiki/Occam's_razor
12154 次点击
所在节点    信息安全
39 条回复
momou
2012-03-09 13:50:36 +08:00
学习,等高人。。。
GordianZ
2012-03-09 13:53:59 +08:00
关于¥我插一个嘴,如果已经开始爆破了,估计就没用编码直接上HEX了。而且原文应该不在彩虹表里面。

再且,9位数字的彩虹表用不了1GB啊。
1e9种组合,原文2字节,散列16字节 = 18e9 bytes = 18GB.
但是不可否认包含这次的明文的彩虹表肯定不止1TB.
zhuang
2012-03-09 14:03:56 +08:00
@GordianZ

MD5 计算不是说一段一段的,是要形式如:
md5(moc.xe2v1861xxxxxxx¥0XXXXX)=32-hash
这种作为一个待运算的整体对待的。

拿到密文的人现场计算彩虹表和爆破是没有区别的,做表运算量更大。
lch21
2012-03-09 14:14:20 +08:00
8位任意字符组合,半个小时搞定。

100张显卡集群

实践检验过的
d5d
2012-03-09 14:14:46 +08:00
b0ba5f33e8a56957f7700e3ad2158c4d:60
zhuang
2012-03-09 14:33:47 +08:00
@lch21

8 位没有什么意义……这个解密本质上是近似于 15 位纯数字量级。
话说您真见过 100 张显卡的集群吗?呵呵。
lch21
2012-03-09 14:46:17 +08:00
@zhuang 你了解 Bitcoin 挖矿吗?呵呵
bruce
2012-03-09 14:49:30 +08:00
@zhuang 有些事,看看就算了,没必要那么认真
zhuang
2012-03-09 14:55:18 +08:00
@lch21

应该说这个站点里第一个因为 bitcoin 挣到钱的就是我了,而那个时候中文环境没有任何关于 bitcoin 的介绍。v2ex/twitter 上很多人都应该对此有印象。还有我是 bitcoin 黑。

另外,我还接触过前几年曾经的中国第一超算集群。我个人的体会是,要充分调用集群的运算能力,需要的准备工作很麻烦。比如配置你的任务调度系统,再比如实际调用之前的反复验证。

至于 100 张显卡的集群,我真的只能笑一笑。
zhuang
2012-03-09 14:56:08 +08:00
@bruce

谢谢指教。
cooka
2012-03-09 14:58:41 +08:00
@zhuang 破解者设计密码字典(含v2ex,186)对这个(20位以上字符串)反向计算有没有用处呢?
或者说对反向的帮助有多大?
lch21
2012-03-09 15:01:49 +08:00
@zhuang "中国第一超算集群", 你NB,呵呵
zhuang
2012-03-09 15:10:46 +08:00
@cooka

不是很理解你的问题,我猜你是想问,爆破用的字典有什么作用吧?

前面说过 MD5 是一个从“有限信息”去猜“原始信息”的过程,爆破过程就是,我不知到原文是什么,但是我知道原文的可能组合是什么,把这些所有的组合写下来,一一尝试比对即可。
为了加快速度,这个可能的组合要尽量少,但是还一定要保证不把原文排除掉。

一般来说,最难的就是常见的“大小写特殊符号加数字组合”。在这个例子里,假如我知道密码构成是 v2ex.com+11 位手机号的格式,实际的运算量和纯粹计算 11 位手机号组合差不多。
zhuang
2012-03-09 16:22:41 +08:00
@GordianZ

发现我写错了,引用来源里有,应该是9位以内数字字母混合的是 800GB+ 。
Shared
2012-03-11 02:32:24 +08:00
@GordianZ 不同编码的HEX值是不同的,即使是同样的¥使用Unicode的不同编码方式(UTF8,UTF16等等)得到的结果也不同。所以破解的人最后还得注意一下编码问题?要不然很可能得到的结果是一堆乱码,哈哈
afterain
2012-03-11 14:42:11 +08:00
回顾整个事件,这个帖子无论是从技术还是态度上来说都是非常值得学习的。
其他的……
aristotle9
2012-03-11 16:03:09 +08:00
10个节点的cpu+gpu集群对计算能力的提升大概在2个数量级.
http://www.bnu.edu.cn/xzhd/32239.htm
集群的规模对计算能力之数量级的提升基本上是对数函数(lg n),即使出现gpu集群,现有的运算能力还不足以对现行的密码体系造成决定性的打击.
大神打架是拼数量级的.
sigone
2012-03-11 16:04:37 +08:00
舍得 舍得 ... 呵呵
sigone
2012-03-11 16:07:46 +08:00
其实我说的是一句密文,哪位童鞋能算出他的愿意!
Livid
2012-03-12 09:08:22 +08:00
谢谢 @zhuang 的这个帖子,受教了。

昨天晚上自己做了一些实验,这个事情我想应该接近得出结论了。

http://www.v2ex.com/t/29393

我喜欢并且感谢大家从理科角度来论证这个问题。:)

这是一个专为移动设备优化的页面(即为了让你能够在 Google 搜索结果里秒开这个页面),如果你希望参与 V2EX 社区的讨论,你可以继续到 V2EX 上打开本讨论主题的完整版本。

https://www.v2ex.com/t/29152

V2EX 是创意工作者们的社区,是一个分享自己正在做的有趣事物、交流想法,可以遇见新朋友甚至新机会的地方。

V2EX is a community of developers, designers and creative people.

© 2021 V2EX