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