-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathRSA.py
More file actions
120 lines (98 loc) · 2.84 KB
/
Copy pathRSA.py
File metadata and controls
120 lines (98 loc) · 2.84 KB
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
115
116
117
118
119
#수신자의 준비 단계
#e의 범위 : 1 이상 100 이하
#d: c//a 이상 euler 미만의 정수 (항상 이 범위안에 들어감)
import random as r
import math as m
#소수판별 프로그램
def pme_ck(x):
try:
x = int(x)
except:
return -1
if x < 2:
return -1
if x == 2:
return x
for i in range(2, x):
if x%i == 0:
return -1
return x
#매개변수보다 작고, 매개변수와 서로소인 자연수 찾기
def pme_fd(euler):
while True:
e = r.randint(1, 100)
if m.gcd(euler, e) == 1:
return e
#유클리드 알고리즘
def euclid(e, euler):
for i in range(euler//e, euler):
if (e*i)//euler == 1:
return i
#수신자의 준비
def prepare(p, q):
#입력받은 2개의 큰 소수 조건 확인
p = pme_ck(p); q = pme_ck(q)
if p == -1 or q == -1:
print("\nError:조건에 맞지 않는 입력값\n")
return -1
#n의 오일러함수 값(euler)과 서로 소인 수(e) 임의로 구하기
n = p * q; euler = (p-1) * (q-1)
e = pme_fd(euler)
#ed=1(mod 오일러함수(n))인 d 구하기
d = euclid(e, euler)
return(n, e, p, q, d, euler)
#평문 조건판별(정수)
def or_ck(x):
try:
x = int(x)
except:
print("\nError:조건에 맞지 않는 입력값\n")
return -1
else:
return x
#4자리식 블럭단위로 만들기
def sep(original):
original = str(original)
blocks = []
le = len(original)
end = 0
for i in range(le//4):
end = 4*i
blocks.append(original[4*i:4*i+4])
if le%4 != 0:
blocks.append(original[end+4:])
blocks = list(map(int, blocks))
return blocks
#암호화하기
def enc(blocks, e, n):
cryptogram = ""
for i in blocks:
m = str((i**e)%n)
k = len(m)
cryptogram += '0'*(4-k) + m
return cryptogram
#RSA 시작
def RSA():
while True:
p = input("2이상의 소수를 입력해 주세요\n")
q = input("\n2이상의 소수를 입력해 주세요\n")
result = prepare(p, q)
if result == -1:
continue
break
while True:
if result[4] == None:
result = prepare(p,q)
else:
break
n = result[0]; e = result[1]; p = result[2]; q = result[3]; d = result[4]; euler = result[5]
original = input("\n평문을 십진수로 입력해 주세요\n")
while or_ck(original) == -1:
print("\nError:조건에 맞지 않는 입력값\n")
original = input("\n평문을 십진수로 입력해 주세요\n")
original = or_ck(original)
org_bls = sep(original)
cryptogram = enc(org_bls, e, n)
print(f"\nn:{n}, euler:{euler}\ne:{e}\np:{p}\nq:{q}\nd:{d}")
print(f"Cryptogram:{cryptogram}")
RSA()