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)

你可能感兴趣的:(算法,RSA算法,数据加密,加密技术)