RSA算法

RSA算法

RSA是一种公钥加密算法

过程:

1:
选定俩素数p和q
2:
令n=pq, 和令z= n的欧拉函数φ(n)=(p-1)(q-1)

任意给定正整数n,计算在小于等于n的正整数之中,有多少个与n构成互质关系。计算这个值的方法叫做欧拉函数

3:
选择一个与z互质的数d

如果两个正整数,除了1之外没有其他公因子,我们称这两个数是互质关系

4:
选择一个数e,使ed=1(mod z);

如果两个正整数a和n互质,那么一定可以找到整数b,使得 ab-1 被n整除。
ab=1(mod n)

5:
如果明文为 P,密文为 C;
则公钥为(e,n),且C=P^e (mod n);
私钥为(d,n),且P=C^d (mod n)

eg:

假设p = 3、q = 11(p,q都是素数即可。),则N = pq = 33;
r = (p-1)(q-1) = (3-1)(11-1) = 20;
根据模反元素的计算公式,我们可以得出,e·d ≡ 1 (mod 20),即e·d = 20n+1 (n为正整数);我们假设n=1,则e·d = 21。e、d为正整数,并且e与r互质,则e = 3,d = 7。(两个数交换一下也可以。)
到这里,公钥和密钥已经确定。公钥为(N, e) = (33, 3),密钥为(N, d) = (33, 7)

  • 0
    点赞
  • 7
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值