密码学—RSA公钥算法Python程序

RSA是一种非对称加密算法,基于大素数乘积的欧拉函数性质。它涉及到选取两个素数p和q,计算n=p*q,以及欧拉函数φ(n),然后选择公钥e和私钥d,使得d*e=1modφ(n)。加密和解密过程分别涉及指数运算模n。重要的是,明文和密文必须在模数n的范围内,否则加密会失败。文章还提供了欧拉函数和求解同余方程的实现代码。

RSA流程

  • 选取两个素数p,q保密p,q
  • 计算出n = p×q ,公开n
  • 计算φ(n)=(p-1)(q-1)保密φ(n)
  • 选择一个数e ,e满足:e < φ(n) , gcd(e,φ(n)) = 1公开e
  • 计算出dd×e=1 mod φ(n)保密d
  • 加密m:c = me mod n
  • 解密c :m = cd mod n

细节

在RSA中加密加密并不难,主要是在现实生活中加密的文本的一般对应在转为ASCII的时候对应的数字会特别大,所以假如说我们选择的p×q=n的n不够大,也就是说明文对应的数字大于n这大小的时候就会导致加密失败。

一定要注意模数范围,如果你要加密的数字超过你所在的模数范围就会加密失败,你的要加密的数字必须在你选取的模数范围内,其实这个模数也就是明文空间。(密钥空间: φ(n))。
怎么看空间:就是看你计算式子的模数,好比密钥d,计算的式子是模 φ(n),那密钥空间就是 φ(n)。
明文加解密都是模n,那空间就是你选取好的两个素数相乘后的n大小

知识点

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

竹等寒

谢过道友支持,在下就却之不恭了

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值