【转发+埋坑】python3.6 + PyCrypto实现AES加密、解密(改版)>>> 再改版

今天在弄环境配置中,密码加密的问题。遇到一片好文章 https://blog.csdn.net/s740556472/article/details/79026128算法

按照这个文章的代码所有copy,就能够执行了~~可是遇到一个深坑,纠结了变天。oracle

 

原来是base64转码会出现\n 致使的。编码

因此须要在原来的代码上更改成:加密

#AES-demo

import base64
from Crypto.Cipher import AES

'''
采用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 = '123456'
    # 待加密文本
    text = 'abc123def456'
    # 初始化加密器
    aes = AES.new(add_to_16(key), AES.MODE_ECB)
    #先进行aes加密
    encrypt_aes = aes.encrypt(add_to_16(text))
    #用base64转成字符串形式
    encrypted_text = str(base64.encodebytes(encrypt_aes), encoding='utf-8')  # 执行加密并转码返回bytes
    print(encrypted_text)
    
    # base64会存在\n的状况,转码会出现深坑。建议改成以下:
    return encrypted_text.replace("\n","")    


#解密方法
def decrypt_oralce():
    # 秘钥
    key = '123456'
    # 密文
    text = 'qR/TQk4INsWeXdMSbCDDdA=='
    # 初始化加密器
    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','') 
    print(decrypted_text)

if __name__ == '__main__':
   # encrypt_oracle()
    decrypt_oralce()


#--------------------- 
#做者:sy_y 
#来源:CSDN 
#原文:https://blog.csdn.net/s740556472/article/details/79026128 
#版权声明:本文为博主原创文章,转载请附上博文连接!

 

长见识点:spa

用Base64编码的时候若是出现\n 之类的字符。.net

当字符串过长(通常超过76)时会自动在中间加一个换行符,字符串最后也会加一个换行符。致使和其余模块对接时结果不一致。3d

因此之后遇到Base64编码的问题,必定要当心\n.code

 

心里深处。。。搞了一下午觉得是pyCrypto的问题,最终发觉解码看起来一样的一段字符串,直接decrypto("aaa\nbbb")不报错,可是blog

str_text = "aaa\nbbb"; decrypto(str_text) 就会报错。。。最终经过比较长度以及打印,发觉是base64的\n搞的事情。。。心塞。。ip

相关文章
相关标签/搜索