美文网首页
python3.6 AES 加密解密

python3.6 AES 加密解密

作者: 搬砖_工程师 | 来源:发表于2019-01-23 11:42 被阅读16次

    本来以为这是个比较简单的东西,网上一搜一大把。搜索结果气的我自己看文档写了一个。
    首先安装pycryptodome或者pycryptodomex 用pip 安装,安装之后需要修改包名crypto改为Crypto

    import base64
    from Crypto.Cipher import AES
    
    '''
    采用AES对称加密算法
    '''
    # str不是32的倍数那就补足为16的倍数
    def add_to_32(value):
        while len(value) % 32 != 0:
            value += '\0'
        return str.encode(value)  # 返回bytes
    #加密方法
    def encrypt_oracle(text):
        # 秘钥
        key = 'lymhqnoetl15321'
        # 待加密文本
        # 初始化加密器
        aes = AES.new(add_to_32(key), AES.MODE_ECB)
        #先进行aes加密
        encrypt_aes = aes.encrypt(add_to_32(text))
        #用base64转成字符串形式
        encrypted_text = str(base64.encodebytes(encrypt_aes), encoding='utf-8')  # 执行加密并转码返回bytes
        print(encrypted_text)
        return encrypted_text
    #解密方法
    def decrypt_oralce(text):
        # 秘钥
        key = 'lymhqnoetl15321'
        # 密文
        # 初始化加密器
        aes = AES.new(add_to_32(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__':
       # encrypt_oracle()
        encrypt_oracle('2019-12-12')
    

    我是采用ECB模式加密你也可以用其他模式加密,模式区别可以看这篇https://www.cnblogs.com/liangxuehui/p/4651351.html
    秘钥加密解密需要统一。

    相关文章

      网友评论

          本文标题:python3.6 AES 加密解密

          本文链接:https://www.haomeiwen.com/subject/fljjjqtx.html