目前 RSA 算法相关的教程和文章都有一个根本性缺陷

2020-02-24 09:43:46 +08:00
 itskingname

注意我是说这些教程和文章有缺陷,不是说 RSA 算法有缺陷。

我们知道,在 RSA 算法里面,需要选定两个足够大的质数 p 和 q 相乘得到 N,由于对 N 进行分解非常困难,所以能保证 RSA 算法的安全性。网上的文章也是这样说的。

但是,我在网上看了四十多篇 RSA 相关的文章,所有的文章对于如何选定 p 和 q,全都没有讲。都只是轻描淡写地说一句:

选定两个足够大的质数 p 和 q

我现在就问你,你给我找两个质数,每个质数要超过 100 位数。你能在短时间找出来吗?

所以我很好奇,现在的 RSA 库里面,他们是怎么选定这个 p 和 q 的呢?难道是现场 2,3,5,7,11,13...这样一个一个数直到找到足够大的为止?还是提前算好并存在了某个地方,要用的时候直接随机取出来用?

目前 python-rsa 库确实是一个一个数出来的:

4166 次点击
所在节点    分享发现
42 条回复
fbi007130
2020-02-25 13:52:57 +08:00
因为面向的人不同
大学时候密码学课上把 RSA 分析得很透切,关于楼主提到的问题,也详尽分析过。
同时当时。。。针对 1024bit rsa 也已经有一些破解的办法 /手段了
no1xsyzy
2020-02-26 10:41:39 +08:00
@liaoliaojun 你大约需要 (10^41/41-10^40/40)*128/8/1024/1024/1024/1024 = 31107907577789752039967513.66592 PB 来存储这些素数。

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

https://tanronggui.xyz/t/646975

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

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

© 2021 V2EX