Create Onepad_Cipher.py

In one pad algorithm length of key and length of message are equal which results in endless possibilities of false messages on bruteforce.
This commit is contained in:
Syed Haseeb Shah 2018-04-13 20:49:38 +05:00 committed by GitHub
parent 0a1b6ad4cf
commit 0fdd2d369e
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23

28
ciphers/Onepad_Cipher.py Normal file
View File

@ -0,0 +1,28 @@
class Onepad:
def encrypt(self, text):
'''Function to encrypt text using psedo-random numbers'''
plain = []
key = []
cipher = []
for i in text:
plain.append(ord(i))
for i in plain:
k = random.randint(1, 300)
c = (i+k)*k
cipher.append(c)
key.append(k)
return cipher, key
def decrypt(self, cipher, key):
'''Function to decrypt text using psedo-random numbers.'''
plain = []
for i in range(len(key)):
p = (cipher[i]-(key[i])**2)/key[i]
plain.append(chr(p))
plain = ''.join([i for i in plain])
return plain
if __name__ == '__main__':
c,k = Onepad().encrypt('Hello')
print c, k
print Onepad().decrypt(c, k)