RSA算法
2021/4/18 12:25:16
本文主要是介绍RSA算法,对大家解决编程问题具有一定的参考价值,需要的程序猿们随着小编来一起学习吧!
RSA的加密过程
(1)选择两个大的参数,计算出模数 N = p * q
(2)计算欧拉函数 φ = (p-1) * (q-1),然后选择一个e (1 < e < φ) ,并且e和φ互质(互质:公约数只有1的两个整数)
(3)取e的模反数d,计算方法为:e * d ≡ 1 (mod φ)
(模反元素:如果两个正整数e和n互质,那么一定可以找到整数d,使得 e * d - 1 被n整除,或者说e * d被n除的余数是1。这时,d就叫做e的“模反元素”。欧拉定理可以用来证明模反元素必然存在。两个整数a,b,它们除以整数M所得的余数相等:a ≡ b(mod m);
比如说5除3余数为2,11除3余数也为2,于是可写成11 ≡ 5(mod 3)。)
(4)对明文m进行加密:c = pow(m, e, N),可以得到密文c。
(5)对密文c进行解密:m = pow(c, d, N),可以得到明文m。
p 和 q :大整数N的两个因子
N:大整数N,我们称之为模数
e 和 d:互为模反数的两个指数
c 和 m:分别是密文和明文
(N, e):公钥
(N, d):私钥
pow(x, y, z):效果等效pow(x, y)1 % z, 先计算x的y次方,如果存在另一个参数z,需要再对结果进行取模。
安全性:
对于RSA加密算法,公钥(N, e)为公钥,可以任意公开,破解RSA最直接(亦或是暴力)的方法就是分解整数N,然后计算欧拉函数φ(n)=(p-1) * (q-1),再通过d * e ≡ 1 mod φ(N),即可计算出 d,然后就可以使用私钥(N, d)通过m = pow(c,d,N)解密明文
例子
已知p、q、e以及c,可以通过前三个参数求出d
python脚本
import gmpy2 p = gmpy2.mpz(18443) #初始化大整数 q = gmpy2.mpz(49891) e = gmpy2.mpz(19) phi_n = (p-1)*(q-1) d = gmpy2.invert(e,phi_n) #invert(x,m)返回y使得x * y == 1 modulo m,如果不存在y,则返回0 print("p=%s,q=%s,e=%s"%(p,q,e)) print("d is:\n%s"%d)
上面RSA相关内容来自https://blog.csdn.net/huanghelouzi/article/details/82943615
gmpy2用法
import gmpy2 gmpy2.mpz(n)#初始化一个大整数 gmpy2.mpfr(x)# 初始化一个高精度浮点数x d = gmpy2.invert(e,n) # 求逆元,de = 1 mod n C = gmpy2.powmod(M,e,n)# 幂取模,结果是 C = (M^e) mod n gmpy2.is_prime(n) #素性检测 gmpy2.gcd(a,b) #欧几里得算法,最大公约数 gmpy2.gcdext(a,b) #扩展欧几里得算法 gmpy2.iroot(x,n) #x开n次根
上面gmpy2用法相关内容来自https://blog.csdn.net/qq_42250840/article/details/105153227
这篇关于RSA算法的文章就介绍到这儿,希望我们推荐的文章对大家有所帮助,也希望大家多多支持为之网!
- 2025-01-12百万架构师第十五课:源码分析:Spring 源码分析:SpringMVC核心原理及源码分析|JavaGuide
- 2025-01-11有哪些好用的家政团队管理工具?
- 2025-01-11营销人必看的GTM五个指标
- 2025-01-11办公软件在直播电商前期筹划中的应用与推荐
- 2025-01-11提升组织效率:上级管理者如何优化跨部门任务分配
- 2025-01-11酒店精细化运营背后的协同工具支持
- 2025-01-11跨境电商选品全攻略:工具使用、市场数据与选品策略
- 2025-01-11数据驱动酒店管理:在线工具的核心价值解析
- 2025-01-11cursor试用出现:Too many free trial accounts used on this machine 的解决方法
- 2025-01-11百万架构师第十四课:源码分析:Spring 源码分析:深入分析IOC那些鲜为人知的细节|JavaGuide