python密碼學(xué)Vignere密碼教程
Vignere密碼
Vignere Cipher包含用于加密和解密的Caesar Cipher算法. Vignere Cipher與Caesar Cipher算法類似,只有一個(gè)主要區(qū)別:Caesar Cipher包含一個(gè)字符移位的算法,而Vignere Cipher包含多個(gè)字母移位的鍵.
數(shù)學(xué)方程

Vignere密碼使用多組替換,因此它也被稱為 polyalphabetic cipher . Vignere Cipher將使用字母鍵而不是數(shù)字鍵表示:字母A將用于鍵0,字母B將用于鍵1,依此類推.加密過(guò)程之前和之后的字母數(shù)字顯示在下面 :

基于Vignere密鑰長(zhǎng)度的可能密鑰數(shù)量的可能組合如下,給出了Vignere Cipher算法的安全性的結(jié)果 :

Vignere Tableau
用于Vignere密碼的畫面如下所示 :

實(shí)現(xiàn)
讓我們了解如何實(shí)現(xiàn)Vignere密碼.考慮文本這是Vignere密碼的基本實(shí)現(xiàn)將被編碼,使用的密鑰是 PIZZA.
代碼
您可以使用以下代碼在Python中實(shí)現(xiàn)Vignere密碼 :
import?pyperclip
LETTERS?=?'ABCDEFGHIJKLMNOPQRSTUVWXYZ'
def?main():
???myMessage?=?"This?is?basic?implementation?of?Vignere?Cipher"
???myKey?=?'PIZZA'
???myMode?=?'encrypt'??
???if?myMode?==?'encrypt':
??????translated?=?encryptMessage(myKey,?myMessage)
???elif?myMode?==?'decrypt':
??????translated?=?decryptMessage(myKey,?myMessage)??
???print('%sed?message:'?%?(myMode.title()))
???print(translated)
???print()
def?encryptMessage(key,?message):
???return?translateMessage(key,?message,?'encrypt')
def?decryptMessage(key,?message):
???return?translateMessage(key,?message,?'decrypt')
def?translateMessage(key,?message,?mode):
???translated?=?[]?#?stores?the?encrypted/decrypted?message?string
???keyIndex?=?0
???key?=?key.upper()
???for?symbol?in?message:
??????num?=?LETTERS.find(symbol.upper())
??????if?num?!=?-1:
?????????if?mode?==?'encrypt':
????????????num?+=?LETTERS.find(key[keyIndex])
elif?mode?==?'decrypt':
???????????????num?-=?LETTERS.find(key[keyIndex])
????????????num?%=?len(LETTERS)????????????
????????????if?symbol.isupper():
???????????????translated.append(LETTERS[num])
????????????elif?symbol.islower():
???????????????translated.append(LETTERS[num].lower())
????????????keyIndex?+=?1
????????????
????????????if?keyIndex?==?len(key):
???????????????keyIndex?=?0
?????????else:
????????????translated.append(symbol)
??????return?''.join(translated)
if?__name__?==?'__main__':
???main()輸出
當(dāng)您實(shí)現(xiàn)上面給出的代碼時(shí),您可以觀察到以下輸出;

攻擊Vignere密碼的可能組合幾乎是不可能的.因此,它被視為安全加密模式.
以上就是python密碼學(xué)Vignere密碼教程的詳細(xì)內(nèi)容,更多關(guān)于python密碼學(xué)Vignere的資料請(qǐng)關(guān)注腳本之家其它相關(guān)文章!
相關(guān)文章
Python scikit-learn數(shù)據(jù)預(yù)處理常見方法和步驟
數(shù)據(jù)預(yù)處理是數(shù)據(jù)準(zhǔn)備階段的一個(gè)重要環(huán)節(jié),主要目的是將原始數(shù)據(jù)轉(zhuǎn)換成適合機(jī)器學(xué)習(xí)模型使用的格式,數(shù)據(jù)預(yù)處理可以顯著提高機(jī)器學(xué)習(xí)模型的性能和準(zhǔn)確度,本文給大家介紹了Python數(shù)據(jù)預(yù)處理常見方法和步驟,需要的朋友可以參考下2024-05-05
Python小整數(shù)對(duì)象池和字符串intern實(shí)例解析
這篇文章主要介紹了Python小整數(shù)對(duì)象池和字符串intern實(shí)例解析,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2020-03-03
Python的Flask框架中的Jinja2模板引擎學(xué)習(xí)教程
這篇文章主要介紹了Python的Flask框架中的Jinja2模板引擎學(xué)習(xí)教程,Jinja2模板引擎的用法也是Flask的Web開發(fā)中的重要知識(shí),需要的朋友可以參考下2016-06-06
python使用openpyxl庫(kù)讀取Excel文件數(shù)據(jù)
openpyxl是一個(gè)功能強(qiáng)大的庫(kù),可以輕松地實(shí)現(xiàn)Excel文件的讀寫操作,本文將介紹如何使用openpyxl庫(kù)讀取Excel文件中的數(shù)據(jù),感興趣的小伙伴可以了解下2023-11-11
python算法學(xué)習(xí)之桶排序算法實(shí)例(分塊排序)
本代碼介紹了python算法學(xué)習(xí)中的桶排序算法實(shí)例,大家參考使用吧2013-12-12
python抓取某汽車網(wǎng)數(shù)據(jù)解析html存入excel示例
python抓取某汽車網(wǎng)經(jīng)銷商信息網(wǎng)頁(yè)數(shù)據(jù)解析html,這里提供一個(gè)示例演示,大家可以根據(jù)需要分析自己網(wǎng)站的數(shù)據(jù)2013-12-12

