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(): #明文是否為字母,如果是,則判斷大小寫(xiě),分別進(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(): #密文為否為字母,如果是,則判斷大小寫(xiě),分別進(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("加密請(qǐng)按D,解密請(qǐng)按E:")
user_input=input();
while(user_input!='D' and user_input!='E'):#輸入合法性判斷
print("輸入有誤!請(qǐng)重新輸入:")
user_input=input()
print("請(qǐng)輸入密鑰:")
key=input()
while(False==key.isalpha()):#輸入合法性判斷
print("輸入有誤!密鑰為字母,請(qǐng)重新輸入:")
key=input()
key_list=Get_KeyList(key)
if user_input=='D':
#加密
print("請(qǐng)輸入明文:")
plaintext=input()
ciphertext=Encrypt(plaintext,key_list)
print("密文為:\n%s" % ciphertext)
else:
#解密
print("請(qǐng)輸入密文:")
ciphertext=input()
plaintext=Decrypt(ciphertext,key_list)
print("明文為:\n%s" % plaintext)
以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
python切片中內(nèi)存的注意事項(xiàng)總結(jié)
在本篇文章里小編給大家整理的是一篇關(guān)于python切片中內(nèi)存的注意事項(xiàng)總結(jié)內(nèi)容,有需要的朋友們可以學(xué)習(xí)參考下。2021-08-08
Python+OpenCV+圖片旋轉(zhuǎn)并用原底色填充新四角的例子
今天小編就為大家分享一篇Python+OpenCV+圖片旋轉(zhuǎn)并用原底色填充新四角的例子,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2019-12-12
使用Python實(shí)現(xiàn)自動(dòng)編寫(xiě)word文檔
這篇文章主要為大家詳細(xì)介紹了如何使用Python中的python-docx實(shí)現(xiàn)自動(dòng)編寫(xiě)word文檔,文中的示例代碼講解詳細(xì),感興趣的小伙伴可以參考一下2024-12-12
pyspark.sql.DataFrame與pandas.DataFrame之間的相互轉(zhuǎn)換實(shí)例
今天小編就為大家分享一篇pyspark.sql.DataFrame與pandas.DataFrame之間的相互轉(zhuǎn)換實(shí)例,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2018-08-08
python免殺技術(shù)shellcode的加載與執(zhí)行
本文主要介紹了python免殺技術(shù)shellcode的加載與執(zhí)行,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2023-04-04
PyQT5 實(shí)現(xiàn)快捷鍵復(fù)制表格數(shù)據(jù)的方法示例
這篇文章主要介紹了PyQT5 實(shí)現(xiàn)快捷鍵復(fù)制表格數(shù)據(jù)的方法示例,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2020-06-06

