rsa脚本 Crypto.Util.number.getPrime()函数详解

Crypto.Util是PyCryptodome库的一个组件,专注于提供加密和安全相关的实用工具。这个包包含了用于随机数生成、ASN.1编码、PKCS#1填充值计算等功能。在3.18.0版本中,它可能包含了一些更新和改进,帮助开发者更安全地实现密码学算法。
摘要由CSDN通过智能技术生成
  • 3
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
这段代码看起来是使用RSA加密算法生成密钥对,并进行信息加密的过程。以下是代码的完善建议: 1. 导入所需的模块和函数: ```python from Crypto.Util.number import getPrime, inverse, getRandomRange from Crypto.PublicKey import RSA import base64 ``` 2. 修改 `long` 函数为 `int`: ```python key = RSA.construct((int(n), int(e), int(d), int(p), int(p))) ``` 3. 将 `xrange` 替换为 `range`(Python 3.x 不再支持 `xrange`): ```python for _ in range(s): ``` 4. 修改打印语句中的 `enc.encode('base64')` 为 `base64.b64encode(enc)`: ```python print(base64.b64encode(enc)) ``` 完成这些修改后,代码应该如下所示: ```python from Crypto.Util.number import getPrime, inverse, getRandomRange from Crypto.PublicKey import RSA import base64 from secret import s, FLAG def gen_prime(s): while True: r = getPrime(s) R = [r] t = int(5 * s / 2) + 1 for i in range(0, t): R.append(r + getRandomRange(0, 4 * s ** 2)) p = reduce(lambda a, b: a * b, R, 2) + 1 if isPrime(p): if len(bin(p)[2:]) == 1024: return p while True: p = gen_prime(s) q = gen_prime(s) n = p * q e = 65537 d = inverse(e, (p-1)*(q-1)) if len(bin(n)[2:]) == 2048: break msg = FLAG key = RSA.construct((int(n), int(e), int(d), int(p), int(p))) for _ in range(s): enc = key.encrypt(msg, 0)[0] msg = enc print(key.publickey().exportKey()) print('-' * 76) print(base64.b64encode(enc)) print('-' * 76) ``` 请注意,这只是对代码进行了一些基本的修正和完善,还可能存在其他需要优化的地方。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值