简单的密码技术——凯撒密码(Caesar cipher)
介绍
对于加密技术最早的就是凯撒加密,凯撒密码涉及替换情报中的每个字母,是一种最简单且最广为人知的加密技术。它是一种替换加密的技术,明文中的所有字母都在字母表上向后(或向前)按照一个固定数目进行偏移后被替换成密文。例如,当偏移量是3的时候,所有的字母A将被替换成D,B变成E,以此类推。这个加密方法是以罗马共和时期恺撒的名字命名的,当年恺撒曾用此方法与其将军们进行联系。
相应代码
主代码
python语言实现
class CaesarCipher:
'''Class for doing encryption(加密) and decryption(解密) using a Caesar cipher'''
def __init__(self,shift):
'''Construcr Caesar cipher given integar shift for ratation'''
encoder = [None] * 26
decoder = [None] * 26
for k in range(26):
encoder[k] = chr((k+shift)%26 + ord('A'))
decoder[k] = chr((k-shift)%26 + ord('A'))
self._forward = ''.join(encoder)
self._backwad = ''.join(decoder)
def enctypt(self,message):
'''Return string representing encrypted message'''
return self._transform(message,self._forward)
def decrypt(self,secret):
'''return decrypted message given encrypted secret'''
return self._transform(secret,self._backwad)
def _transform(self,original,code):
'''Utility to perform transformation based on given code string'''
msg = list(original.upper())
for k in range(len(msg)):
if msg[k].isupper():
j = ord(msg[k])-ord('A')
msg[k] = code[j]
return ''.join(msg)
这里创建了一个类,其中enctypt方法就是加密过程,decrypt方法就是解密过程
测试代码
def main():
cipher = CaesarCipher(3)
message = 'i love you'
code = cipher.enctypt(message)
print('the secret message is: ',code)
answer = cipher.decrypt(code)
print('the real meassage is: ',answer)
if __name__ == '__main__':
main()
显示结果:
解释:CaesarCipher类初始化生成self._forward
和self._backward
两个字符串,分别是
DEFGHIJKLMNOPQRSTUVWXYZABC
XYZABCDEFGHIJKLMNOPQRSTUVW
这里主要通过 _transform(self,original,code)方法
这个方法是私有的,通过索引值,在code字符串里面取值,并返回。