-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathmain.py
executable file
·114 lines (74 loc) · 2.22 KB
/
main.py
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
#! /usr/bin/env python
import random
import libnum
from Crypto.Util.number import getPrime
from Crypto.Random import get_random_bytes
def square_and_multiply(x, c, n):
c = bin(c)
z = x
for i in range(3, len(c)):
z = z ** 2 % n
if c[i:i+1] == '1':
z = z * x % n
return z
def highest_power_of_two(mphi):
s = 0
d = mphi
while (d & 1 == 0):
s += 1
d = (d >> 1)
pwt = 2 ** s
r = mphi // pwt
return s, r
def factoring(n, a, b):
mphi = a*b - 1
s, r = highest_power_of_two(mphi)
w = random.randint(1, n-1)
x = libnum.gcd(w, n)
if 1 < x < n:
print(f"SUCCESS, factor = {x}.")
return "SUCCESS", x
v = square_and_multiply(w, r, n)
if (v % n == 1):
print("FAILURE. Please rerun.")
return "FAILURE", -11
v_0 = None
while (v % n != 1):
v_0 = v
v = (v**2) % n
if (v_0 % n == -1):
print("FAILURE. Please rerun.")
return "FAILURE", -11
else:
x = libnum.gcd(v_0+1, n)
print(f"SUCCESS, factor = {x}.")
return "SUCCESS", x
def get_rsa_params(primebits):
p = getPrime(primebits, randfunc=get_random_bytes)
q = getPrime(primebits, randfunc=get_random_bytes)
while(q == p):
q = getPrime(primebits, randfunc=get_random_bytes)
n = p*q
phi = (p-1)*(q-1)
b = random.randint(1, phi)
while(libnum.gcd(b, phi) != 1):
b = random.randint(1, phi)
a = libnum.invmod(b, phi)
print(f"We generate two prime p = {p}, q = {q}.")
print(f"We then calculate Phi(n)={phi}, b random invertible in Z_Phi(n), a inverse of b.")
print(f"\nNow imagine we don't know p, q and we somehow obtain a, b.")
return n, a, b
if __name__ == "__main__":
primebits = 16
n, a, b = get_rsa_params(primebits)
#n = 89855713
#a = 82330933
#b = 34986517
print(f"\nWe know a = {a}, b = {b}.")
print(f"We want to use them to factor n = {n}.")
status, factor = factoring(n, a, b)
if status == "SUCCESS":
other_factor = n // factor
print(f"\nIt seems that {factor} * {other_factor} = {n}")
if factor == n:
print("TRIVIAL FACTOR. Found factor equals n.")