标签:改版 AES PyCrypto 16 text base64 aes str
今天在弄环境配置中,密码加密的问题。遇到一片好文章 https://blog.csdn.net/s740556472/article/details/79026128
按照这个文章的代码全部copy,就可以执行了~~但是遇到一个深坑,纠结了变天。
原来是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 #版权声明:本文为博主原创文章,转载请附上博文链接!
长见识点:
用Base64编码的时候如果出现\n 之类的字符。
当字符串过长(一般超过76)时会自动在中间加一个换行符,字符串最后也会加一个换行符。导致和其他模块对接时结果不一致。
所以以后遇到Base64编码的问题,一定要小心\n.
内心深处。。。搞了一下午以为是pyCrypto的问题,最终发觉解码看起来同样的一段字符串,直接decrypto("aaa\nbbb")不报错,但是
str_text = "aaa\nbbb"; decrypto(str_text) 就会报错。。。最终通过比较长度以及打印,发觉是base64的\n搞的事情。。。心塞。。
标签:改版,AES,PyCrypto,16,text,base64,aes,str 来源: https://www.cnblogs.com/shuo-yang0459/p/10445840.html
本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享; 2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关; 3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关; 4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除; 5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。