189 8069 5689

实现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)

另外有需要云服务器可以了解下创新互联scvps.cn,海内外云服务器15元起步,三天无理由+7*72小时售后在线,公司持有idc许可证,提供“云服务器、裸金属服务器、高防服务器、香港服务器、美国服务器、虚拟主机、免备案服务器”等云主机租用服务以及企业上云的综合解决方案,具有“安全稳定、简单易用、服务可用性高、性价比高”等特点与优势,专为企业上云打造定制,能够满足用户丰富、多元化的应用场景需求。


本文名称:实现base64+gzip+AES-ECB加密解密-创新互联
本文来源:http://gzruizhi.cn/article/dpoodp.html

其他资讯