python 中对 aes加密json数据,进行解密时注意点

from Crypto.Cipher import AES
    def params_aes_encrypt(self,text):
    '''数据加密'''
    text = text.replace(" ", "")
    BS = 16
    pad = lambda s: s + (BS - len(s) % BS) * chr(BS - len(s) % BS)
    text = pad(text)
    o_aes = AES.new(self.aes__key.encode(), AES.MODE_CBC, self.aes_iv.encode())
    esb = o_aes.encrypt(text.encode("UTF8"))
    ep = base64.b64encode(esb).decode("UTF8")
    return ep

def params_aes_dncrypt(self,text):
    '''数据解密'''
    o_aes = AES.new(self.aes__key.encode(), AES.MODE_CBC, self.aes_iv.encode())
    plain_text = o_aes.decrypt(base64.b64decode(text))
    return plain_text

// aes采用的是pycryptodome包中的aes
1.self.aes__key 和 self.aes_iv 值必须是字节类型
2.大坑,aes在对数据解密时,返回的是bytes类型,会在数据最后添加空格,这样在json.loads()时会爆出
source code string cannot contain null bytes错误。解决办法时在数据解密后,调用bytes的strip()方法删除空格,再json.loads 是就可以了
3.需要注意网页返回数据的格式,可以采用chardet包的detect(string) string需要时bytes类型

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值