首页 技术 正文
技术 2022年11月8日
0 收藏 437 点赞 1,473 浏览 912 个字

RSA算法是数学应用于实际的一项伟大发明,起数学过程相对而言还是比较专业的,有兴趣可以看看。

RSA算法的证明过程,详见:http://www.ruanyifeng.com/blog/2013/06/rsa_algorithm_part_one.html

首先默认有个欧拉定理及相关的推论成立,这个要看证明过程不简单

程序员眼中的RSA算法

然后看一下其加密解密的公式,可以试着推导一下:

程序员眼中的RSA算法

可以看出非对称的加密解密过程,在数学上是成立的。

那么回头看它的安全性:就是要确保d不被攻破,d安全的前提是n不被成功分解

1.能不能遍历所有的素数,来猜测p,q?

a)素数有无穷多个,google一下欧几里得的反证妙法;

b)现在再想发现新的素数很困难,数字很大,目前发现的最大质数 十进制表示有17 425 170位,够写一本书;

c)现在发现的素数有多少个呢?这是最关键的。参见:http://www.zhihu.com/question/22356265

64bit的数字 十进制大概是2*10^19,其中质数的个数约为4*10^17次方,差不多有2%的数是质数,想要遍历的话,只能呵呵了。

2.每次生成秘钥对时,都要先有两个大质数,怎么获得两个大质数呢?

a)把所有发现的质数存在本地,每次随机选两个?看看数据量就知道存储不够

b)做一个公共数据库,存储所有发现的质数,每次调库?估一眼储存,还是不够的

c)公共服务随机产生,需要的话去调用接口?不安全,这个数理论上不能在网络中传输,如果公司内网,可以考虑

d)本地随机产生?靠谱,生成复杂度高不?

3.总之要随机生成,参见:http://bindog.github.io/blog/2014/07/19/how-to-generate-big-primes/

a)素数判定方法,复杂度还好,能几乎实时

b)随机寻找的复杂度,由前面64bit的数看,有2%的数是质数,这是可以接受的,平均搜100个能得到两个,1024bit的概率有多大,不清楚

c)真随机性,上面文章中提到的,有意思的斯诺登披露的消息

4.有了两个大素数后,就是软件计算的事,长位数的大数计算,可以用croypt等库来做。网上有些直接贴的代码,学学原理可以,实际用肯定是不行。

相关推荐
python开发_常用的python模块及安装方法
adodb:我们领导推荐的数据库连接组件bsddb3:BerkeleyDB的连接组件Cheetah-1.0:我比较喜欢这个版本的cheeta…
日期:2022-11-24 点赞:878 阅读:9,488
Educational Codeforces Round 11 C. Hard Process 二分
C. Hard Process题目连接:http://www.codeforces.com/contest/660/problem/CDes…
日期:2022-11-24 点赞:807 阅读:5,903
下载Ubuntn 17.04 内核源代码
zengkefu@server1:/usr/src$ uname -aLinux server1 4.10.0-19-generic #21…
日期:2022-11-24 点赞:569 阅读:6,736
可用Active Desktop Calendar V7.86 注册码序列号
可用Active Desktop Calendar V7.86 注册码序列号Name: www.greendown.cn Code: &nb…
日期:2022-11-24 点赞:733 阅读:6,488
Android调用系统相机、自定义相机、处理大图片
Android调用系统相机和自定义相机实例本博文主要是介绍了android上使用相机进行拍照并显示的两种方式,并且由于涉及到要把拍到的照片显…
日期:2022-11-24 点赞:512 阅读:8,127
Struts的使用
一、Struts2的获取  Struts的官方网站为:http://struts.apache.org/  下载完Struts2的jar包,…
日期:2022-11-24 点赞:671 阅读:5,289