本文實例為大家分享了python實現(xiàn)維吉尼亞加密法的具體代碼,供大家參考,具體內(nèi)容如下

Vigenere加密/解密時,把英文字母映射為0-25的數(shù)字再進行運算,并按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()
分享標(biāo)題:python實現(xiàn)維吉尼亞加密法-創(chuàng)新互聯(lián)
分享地址:http://chinadenli.net/article2/ceeeoc.html
成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供App設(shè)計、靜態(tài)網(wǎng)站、營銷型網(wǎng)站建設(shè)、手機網(wǎng)站建設(shè)、企業(yè)建站、網(wǎng)頁設(shè)計公司
聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時需注明來源: 創(chuàng)新互聯(lián)
猜你還喜歡下面的內(nèi)容