1. 程式人生 > >實現 base64+gzip+AES-ECB加密解密

實現 base64+gzip+AES-ECB加密解密

實現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)