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類型

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章