導(dǎo)致這種錯(cuò)誤的原因是沒有正確安裝AES庫(kù),執(zhí)行下面命令安裝Python3版本的AES庫(kù):
讓客戶滿意是我們工作的目標(biāo),不斷超越客戶的期望值來(lái)自于我們對(duì)這個(gè)行業(yè)的熱愛。我們立志把好的技術(shù)通過有效、簡(jiǎn)單的方式提供給客戶,將通過不懈努力成為客戶在信息化領(lǐng)域值得信任、有價(jià)值的長(zhǎng)期合作伙伴,公司提供的服務(wù)項(xiàng)目有:申請(qǐng)域名、網(wǎng)頁(yè)空間、營(yíng)銷軟件、網(wǎng)站建設(shè)、杭州網(wǎng)站維護(hù)、網(wǎng)站推廣。
pipinstall?pycryptodome
------------------------------
ID:Python之戰(zhàn)
|作|者|公(zhong)號(hào):python之戰(zhàn)?
專注Python,專注于網(wǎng)絡(luò)爬蟲、RPA的學(xué)習(xí)-踐行-總結(jié)
喜歡研究和分享技術(shù)瓶頸,歡迎關(guān)注
獨(dú)學(xué)而無(wú)友,則孤陋而寡聞!
---------------------------
它被預(yù)期能成為人們公認(rèn)的加密包括金融、電信和政府?dāng)?shù)字信息的方法。 AES 是一個(gè)新的可以用于保護(hù)電子數(shù)據(jù)的加密算法。明確地說,AES 是一個(gè)迭代的、對(duì)稱密鑰分組的密碼,它可以使用128、192 和 256 位密鑰,并且用 128 位(16字節(jié))分組加密和解密數(shù)據(jù)。與公共密鑰密碼使用密鑰對(duì)不同,對(duì)稱密鑰密碼使用相同的密鑰加密和解密數(shù)據(jù)。通過分組密碼返回的加密數(shù)據(jù) 的位數(shù)與輸入數(shù)據(jù)相同。迭代加密使用一個(gè)循環(huán)結(jié)構(gòu),在該循環(huán)中重復(fù)置換(permutations )和替換(substitutions)輸入數(shù)據(jù)。Figure 1 顯示了 AES 用192位密鑰對(duì)一個(gè)16位字節(jié)數(shù)據(jù)塊進(jìn)行加密和解密的情形。
這個(gè)不會(huì)呀。一般好像都用openssl解密。知道密碼(可能還有椒鹽密碼)的情況下,按照指定模式解密。python的話,可能要綁定openssl來(lái)處理
就不給定義了,我簡(jiǎn)單解釋下,就是我的信息不想讓別人知道,使用 秘鑰(key) 對(duì)我的信息進(jìn)行 加密(encrypt) ,變成鬼符一樣的 秘文(ciphertext) 。別人就算看到了,也無(wú)法識(shí)別,只有有了秘鑰,把秘文 解密(decrypt) 后才能看懂信息,秘鑰呢?一般人我不告訴他。我的秘鑰是私密信息,所以也叫 私鑰(private key) ,加密和解密用的秘鑰是相同的,所以叫 “對(duì)稱加密” ,也叫 “私鑰加密” 。
對(duì)于明文plaintext,和對(duì)稱秘鑰key
加密過程 E(plaintext, key) = ciphertext
解密過程 D(ciphertext, key) = plaintext
對(duì)稱加密的分為 分組密碼(block cipher) 和 流密碼(stream cipher) 兩種類型。本文只介紹分組密碼。
分組密碼是每次只能處理特定長(zhǎng)度的一塊(block)數(shù)據(jù)的一類加解密算法。AES就是一種分組密碼算法。AES加密算法每次可以加密的塊長(zhǎng)度是128位(bit)。
ECB模式
使用AES加密算法ECB模式,每次能加密128位數(shù)據(jù),即16個(gè)字節(jié)。如果要加密48個(gè)字節(jié)內(nèi)容,我們需要把數(shù)據(jù)分為3組,每組16個(gè)字節(jié),分別為P1、P2、P3。P1、P2、P3加密后形成的秘文分別為C1、C2、C3,我們把C1、C2、C3依次拼接起來(lái)就成為最終的加密結(jié)果。
CBC模式
《對(duì)稱加密之對(duì)稱加密二》正在寫作,會(huì)包含分組密碼的更多模式,流密碼及AES的更多知識(shí)。
DES加密:舊的加密算法,NIST規(guī)定僅能用于遺留系統(tǒng)和TDEA。(參考文獻(xiàn)[CNS] 3.2章)
TDEA(Triple DEA)加密:很多資料也叫3DES(Triple DES)。(參考文獻(xiàn)[SP800-67])
Python 可以使用 pycrypto 模塊進(jìn)行AES加解密。安裝 pycrypto 可使用命令 pip install pycrypto 安裝。
下面AES演示第一版,先看下,緊接著就會(huì)升級(jí)到第二版本。
運(yùn)行一下,能正常加解密。但是,如果你把要加密的文本,從 aesAlgorithmDemo 改為 hello ,就會(huì)運(yùn)行報(bào)錯(cuò):
這是因?yàn)?,AES的分組長(zhǎng)度是128位,即16個(gè)字節(jié)。有些AES實(shí)現(xiàn),要加密的消息長(zhǎng)度不是16個(gè)字節(jié)的倍數(shù)需要填充。
填充的方法一般是按照PKCS#7填充標(biāo)準(zhǔn)。
如果要數(shù)據(jù)的長(zhǎng)度不是分組的整數(shù)倍,需要填充數(shù)據(jù)到分組的倍數(shù),如果數(shù)據(jù)的長(zhǎng)度是分組的倍數(shù),需要填充分組長(zhǎng)度的數(shù)據(jù),填充的每個(gè)字節(jié)值為填充的長(zhǎng)度。PKCS#7支持的分組長(zhǎng)度為1到255個(gè)字節(jié)。
舉一些例子:
AES的分組長(zhǎng)度為16個(gè)字節(jié),不管秘鑰是128位、192位還是256位。如果要加密的數(shù)據(jù)長(zhǎng)度是5個(gè)字節(jié),你需要填充11個(gè)字節(jié),填充的內(nèi)容位填充的長(zhǎng)度0x0b。填充后類似下面表示
如果數(shù)據(jù)長(zhǎng)度是30個(gè)字節(jié),需要填充2個(gè)字節(jié),每個(gè)字節(jié)的內(nèi)容為0x02,如果數(shù)據(jù)成都恰好為16的倍數(shù),需要填充16個(gè)字節(jié),每個(gè)字節(jié)的內(nèi)容為0x10。
弄明白填充的概念后,我們重寫加解密函數(shù)如下:
這樣填充后會(huì)不會(huì)可其它系統(tǒng)不兼容?不會(huì)。一般的AES程序都是支持PKCS#7填充的。
密碼學(xué)基礎(chǔ)之RSA與不對(duì)稱秘鑰
密碼學(xué)基礎(chǔ)系列
[CNS] 《密碼編碼學(xué)與網(wǎng)絡(luò)安全》(第六版)
[SP800-67] NIST Special Publication 800-67 Revision 1, Recommendation for Triple Data Encryption Algorithm (TDEA) Block Cipher, January 2012.
[SSH] OpenSSH CBC模式信息泄露漏洞
[NIST SP 800-57 Part 1 Rev. 4] Recommendation for Key Management, Part 1: General
問題背景:
m3u8文件加密時(shí),使用“from Crypto.Cipher import AES”相關(guān)函數(shù)解密:
#EXT-X-KEY 記錄了加密的方式,一般是AES-128以及加密的KEY信息
出現(xiàn)問題:
from Crypto.Cipher import AES
pip install Crypto
出錯(cuò)
解決辦法:
安裝crypto庫(kù)(首字母c是小寫)
pip install crypto
進(jìn)入python的庫(kù)管理位置,site-packages文件夾,找到crypto,將其首字母c改為大寫
判斷是否解決的方式:
from Crypto.Cipher import AES
不會(huì)報(bào)錯(cuò),說明成功。
備注:
如果在C:\Python36\Lib\site-packages\Crypto目錄下沒有找到:\Cipher目錄。
可以嘗試安裝pycryptodome庫(kù) 或 pycrypto庫(kù):
pip install pycryptodome
pip install pycrypto (安裝這個(gè)庫(kù),基本會(huì)失敗,會(huì)報(bào)錯(cuò))
你看一下這個(gè)例子吧??梢詤⒖枷旅娴牡刂罚呵懊婕由蟞ttp,把句號(hào)改成點(diǎn)。
likang。me/blog/2013/06/05/python-pycrypto-aes-ecb-pkcs-5/
#?-*-?coding:?utf-8?-*-
from?Crypto.Cipher?import?AES
import?os
BS?=?AES.block_size
pad?=?lambda?s:?s?+?(BS?-?len(s)?%?BS)?*?chr(BS?-?len(s)?%?BS)
unpad?=?lambda?s?:?s[0:-ord(s[-1])]
key?=?os.urandom(16)?#?the?length?can?be?(16,?24,?32)
text?=?'to?be?encrypted'
cipher?=?AES.new(key)
encrypted?=?cipher.encrypt(pad(text)).encode('hex')
print?encrypted??#?will?be?something?like?'f456a6b0e54e35f2711a9fa078a76d16'
decrypted?=?unpad(cipher.decrypt(encrypted.decode('hex')))
print?decrypted??#?will?be?'to?be?encrypted'