亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

python密碼學(xué)列置換密碼學(xué)習(xí)

 更新時(shí)間:2022年05月23日 17:20:43   作者:Jarrycow  
這篇文章主要為大家介紹了python密碼學(xué)列置換密碼學(xué)習(xí)的示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪

列置換密碼

參考教材:《現(xiàn)代密碼學(xué)教程》P46 3.1.1

過(guò)程

加密過(guò)程

  • 將明文p以設(shè)定的固定分組寬度m按行寫(xiě)出,即每行有m個(gè)字符;若明文長(zhǎng)度不是m的整數(shù)倍,則不足部分用雙方約定的方式填充,如雙方約定用空格代替空缺處字符,不妨設(shè)最后得字符矩陣[Mp]n×m
  • 按1,2…,m的某一置換σ交換列的位置次序得字符矩陣[Mp]n×m
  • 把矩陣按[Mp]n×m列的順序依次讀出得密文序列c。

解密過(guò)程

  • 將密文c以分組寬度n按列寫(xiě)出得到字符矩陣[Mp]n×m
  • 按加密過(guò)程用的置換σ的逆置換σ-1交換列的位置次序得字符矩陣[Mp]n×m
  • 把矩陣[Mp]n×m按1,2…,n行的順序依次讀出得明文p

說(shuō)明

以例3.2為例

σ=(143)(56)即每個(gè)括號(hào)里部分輪著相對(duì)應(yīng)

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]) #解決最后一個(gè)的問(wèn)題
            antiKey[int(s[i][0])]=int(s[i][-1])
            temp.append(int(s[i][-1]))

當(dāng)然,這兒σ=(143)(56)中沒(méi)有2,因?yàn)?對(duì)應(yīng)他自己即

2→2

所以要再單獨(dú)表示

sameKey=lenKey-set(temp) #找到?jīng)]有變化的密鑰
    for i in sameKey:
        Key[i]=i
        antiKey[i]=i

而加密的時(shí)候,便是把明文先變?yōu)榫仃?,載根據(jù)密鑰進(jìn)行轉(zhuǎn)換

比如本題便將矩陣第一列轉(zhuǎn)換為第四列,第四列轉(zhuǎn)換為第三列,第三列轉(zhuǎn)換為第一列,以此類推

這里可以用生成式完成

M=[M[i][Key[j+1]-1] for i in range(n) for j in range(m)] #矩陣轉(zhuǎn)換

完整代碼

'''列置換密碼
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): # 密鑰形成函數(shù)
        m=self.__m
        Key={}
        antiKey={}
        s=re.split(r'[()]',s) #以()分界
        while '' in s: # 消除''
            s.remove('')
        temp=[]
        lenKey={i+1 for i in range(m)} #密鑰長(zhǎng)度
        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]) #解決最后一個(gè)的問(wèn)題
            antiKey[int(s[i][0])]=int(s[i][-1])
            temp.append(int(s[i][-1]))
        sameKey=lenKey-set(temp) #找到?jīng)]有變化的密鑰
        for i in sameKey:
            Key[i]=i
            antiKey[i]=i
        self.__key.append(Key)
        self.__key.append(antiKey)
    def enCode(self,p): #加密函數(shù)
        self.__apaMsg=p
        m=self.__m
        n=self.__n
        Key=self.__key[0]
        p=p.replace(' ','') #去除空格
        p+=' '*(m-len(p)%m) #末尾補(bǔ)齊
        n=len(p)//m #矩陣列數(shù)
        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)] #矩陣轉(zhuǎn)換
        M=''.join(M) #列表轉(zhuǎn)換為字符串
        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

以上就是python密碼學(xué)列置換密碼學(xué)習(xí)的詳細(xì)內(nèi)容,更多關(guān)于python密碼學(xué)列置換密碼的資料請(qǐng)關(guān)注腳本之家其它相關(guān)文章!

相關(guān)文章

最新評(píng)論