濮阳杆衣贸易有限公司

主頁 > 知識庫 > python實現(xiàn)希爾密碼加密的示例代碼

python實現(xiàn)希爾密碼加密的示例代碼

熱門標簽:百應電話機器人總部 成都呼叫中心外呼系統(tǒng)哪家強 西青語音電銷機器人哪家好 旅游廁所地圖標注怎么弄 宿州電話機器人哪家好 南昌地圖標注 無錫智能外呼系統(tǒng)好用嗎 電梯新時達系統(tǒng)外呼顯示e 地圖標注與注銷

原理

希爾密碼是運用基本矩陣論原理的替換密碼,由Lester S. Hill在1929年發(fā)明。

每個字母當作26進制數(shù)字:A=0, B=1, C=2… 一串字母當成n維向量,跟一個n×n的矩陣相乘,再將得出的結(jié)果模26。(注意用作加密的矩陣(即密匙)在 必須是可逆的,否則就不可能解碼。只有矩陣的行列式和26互質(zhì),才是可逆的。)

實現(xiàn)

希爾密碼是運用基本矩陣論原理的替換密碼,使用一個m*m的矩陣作為密鑰,此矩陣必須可逆,解密使用逆矩陣解密。

  • 加密: 密文向量 = 密鑰矩陣 * 明文向量 (mod 26)
  • 解密:明文向量 = 密鑰矩陣逆矩陣 * 密文向量 (mod 26)

使用numpy庫的矩陣對象,可以十分方便地進行矩陣乘法,矩陣求逆和取模等運算。

import numpy as np

m = 'YOURPINNOISFOURONETWOSIX'  #明文
a = np.matrix([[11,2,19],[5,23,25],[20,7,17]])  #密鑰LCTFXZUHR
num_m = []
temp = []
count = 1
for i in m:  #將明文分為三個一組
    temp.append(ord(i)-ord('A'))
    if count % 3 == 0:
        num_m.append(temp)
        temp = []
    count += 1
mat_m = [np.matrix(i).T for i in num_m]  #將明文分組轉(zhuǎn)換為向量形式
mat_c = [a * i % 26 for i in mat_m]  #得到密文分組的向量形式
num_c = []
temp = []
for i in mat_c:  #將密文向量轉(zhuǎn)換為列表形式,且合并到一個列表
    temp = i.tolist()
    for j in range(3):
        num_c.append(temp[j][0])
c = [chr(i+ord('A')) for i in num_c]
print(''.join(c))  #連接成字符串,輸出密文

到此這篇關于python實現(xiàn)希爾密碼加密的示例代碼的文章就介紹到這了,更多相關python 希爾密碼加密內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!

您可能感興趣的文章:
  • 使用python實現(xiàn)希爾、計數(shù)、基數(shù)基礎排序的代碼
  • Python排序搜索基本算法之希爾排序?qū)嵗治?/li>
  • Python實現(xiàn)希爾排序算法的原理與用法實例分析
  • python編程實現(xiàn)希爾排序
  • python實現(xiàn)的希爾排序算法實例

標簽:濰坊 許昌 贛州 西安 渭南 辛集 雅安 七臺河

巨人網(wǎng)絡通訊聲明:本文標題《python實現(xiàn)希爾密碼加密的示例代碼》,本文關鍵詞  python,實現(xiàn),希爾,密碼,加密,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問題,煩請?zhí)峁┫嚓P信息告之我們,我們將及時溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡,涉及言論、版權(quán)與本站無關。
  • 相關文章
  • 下面列出與本文章《python實現(xiàn)希爾密碼加密的示例代碼》相關的同類信息!
  • 本頁收集關于python實現(xiàn)希爾密碼加密的示例代碼的相關信息資訊供網(wǎng)民參考!
  • 推薦文章
    彭泽县| 明水县| 云梦县| 千阳县| 达拉特旗| 岑巩县| 新干县| 四子王旗| 娱乐| 商水县| 张家口市| 甘德县| 沛县| 通江县| 长宁区| 台江县| 汉中市| 将乐县| 彭山县| 安新县| 冷水江市| 吐鲁番市| 米泉市| 航空| 深泽县| 云林县| 南郑县| 汉源县| 新蔡县| 辽阳市| 福海县| 通江县| 吴江市| 普洱| 麟游县| 正镶白旗| 石渠县| 林芝县| 太保市| 乌鲁木齐县| 武义县|