Vignere Cipher 구현
이 장에서는 Vignere 암호를 구현하는 방법을 이해하겠습니다. 텍스트 고려This is basic implementation of Vignere Cipher 인코딩되고 사용되는 키는 PIZZA.
암호
다음 코드를 사용하여 Python에서 Vignere 암호를 구현할 수 있습니다.
import pyperclip
LETTERS = 'ABCDEFGHIJKLMNOPQRSTUVWXYZ'
def main():
myMessage = "This is basic implementation of Vignere Cipher"
myKey = 'PIZZA'
myMode = 'encrypt'
if myMode == 'encrypt':
translated = encryptMessage(myKey, myMessage)
elif myMode == 'decrypt':
translated = decryptMessage(myKey, myMessage)
print('%sed message:' % (myMode.title()))
print(translated)
print()
def encryptMessage(key, message):
return translateMessage(key, message, 'encrypt')
def decryptMessage(key, message):
return translateMessage(key, message, 'decrypt')
def translateMessage(key, message, mode):
translated = [] # stores the encrypted/decrypted message string
keyIndex = 0
key = key.upper()
for symbol in message:
num = LETTERS.find(symbol.upper())
if num != -1:
if mode == 'encrypt':
num += LETTERS.find(key[keyIndex])
elif mode == 'decrypt':
num -= LETTERS.find(key[keyIndex])
num %= len(LETTERS)
if symbol.isupper():
translated.append(LETTERS[num])
elif symbol.islower():
translated.append(LETTERS[num].lower())
keyIndex += 1
if keyIndex == len(key):
keyIndex = 0
else:
translated.append(symbol)
return ''.join(translated)
if __name__ == '__main__':
main()
산출
위에 주어진 코드를 구현할 때 다음 출력을 관찰 할 수 있습니다.
Vignere 암호를 해킹하는 가능한 조합은 거의 불가능합니다. 따라서 보안 암호화 모드로 간주됩니다.