gmpy2 是否适合在 python 中实现 RSA?
Is gmpy2 suitable for implementing RSA in python?
更具体地说,gmpy2.next_prime
函数是否足以找到所需的大素数?或者我应该使用其他许多 gmpy2.*_prp
功能之一吗?
例如,下面的代码是否足以找到合适的加密素数?
import os
import gmpy2
def random(bytez):
seed = reduce(lambda a, b: (a << 8)|ord(b), os.urandom(bytez), 0)
return gmpy2.mpz_urandomb(gmpy2.random_state(seed), bytez*8)
def find_prime(bytez=128):
p = random(bytez)|1
while not gmpy2.is_bpsw_prp(p):
p = random(bytez)|1
return p
def good_pair(p, q):
n = p*q
k = gmpy2.ceil(gmpy2.log2(n))
if abs(p - q) > 2**(k/2 - 100):
return n
return 0
def make_rsa_keypair():
p, q = find_prime(), find_prime()
n = good_pair(p, q)
while not n:
p, q = find_prime(), find_prime()
n = good_pair(p, q)
tot = n - (p + q - 1)
e = (1 << 16) + 1
d = gmpy2.invert(e, tot)
return {
'public':{
'n':n,
'e':e,
},
'private':{
'n':n,
'd':d,
}
}
更新:根据建议更新了代码。
免责声明:我维护 gmpy2
。
我建议使用 gmpy2.is_bpsw_prp
而不是 gmpy2.next_prime
。 BPSW 测试会更快,并且没有已知的反例。 is_prime
和 next_prime
检查曾经使用,并且可能仍然使用一组固定的基础,并且有可能通过一系列已知测试进行复合。 IIRC,有人找到了通过前 17 次检查的复合材料。默认情况下,会进行 25 次检查,但这是一个弱点。
我计划在 gmpy2
的下一个版本中包含 APR-CL 可证明素性测试。
在选择 RSA 素数时应遵循特定的准则,以防止意外选择素数,从而创建可以轻松因式分解的 n
。
更具体地说,gmpy2.next_prime
函数是否足以找到所需的大素数?或者我应该使用其他许多 gmpy2.*_prp
功能之一吗?
例如,下面的代码是否足以找到合适的加密素数?
import os
import gmpy2
def random(bytez):
seed = reduce(lambda a, b: (a << 8)|ord(b), os.urandom(bytez), 0)
return gmpy2.mpz_urandomb(gmpy2.random_state(seed), bytez*8)
def find_prime(bytez=128):
p = random(bytez)|1
while not gmpy2.is_bpsw_prp(p):
p = random(bytez)|1
return p
def good_pair(p, q):
n = p*q
k = gmpy2.ceil(gmpy2.log2(n))
if abs(p - q) > 2**(k/2 - 100):
return n
return 0
def make_rsa_keypair():
p, q = find_prime(), find_prime()
n = good_pair(p, q)
while not n:
p, q = find_prime(), find_prime()
n = good_pair(p, q)
tot = n - (p + q - 1)
e = (1 << 16) + 1
d = gmpy2.invert(e, tot)
return {
'public':{
'n':n,
'e':e,
},
'private':{
'n':n,
'd':d,
}
}
更新:根据建议更新了代码。
免责声明:我维护 gmpy2
。
我建议使用 gmpy2.is_bpsw_prp
而不是 gmpy2.next_prime
。 BPSW 测试会更快,并且没有已知的反例。 is_prime
和 next_prime
检查曾经使用,并且可能仍然使用一组固定的基础,并且有可能通过一系列已知测试进行复合。 IIRC,有人找到了通过前 17 次检查的复合材料。默认情况下,会进行 25 次检查,但这是一个弱点。
我计划在 gmpy2
的下一个版本中包含 APR-CL 可证明素性测试。
在选择 RSA 素数时应遵循特定的准则,以防止意外选择素数,从而创建可以轻松因式分解的 n
。