今天在弄环境配置中,密码加密的问题。遇到一片好文章 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