Einfache Substitutions-Chiffre
Die einfache Ersetzungsverschlüsselung ist die am häufigsten verwendete Verschlüsselung und enthält einen Algorithmus zum Ersetzen jedes einfachen Textzeichens durch jedes Verschlüsselungstextzeichen. In diesem Prozess werden Alphabete im Vergleich zum Caesar-Verschlüsselungsalgorithmus durcheinander gebracht.
Beispiel
Schlüssel für eine einfache Substitutions-Chiffre bestehen normalerweise aus 26 Buchstaben. Ein Beispielschlüssel ist -
plain alphabet : abcdefghijklmnopqrstuvwxyz
cipher alphabet: phqgiumeaylnofdxjkrcvstzwb
Eine beispielhafte Verschlüsselung mit dem obigen Schlüssel ist−
plaintext : defend the east wall of the castle
ciphertext: giuifg cei iprc tpnn du cei qprcni
Der folgende Code zeigt ein Programm zum Implementieren einer einfachen Substitutionsverschlüsselung -
import random, sys
LETTERS = 'ABCDEFGHIJKLMNOPQRSTUVWXYZ'
def main():
message = ''
if len(sys.argv) > 1:
with open(sys.argv[1], 'r') as f:
message = f.read()
else:
message = raw_input("Enter your message: ")
mode = raw_input("E for Encrypt, D for Decrypt: ")
key = ''
while checkKey(key) is False:
key = raw_input("Enter 26 ALPHA key (leave blank for random key): ")
if key == '':
key = getRandomKey()
if checkKey(key) is False:
print('There is an error in the key or symbol set.')
translated = translateMessage(message, key, mode)
print('Using key: %s' % (key))
if len(sys.argv) > 1:
fileOut = 'enc.' + sys.argv[1]
with open(fileOut, 'w') as f:
f.write(translated)
print('Success! File written to: %s' % (fileOut))
else: print('Result: ' + translated)
# Store the key into list, sort it, convert back, compare to alphabet.
def checkKey(key):
keyString = ''.join(sorted(list(key)))
return keyString == LETTERS
def translateMessage(message, key, mode):
translated = ''
charsA = LETTERS
charsB = key
# If decrypt mode is detected, swap A and B
if mode == 'D':
charsA, charsB = charsB, charsA
for symbol in message:
if symbol.upper() in charsA:
symIndex = charsA.find(symbol.upper())
if symbol.isupper():
translated += charsB[symIndex].upper()
else:
translated += charsB[symIndex].lower()
else:
translated += symbol
return translated
def getRandomKey():
randomList = list(LETTERS)
random.shuffle(randomList)
return ''.join(randomList)
if __name__ == '__main__':
main()
Ausgabe
Sie können die folgende Ausgabe beobachten, wenn Sie den oben angegebenen Code implementieren: