import random
import base64
'''
Euclid's algorithm to determine the greatest common divisor
'''
def gcd(a,b):
while b != 0:
c = a % b
a = b
b = c
return a
def egcd(a, b):
if a == 0:
return (b, 0, 1)
g, y, x = egcd(b%a,a)
return (g, x - (b//a) * y, y)
def modinv(a, m):
g, x, y = egcd(a, m)
if g != 1:
raise Exception('No modular inverse')
return x%m
def encrypt(plaintext,keypair):
e,n = keypair
# Encrypt the plaintext
cipher = ''.join([chr(pow(ord(char),e,n)) for char in plaintext])
# Encode the ciphertext so it's more readable/sharable
encoded = base64.b64encode(cipher.encode('utf-8'))
return str(encoded,'utf-8')
def decrypt(ciphertext,keypair):
d,n = keypair
# Decode the text to the original format
decoded = base64.b64decode(ciphertext).decode('utf-8')
# Decrypt it
plain = (str(chr(pow(ord(char),d,n))) for char in decoded)
return ''.join(plain)
def generate_keypair(p,q,e=None):
n = p * q
#Phi is the totient of n
phi = (p-1)*(q-1)
#Choose an integer e such that e and phi(n) are coprime
if e is None:
e = random.randrange(1, phi)
#Use Euclid's Algorithm to verify that e and phi(n) are comprime
g = gcd(e, phi)
while g != 1:
e = random.randrange(1, phi)
g = gcd(e, phi)
#Now find the multiplicative inverse of e and phi to generate the private key
d = modinv(e, phi)
return ((e,n),(d,n))
#Only run this part if we're not running as an imported module
if __name__ == '__main__':
p = int(input("Enter prime number p: "))
q = int(input("Enter prime number q: "))
public, private = generate_keypair(p,q)
print("Your public key is the number pair of (e=" + str(public[0]) + ", n=" + str(public[1]) +").\n")
print("Your private key is the number pair of (d=" + str(private[0]) + ", n=" + str(private[1]) +").\n")
s = input("Enter your message: ")
encrypted = encrypt(s,public)
print("Encrypted message: " + encrypted)
decrypted = decrypt(encrypted,private)
print("Decrypt: " + decrypted)
Category Archives: Class
woE7ewVfwoAzbwXCgC5iMyRvBTvCgGBiOy4=
public key: e=5, n=133
Bandit Level 5 Password
koReBOKuIDDepwhWk7jZC0RTdopnAY Kh
Telnet Demo
telnet YOU WILL GET THE SERVER IN CLASS
EHLO totally.legit.server.com
MAIL FROM:<NAME@AURLIWILLGIVEYOU.com>
RCPT TO: <ONEOFOUREMAILS@gmail.com>
DATA
From: Da Boss <NAME@AURLIWILLGIVEYOU.com>
To: The Dude <ONEOFOUREMAILS@gmail.com>
Subject: Totally legit offer for The Dude
Hello Mr The Dude,
I would like to give you lots of free money. Please click this not
at all suspicious link to claim it:
Best,
Da Boss
Totally Legitimate Company, Inc.
.
QUIT


