#########################Playfair密码#########################
#约定1:若明文字母数量为奇数,在明文末尾添加一个'Z'
#约定2:'I'作为'J'来处理
#字母表
letter_list='ABCDEFGHJKLMNOPQRSTUVWXYZ'
#密码表
T_letter=['','','','','']
#根据密钥建立密码表
def Create_Matrix(key):
key=Remove_Duplicates(key) #移除密钥中的重复字母
key=key.replace(' ','') #去除密钥中的空格
for ch in letter_list: #根据密钥获取新组合的字母表
if ch not in key:
key+=ch
j=0
for i in range(len(key)): #将新的字母表里的字母逐个填入密码表中,组成5*5的矩阵
T_letter[j]+=key[i] #j用来定位字母表的行
if 0==(i+1)%5:
j+=1
#移除字符串中重复的字母
def Remove_Duplicates(key):
key=key.upper() #转成大写字母组成的字符串
_key=''
for ch in key:
if ch=='I':
ch='J'
if ch in _key:
continue
else:
_key+=ch
return _key
#获取字符在密码表中的位置
def Get
Playfair密码 Python实现
最新推荐文章于 2024-05-19 21:36:49 发布
本文介绍了Playfair密码的加密和解密原理,并提供了Python实现代码。通过创建密码表,移除密钥中重复字母,以及利用Get_MatrixIndex函数获取字符位置,实现了对明文和密文的有效处理。
摘要由CSDN通过智能技术生成