溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

python如何實現(xiàn)列置換密碼

發(fā)布時間:2022-05-24 09:20:18 來源:億速云 閱讀:454 作者:iii 欄目:開發(fā)技術

這篇文章主要介紹了python如何實現(xiàn)列置換密碼的相關知識,內(nèi)容詳細易懂,操作簡單快捷,具有一定借鑒價值,相信大家閱讀完這篇python如何實現(xiàn)列置換密碼文章都會有所收獲,下面我們一起來看看吧。

    過程

    加密過程

    • 將明文p以設定的固定分組寬度m按行寫出,即每行有m個字符;若明文長度不是m的整數(shù)倍,則不足部分用雙方約定的方式填充,如雙方約定用空格代替空缺處字符,不妨設最后得字符矩陣[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為例

    python如何實現(xiàn)列置換密碼

    σ=(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) #找到?jīng)]有變化的密鑰
        for i in sameKey:
            Key[i]=i
            antiKey[i]=i

    而加密的時候,便是把明文先變?yōu)榫仃?,載根據(jù)密鑰進行轉(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)} #密鑰長度
            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) #找到?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) #末尾補齊
            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如何實現(xiàn)列置換密碼”這篇文章的內(nèi)容就介紹到這里,感謝各位的閱讀!相信大家對“python如何實現(xiàn)列置換密碼”知識都有一定的了解,大家如果還想學習更多知識,歡迎關注億速云行業(yè)資訊頻道。

    向AI問一下細節(jié)

    免責聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進行舉報,并提供相關證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權(quán)內(nèi)容。

    AI