首頁 >後端開發 >Python教學 >Python--AES加密與解密方法指導

Python--AES加密與解密方法指導

巴扎黑
巴扎黑原創
2017-07-21 14:19:293441瀏覽

起源:

影片下載,解析到一個網站時,發現其影片id是用AES加密過的,用的是這個函式庫。
解密很簡單的一句js程式碼:

t.video = CryptoJS.AES.decrypt(t.video, secret).toString(CryptoJS.enc.Utf8);

#原本想著簡單,找段python程式碼做解密是了,沒想到反覆嘗試,寫法五花八門多種多樣,就是解不出來,竟費去許多工夫!

如何簡單?我只實現驗證下面的字符串加解密:

    # data = '-85297962_172051801'# key = '583a01a9ba901a3adda7252ebca42c09'# encrypt_data = 'U2FsdGVkX192df0Gxgia8s93zZp85f9m2nU1VIGU+RZQDtViB1LPBnE0CBWgVDBj'

 

1、Python Cryptography Toolkit (pycrypto)

加解密需要用到它,其網址是:
目前最新版本為2.6.1。如何安裝及其簡單Demo,其頁面上都 ,而其用法在網上一搜也到處都是,可就是不能解決我的問題,我想是我用錯了,但哪種才是對的哪!

crypto-js這個,應該用的是AES預設模式,AES.MODE_CBC。 js程式碼也是難懂,總是不停試不停試!

 

2、加密與解密

#直接上程式碼吧,它滿足了需求:

# coding=utf-8import base64from Crypto.Cipher import AESfrom Crypto import Randomfrom hashlib import md5

BLOCK_SIZE = AES.block_sizedef pad(data):
    length = BLOCK_SIZE - (len(data) % BLOCK_SIZE)return data + (chr(length) * length).encode()def unpad(data):return data[:-(data[-1] if type(data[-1]) == int else ord(data[-1]))]def bytes_to_key(my_data, salt, output=48):# extended from assert len(salt) == 8, len(salt)
    my_data += salt
    key = md5(my_data).digest()
    final_key = keywhile len(final_key) < output:
        key = md5(key + my_data).digest()
        final_key += keyreturn final_key[:output]def encrypt(message, passphrase):
    salt = Random.new().read(8)
    key_iv = bytes_to_key(passphrase, salt, 32 + 16)
    key = key_iv[:32]
    iv = key_iv[32:]
    aes = AES.new(key, AES.MODE_CBC, iv)return base64.b64encode(b"Salted__" + salt + aes.encrypt(pad(message)))def decrypt(data, password):if len(data) <= BLOCK_SIZE:return data

    data = base64.b64decode(data)
    salt = data[8:16]
    key_iv = bytes_to_key(password, salt, 32 + 16)
    key = key_iv[:32]
    iv = key_iv[32:]

    cipher = AES.new(key, AES.MODE_CBC, iv)return unpad(cipher.decrypt(data[BLOCK_SIZE:]))if __name__ == '__main__':# data = '-85297962_172051801'# key = '583a01a9ba901a3adda7252ebca42c09'# encrypt_data = 'U2FsdGVkX192df0Gxgia8s93zZp85f9m2nU1VIGU+RZQDtViB1LPBnE0CBWgVDBj'key = '583a01a9ba901a3adda7252ebca42c09'data = '-85297962_172051801'encrypt_data = encrypt(data, key)print encrypt_data# encrypt_data = 'U2FsdGVkX192df0Gxgia8s93zZp85f9m2nU1VIGU+RZQDtViB1LPBnE0CBWgVDBj'decrypt_data = decrypt(encrypt_data, key)print 'decrypt_data:', decrypt_data

同一個字符串,發現加密後的字符串,每次不盡相同。對AES沒多研究,挺覺奇怪!

 

3、打包與發布

若是只用到了Crypto一部分功能,例如我們用到的aes解密,則可以抽簡出來所需程式碼,以避免打入整個Crypto庫。

奇怪的是,引用_AES.pyd這個動態函式庫,引用路徑有問題。查閱資料,原來Crypto寫死了它的引用路徑,其頁碼有如此寫:

#
#ifdef IS_PY3Km = PyModule_Create(&moduledef);#elsem = Py_InitModule("Crypto.Cipher." _MODULE_STRING, modulemethods);#endif

 

而用py2exe打包抽取,其把Crypto\Cipher\_AES.pyd改名為Crypto.Cipher._AES.pyd文件,放與發布目錄下,令人頗長見識

以上是Python--AES加密與解密方法指導的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn