實現 base64+gzip+AES-ECB加密解密
阿新 • • 發佈:2018-11-09
實現base64+gzip+AES-ECB加密解密
# 本程式碼基於python3.6.1測試通過 import base64 from Crypto.Cipher import AES from io import StringIO import gzip ''' 採用AES對稱加密演算法 ''' # str不是16的倍數那就補足為16的倍數 def add_to_16(value): while len(value) % 16 != 0: value += '\0' return str.encode(value) # 返回bytes # 加密方法 def encrypt_oracle(): # 祕鑰 key = 'jiayanmiyao' # 待加密文字 text = 'testing' # 初始化加密器 aes = AES.new(add_to_16(key), AES.MODE_ECB) # 先進行aes加密 encrypt_aes = aes.encrypt(add_to_16(text)) # 用base64轉成字串形式 encrypted_text = base64.encodebytes(encrypt_aes) # 執行加密並轉碼返回bytes # str(encoding=utf-8) #gzip壓縮 en_gzip = gzip.compress(encrypted_text) #base64編碼 en_base64 = base64.b64encode(en_gzip) return en_base64 # 解密方法 def decrypt_oralce(text): # 祕鑰 key = 'jiayanmiyao' # 密文 # base64解碼 de_base64 = base64.b64decode(text) # gzip解壓 de_gzip = gzip.decompress(de_base64) text = str(de_gzip, encoding="utf-8") # 初始化加密器 aes = AES.new(add_to_16(key), AES.MODE_ECB) # 優先逆向解密base64成bytes base64_decrypted = base64.decodebytes(text.encode(encoding='utf-8')) # 執行解密密並轉碼返回str decrypted_text = str(aes.decrypt(base64_decrypted), encoding='utf-8').replace('\0', '') return decrypted_text if __name__ == '__main__': en_result = encrypt_oracle() print(en_result) de_result = decrypt_oralce(en_result) print(de_result)