python實(shí)現(xiàn)維吉尼亞加密法
本文實(shí)例為大家分享了python實(shí)現(xiàn)維吉尼亞加密法的具體代碼,供大家參考,具體內(nèi)容如下
Vigenere加密/解密時(shí),把英文字母映射為0-25的數(shù)字再進(jìn)行運(yùn)算,并按n個(gè)字母為一組進(jìn)行變換.算法定義如下:
設(shè)密鑰 k =(k1,k2,k3…,kn),明文 m = (m1,m2,….mn),則加密算法為:
Ek(m) = (c1,c2,…cn)
其中:c1 = (mi+ki)(mod 26),i=1,2,3…..n
解密算法為:
mi = (ci - ki)(mod 26), i = 1,2,…..n。
import string,os def vigenereEncrypt(msg,key): size = len(key) result = [] cnt = 0 for i in msg: if i.upper() in string.uppercase: #offset相當(dāng)于是 ki offset = string.uppercase.find(key[cnt%size]) t = string.uppercase[(string.uppercase.find(i.upper())+offset)%26] #這里相當(dāng)于是c1 = (mi+ki)(mod 26) ,t = c1 if i.isupper(): result.append(t) else: result.append(t.lower()) cnt+=1 else: result.append(i) return "".join(result) def main(): msg = "Common sense is not so common" cipher = vigenereEncrypt(msg,"PIZZA")#key = "PIZZA: print cipher if __name__=="__main__": main()
小編再為大家分享一段Vigenere密碼Python實(shí)現(xiàn)代碼:
##########Vigenere密碼############ letter_list='ABCDEFGHIJKLMNOPQRSTUVWXYZ' #字母表 #根據(jù)輸入的key生成key列表 def Get_KeyList(key): key_list=[] for ch in key: key_list.append(ord(ch.upper())-65) return key_list #加密函數(shù) def Encrypt(plaintext,key_list): ciphertext="" i=0 for ch in plaintext: #遍歷明文 if 0==i%len(key_list): i=0 if ch.isalpha(): #明文是否為字母,如果是,則判斷大小寫,分別進(jìn)行加密 if ch.isupper(): ciphertext+=letter_list[(ord(ch)-65+key_list[i]) % 26] i+=1 else: ciphertext+=letter_list[(ord(ch)-97+key_list[i]) % 26].lower() i+=1 else: #如果密文不為字母,直接添加到密文字符串里 ciphertext+=ch return ciphertext #解密函數(shù) def Decrypt(ciphertext,key): plaintext="" i=0 for ch in ciphertext: #遍歷密文 if 0==i%len(key_list): i=0 if ch.isalpha(): #密文為否為字母,如果是,則判斷大小寫,分別進(jìn)行解密 if ch.isupper(): plaintext+=letter_list[(ord(ch)-65-key_list[i]) % 26] i+=1 else: plaintext+=letter_list[(ord(ch)-97-key_list[i]) % 26].lower() i+=1 else: #如果密文不為字母,直接添加到明文字符串里 plaintext+=ch return plaintext if __name__=='__main__': print("加密請按D,解密請按E:") user_input=input(); while(user_input!='D' and user_input!='E'):#輸入合法性判斷 print("輸入有誤!請重新輸入:") user_input=input() print("請輸入密鑰:") key=input() while(False==key.isalpha()):#輸入合法性判斷 print("輸入有誤!密鑰為字母,請重新輸入:") key=input() key_list=Get_KeyList(key) if user_input=='D': #加密 print("請輸入明文:") plaintext=input() ciphertext=Encrypt(plaintext,key_list) print("密文為:\n%s" % ciphertext) else: #解密 print("請輸入密文:") ciphertext=input() plaintext=Decrypt(ciphertext,key_list) print("明文為:\n%s" % plaintext)
以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
python之Flask實(shí)現(xiàn)簡單登錄功能的示例代碼
這篇文章主要介紹了python之Flask實(shí)現(xiàn)簡單登錄功能的示例代碼,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2018-12-12Python中10個(gè)常用的內(nèi)置函數(shù)詳解
這篇文章主要為大家介紹了Python常用的內(nèi)置函數(shù),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下,希望能夠給你帶來幫助2021-12-12python3.6 tkinter實(shí)現(xiàn)屏保小程序
這篇文章主要為大家詳細(xì)介紹了python3.6 tkinter實(shí)現(xiàn)屏保小程序,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2019-07-07pyqt5 tablewidget 利用線程動(dòng)態(tài)刷新數(shù)據(jù)的方法
今天小編就為大家分享一篇pyqt5 tablewidget 利用線程動(dòng)態(tài)刷新數(shù)據(jù)的方法,具有很好的參考價(jià)值,希望對大家有所幫助。一起跟隨小編過來看看吧2019-06-06python實(shí)現(xiàn)字典合并的五種方法(附示例代碼)
在Python中,有多種方法可以通過使用各種函數(shù)和構(gòu)造函數(shù)來合并字典,在本文中,我們將討論一些合并字典的方法,并通過代碼示例講解的非常詳細(xì),具有一定的參考價(jià)值,需要的朋友可以參考下2024-04-04Python實(shí)戰(zhàn)小程序利用matplotlib模塊畫圖代碼分享
這篇文章主要介紹了Python實(shí)戰(zhàn)小程序利用matplotlib模塊畫圖代碼分享,具有一定借鑒價(jià)值,需要的朋友可以了解下。2017-12-12