添加链接
link管理
链接快照平台
  • 输入网页链接,自动生成快照
  • 标签化管理网页链接
相关文章推荐
长情的楼房  ·  BMR Suspension SP036 ...·  2 周前    · 
深情的脆皮肠  ·  Developer Community·  2 月前    · 
近视的眼镜  ·  GitHub - ysc/word: ...·  4 月前    · 

python密码学列置换密码学习

作者:Jarrycow

这篇文章主要为大家介绍了python密码学列置换密码学习的示例详解,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪

列置换密码

参考教材:《现代密码学教程》P46 3.1.1

  • 将明文p以设定的固定分组宽度m按行写出,即每行有m个字符;若明文长度不是m的整数倍,则不足部分用双方约定的方式填充,如双方约定用空格代替空缺处字符,不妨设最后得字符矩阵[Mp]n×m
  • 按1,2…,m的某一置换σ交换列的位置次序得字符矩阵[Mp]n×m
  • 把矩阵按[Mp]n×m列的顺序依次读出得密文序列c。
  • 将密文c以分组宽度n按列写出得到字符矩阵[Mp]n×m
  • 按加密过程用的置换σ的逆置换σ-1交换列的位置次序得字符矩阵[Mp]n×m
  • 把矩阵[Mp]n×m按1,2…,n行的顺序依次读出得明文p

以例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对应他自己即

所以要再单独表示

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__':
    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():

以上就是python密码学列置换密码学习的详细内容,更多关于python密码学列置换密码的资料请关注脚本之家其它相关文章!

您可能感兴趣的文章:
  • python中的断言(assert语句)
    python中的断言(assert语句)
    2022-05-05
  • python标准库ElementTree处理xml
    python标准库ElementTree处理xml
    2022-05-05
  • baselines示例程序train_cartpole.py的ImportError
    baselines示例程序train_cartpole.py的ImportError
    2022-05-05
  • python人工智能遗传算法示例解析
    python人工智能遗传算法示例解析
    2022-05-05
  • Python密码学仿射密码及攻击单字母密码教程
    Python密码学仿射密码及攻击单字母密码教程
    2022-05-05
  • Python协程实践分享
    Python协程实践分享
    2022-05-05
  • Python密码学XOR算法编码流程及乘法密码教程
    Python密码学XOR算法编码流程及乘法密码教程
    2022-05-05
  • Python日志模块logging的使用方法总结
    Python日志模块logging的使用方法总结
    2022-05-05
  • 美国设下计谋,用娘炮文化重塑日本,已影响至中国
    美国设下计谋,用娘炮文化重塑日本,已影响至中国
    2021-11-19
  • 时空伴随者是什么意思?时空伴随者介绍
    时空伴随者是什么意思?时空伴随者介绍
    2021-11-09
  • 工信部称网盘企业免费用户最低速率应满足基本下载需求,天翼云盘回应:坚决支持,始终
    工信部称网盘企业免费用户最低速率应满足基本下载需求,天翼云盘回应:坚决支持,始终
    2021-11-05
  • 2022年放假安排出炉:五一连休5天 2022年所有节日一览表
    2022年放假安排出炉:五一连休5天 2022年所有节日一览表
    2021-10-26
  • 电脑版 - 返回首页

    2006-2024 脚本之家 JB51.Net , All Rights Reserved.
    苏ICP备14036222号