python列置换密码的过程及完整代码是什么
Admin 2022-08-25 群英技术资讯 594 次浏览
参考教材:《现代密码学教程》P46 3.1.1
以例3.2为例
σ=(143)(56)即每个括号里部分轮着相对应
1→4→3→1
5→6→5
这里我是用字典表示
for i in range(len(s)): for j in range(len(s[i])-1): Key[int(s[i][j])]=int(s[i][j+1]) #密钥字典 antiKey[int(s[i][j+1])]=int(s[i][j]) #反密钥字典 Key[int(s[i][-1])]=int(s[i][0]) #解决最后一个的问题 antiKey[int(s[i][0])]=int(s[i][-1]) temp.append(int(s[i][-1]))
当然,这儿σ=(143)(56)中没有2,因为2对应他自己即
2→2
所以要再单独表示
sameKey=lenKey-set(temp) #找到没有变化的密钥 for i in sameKey: Key[i]=i antiKey[i]=i
而加密的时候,便是把明文先变为矩阵,载根据密钥进行转换
比如本题便将矩阵第一列转换为第四列,第四列转换为第三列,第三列转换为第一列,以此类推
这里可以用生成式完成
M=[M[i][Key[j+1]-1] for i in range(n) for j in range(m)] #矩阵转换
'''列置换密码 Auher:Jarrycow time:2020-04-17 ''' import re class colCode: __m=0 __n=0 __key=[] # 密钥 __apaMsg="" # 明文 __secMsg="" #密文 def __init__(self,m): # 初始化,定义矩阵宽 self.__m=m __n=0 __key=[] __apaMsg="" __secMsg="" def getKey(self,s): # 密钥形成函数 m=self.__m Key={} antiKey={} s=re.split(r'[()]',s) #以()分界 while '' in s: # 消除'' s.remove('') temp=[] lenKey={i+1 for i in range(m)} #密钥长度 for i in range(len(s)): for j in range(len(s[i])-1): Key[int(s[i][j])]=int(s[i][j+1]) #密钥字典 antiKey[int(s[i][j+1])]=int(s[i][j]) #反密钥字典 temp.append(int(s[i][j])) #钥匙收录 Key[int(s[i][-1])]=int(s[i][0]) #解决最后一个的问题 antiKey[int(s[i][0])]=int(s[i][-1]) temp.append(int(s[i][-1])) sameKey=lenKey-set(temp) #找到没有变化的密钥 for i in sameKey: Key[i]=i antiKey[i]=i self.__key.append(Key) self.__key.append(antiKey) def enCode(self,p): #加密函数 self.__apaMsg=p m=self.__m n=self.__n Key=self.__key[0] p=p.replace(' ','') #去除空格 p+=' '*(m-len(p)%m) #末尾补齐 n=len(p)//m #矩阵列数 self.__n=n M=[p[i*m:(i+1)*m] for i in range(n)] #矩阵生成 M=[M[i][Key[j+1]-1] for i in range(n) for j in range(m)] #矩阵转换 M=''.join(M) #列表转换为字符串 self.__secMsg=M return M def deCode(self,q): self.__apaMsg=p m=self.__m n=self.__n Key=self.__key[1] M=[q[i*m:(i+1)*m] for i in range(n)] M=[M[i][Key[j+1]-1] for i in range(n) for j in range(m)] M=''.join(M) self.__secMsg=M return M def Print(self): print(self.__m,self.__n,self.__key,self.__apaMsg,self.__secMsg) if __name__=='__main__': m=6 p="Beijing 2008 Olympic Games" s='(143)(56)' a=colCode(m) a.getKey(s) q=a.enCode(p) e=a.deCode(q) a.Print() def main(): pass
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:mmqy2019@163.com进行举报,并提供相关证据,查实之后,将立刻删除涉嫌侵权内容。
猜你喜欢
数字数据类型用于存储数值。它们是不可变的数据类型,这意味着需要改变一个新分配对象的数字数据类型的结果值。
这篇文章主要介绍了python垃圾回收机制原理,python采用的是引用计数机制为主,标记-清除和分代收集两种机制为辅的策略,有需要的的朋友可以借鉴参考想
大家好,本篇文章主要讲的是用Python画圣诞树代码示例,感兴趣的同学赶快来看一看吧,对你有帮助的话记得收藏一下,方便下次浏览
我们从小学开始背诵九九乘法表,是因为九九乘法表是一切计算的前提,没有九九乘法表,就难以进行计算。而且九九乘法表易于记忆和运算,让我们的数学计算起来更简便,更快捷,更有趣味。九九乘法表这么重要,我们就用for语句来打印乘法表吧。
内容介绍1.关于箱线图及plt.boxplot()方法2.绘制一幅简单的箱线图3.绘制一幅更精致的图像4.异常值的标准5.异常值的输出1.关于箱线图及plt.boxplot()方法
成为群英会员,开启智能安全云计算之旅
立即注册Copyright © QY Network Company Ltd. All Rights Reserved. 2003-2020 群英 版权所有
增值电信经营许可证 : B1.B2-20140078 粤ICP备09006778号 域名注册商资质 粤 D3.1-20240008