您现在的位置是:亿华云 > 应用开发
这么先进的加密算法RSA你知道吗?
亿华云2025-10-09 03:50:22【应用开发】0人已围观
简介前面有人让我讲解一下RSA算法,今天我就用我所学的知识讲解一下,首先我们先了解一下RSARSA是一种非对称加密算法,1977年由罗纳德·李维斯特(Ron Rivest)、阿迪·萨莫尔(Adi Sham
前面有人让我讲解一下RSA算法,先进今天我就用我所学的密算知识讲解一下,首先我们先了解一下RSA
RSA是知道一种非对称加密算法,1977年由罗纳德·李维斯特(Ron Rivest)、先进阿迪·萨莫尔(Adi Shamir)和伦纳德·阿德曼(Leonard Adleman)一起提出的密算,因此以三人姓氏的知道首字母命名了该非对称加密算法,RSA算法。先进
在了解非对称性加密的密算时候我们需要了解什么叫对称性加密。我们就那徐克导演拍的知道电影《智取威虎山》,其中的先进一段对话
土匪:天王盖地虎! 杨子荣:宝塔镇河妖! 土匪:野鸡闷头钻,哪能上天王山! 杨子荣:地上有的密算是米,喂呀,知道有根底! 土匪:拜见过阿妈啦?先进 杨子荣:他房上没瓦,非否非,密算否非否!通过他们的知道对话我们知道 土匪在试探杨子荣的身份。当土匪说,天王盖地虎,我就必须说 宝塔镇河妖!也就是双方都知道 这段话是什么意思。翻译成程序员的话就是 双方都有加密的香港云服务器密钥。因此对称加密也可以说是秘密交易者的暗号。
不过对称加密有一个很大的问题,密钥容易泄露。土匪的暗号被杨子荣知道了这个就很容易取得了他们的信任。
RSA加密
我们需要先预习一下还给数学老师的知识
欧拉函数
在数论中,存在正整数 n,小于n并且与n互质的正整数的数目称为n的欧拉函数记着φ(n)。例如:
φ(7) 7对应的比7小的与7互质的数有1、2、3、4、5、6共6个,因此φ(7)=6; φ(8) 8对应的比8小的与8互质的数有1,3,5,7共4个,云南idc服务商因此φ(8)=4; φ(9) 9对应的比9小的与9互质的数有1,2,4,5,6,7,8共7个,,因此φ(9)=7。通式(P是数N的质因数)
若m n互质:φ(n * m)=φ(n)* φ(m),如果n为质数那么φ(n)=n-1。
分解质因数求值:φ(12)=φ(4 * 3)=φ( 2^2 * 3^1 )=( 2^2 - 2^1 ) * (3^1 - 3^0)=4。
欧拉定理
如果两个正整数m和n互质,那么m的φ(n) 次方对n取余衡等于1。m^φ(n)%n≡1。
费马小定理
存在一个质数p,而整数a不是p的倍数,则存在a^(p-1)%p≡1。费马小定理是欧拉定理的特殊情况。因为φ(p)=p-1(任何数都与质数互质)。
模反元素
如果两个正整数e和x互质,那么一定存在一个整数d,高防服务器使得ed-1能够被x整除,则称d是e对x的模反元素。e * d % x≡1,那么e * d ≡ k*x+1。
由以上定理得出以下几个公式:
m^φ(n)%n≡1 m^(k * φ(n))%n≡1 两端同乘以m m^(k * φ(n)+1)%n≡m e * d≡k * x+1 m^e * d%n≡m 替换第3步k * φ(n)+1而m^e*d%n≡m就是我们需要的一个非对称加密的公式。m为明文,e和d分别对应的是公钥私钥。迪菲卡尔曼秘钥交换对公式拆分:
m^e%n=c 加密 c^d%n=m 解密其中c为通过e加密后的密文,然后通过d可以解出明文m。因此:
公钥: e、n 秘钥:d、n 明文:m 密文:cRSA加密过程
取两个质数p1、p2; 确定n值,n=p1 * p2,n值一般会很大长度一般为1024个二进制位; 确定φ(n),φ(n)=(p1-1) * (p2-1); 确定e值,1 确定d值,e*d%φ(n)=1; 加密 c=m^e%n; 解密m=c^d%n。实际验证:
p1=3, p2=7; n=p1 * p2=3 * 7=21; φ(n)=(p1-1) * (p2-1)=2*6=12; 1 e * d % φ(n)=5 * d % 12=1,得d=17; 设置明文m=3,则c = m^e % n = 3^5 % 21=12; 解密密文m=c^d % n=12^17 % 21=3。通过上面的讲解我们知道在RSA 加密中用到的几6个参数
p1 p2 n φ(n) e d这六个数字之中,公钥用到了两个(n和e),其余四个数字都是不公开的。其中最关键的是d,因为n和d组成了私钥,一旦d泄漏,就等于私钥泄漏。
那么,有无可能在已知n和e的情况下,推导出d?
e*d%φ(n)=1 (只有知道e和φ(n),才能算出d。) φ(n)=(p1-1) * (p2-1) (只有知道p1和p2,才能算出φ(n)。) n=p1*p2 (只有将n因数分解,才能算出p和q。)结论:如果n可以被因数分解,d就可以算出,也就意味着私钥被破解。
可是,大整数的因数分解,是一件非常困难的事情。目前,除了暴力破解,还没有发现别的有效方法。维基百科这样写道:
"对极大整数做因数分解的难度决定了RSA算法的可靠性。换言之,对一极大整数做因数分解愈困难,RSA算法愈可靠。
假如有人找到一种快速因数分解的算法,那么RSA的可靠性就会极度下降。但找到这样的算法的可能性是非常小的。今天只有短的RSA密钥才可能被暴力破解。到2008年为止,世界上还没有任何可靠的攻击RSA算法的方式。
只要密钥长度足够长,用RSA加密的信息实际上是不能被解破的。"
或许你看到这里还不相信,我写个程序挨着试 不就可以破解出来吗?例如 21 你或许会很快的分解成 3×7 但是这个数再大一点 比如 这个质数 2^57,885,161-1 它有超过1千7百万个数位 如果让传统计算机来验证他是不是质数 估计可以跑到天荒地老。
很赞哦!(2)
相关文章
- 因为域名解析需要同步到DNS根服务器,而DNS根服务器会不定时刷,只有DNS根服务器刷新后域名才能正常访问,新增解析一般会在10分钟左右生效,最长不会超过24小时,修改解析时间会稍微延长。
- 只要我们做的是从目前的市场情况选择域名,从简单易记,从个性特征上,我们就可以找到一个好域名进行注册。域名注册进行域名记录和解析以及绑定网站后,客户可以通过URL登录您的网站。
- 域名和网址一样吗?域名和网址有什么区别?
- 6、提示添加成功,点击确认进行最后的确定操作。一般10分钟就解析生效,可以用域名进行访问了。
- 4、club娱乐
- 便宜域名使用如何?小白可以买到便宜域名吗?
- 第六:这个圈子里的域名确实是赚钱的一些大玩家,至于小米农,有多少赚钱?几乎没有,也就是说,轿子里只有一个人,而且大多数人都抬着轿子。
- (4) 使用何种形式的域名后缀对网页搜索影响不大,但域名后缀也需要考虑方便用户记忆
- 记住那句话,域名向来不属于任何人,谁先买就归谁,购买期过后,域名又不再属于任何人。
热门文章
站长推荐
其次,一般域名注册有一个获取密码的按钮,域名注册商点击后会向您发送密码。在得到域名注册商发送的密码后,将其传输到域名服务提供商网站,然后输入密码,此时域名呈现申请状态。提交申请后,原注册人通常会向您发送一封电子邮件,询问您是否同意转让。此时,您只需点击同意转移按钮,域名注册商就可以成功转移。
评估域名涉及的行业规模与发展状况成正比。
如果你的潜在终端必须是这个米(域名),那么潜在终端并不多,也没有硬通货,那么你的域名应该在终端有兴趣购买时出售。否则,你可能得自己留着吃。
在更换域名后,并不是就万事大吉了,我们需要将旧域名做301重定向到新域名上,转移旧域名的权重到新域名上。
四、配置网站,填充内容
国内域名
Status、Creation Date、Expiration Date
2016年1月1日:注册价格将降至每年7欧元。