Python을 사용한 암호화-ROT13 알고리즘
지금까지 역 암호 및 Caesar 암호 알고리즘에 대해 배웠습니다. 이제 ROT13 알고리즘과 그 구현에 대해 논의하겠습니다.
ROT13 알고리즘 설명
ROT13 암호는 축약 된 형식을 나타냅니다. Rotate by 13 places. 시프트가 항상 13 인 Caesar Cipher의 특수한 경우입니다. 모든 문자는 메시지를 암호화하거나 해독하기 위해 13 자리 씩 이동합니다.
예
다음 다이어그램은 ROT13 알고리즘 프로세스를 그림으로 설명합니다.
프로그램 코드
ROT13 알고리즘의 프로그램 구현은 다음과 같습니다.
from string import maketrans
rot13trans = maketrans('ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz',
'NOPQRSTUVWXYZABCDEFGHIJKLMnopqrstuvwxyzabcdefghijklm')
# Function to translate plain text
def rot13(text):
return text.translate(rot13trans)
def main():
txt = "ROT13 Algorithm"
print rot13(txt)
if __name__ == "__main__":
main()
다음 이미지와 같이 ROT13 출력을 볼 수 있습니다.
약점
ROT13 알고리즘은 13 교대를 사용합니다. 따라서 암호 텍스트를 해독하기 위해 역방향으로 문자를 이동하는 것은 매우 쉽습니다.
ROT13 알고리즘 분석
ROT13 암호 알고리즘은 Caesar Cipher의 특수한 경우로 간주됩니다. 그것은 매우 안전한 알고리즘이 아니며 주파수 분석을 통해 또는 가능한 25 개의 키를 시도하여 쉽게 깨질 수있는 반면 ROT13은 13 개 위치를 이동하여 깨뜨릴 수 있습니다. 따라서 실제 사용은 포함되지 않습니다.