溫馨提示×

溫馨提示×

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

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

python實現(xiàn)維吉尼亞加密法

發(fā)布時間:2020-09-11 08:19:55 來源:腳本之家 閱讀:241 作者:Cosmop01itan 欄目:開發(fā)技術(shù)

本文實例為大家分享了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()


python實現(xiàn)維吉尼亞加密法

小編再為大家分享一段Vigenere密碼Python實現(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(): #明文是否為字母,如果是,則判斷大小寫,分別進行加密
   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(): #密文為否為字母,如果是,則判斷大小寫,分別進行解密
   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í)有所幫助,也希望大家多多支持億速云。

向AI問一下細(xì)節(jié)

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

AI