3.3.车载中常用AES128 CBC作为安全日志等数据加密方式
一.AES加密简介
AES是一种常用对称加密算法,实现AES有几种模式,主要有ECB、CBC、CFB等几种模式,其中CBC模式中还有一个偏移量参数IV,它提供了较高的安全性。
二.AES128 CBC加密后数据解密
AES-128用32位十六进制密钥,需知悉两个重要变量,key(密匙),和iv(偏移向量),不同的IV可以产生不同的密文,增加了加密的灵活性
可用第三方库文件Crypto进行解密操作
1.先将key / iv 利用bytes.fromhex() 十六进制转换为字符串
key_bytes = bytes.fromhex(key)
iv_bytes = bytes.fromhex(iv)
2.用replace(' ', '')去除待解密数据中空格
data = ciphertext.replace(' ', '')
3.将data十六进制转换为字符串
decoded_data = bytes.fromhex(data)
4.解密数据并转化成16进制字符串
使用unpad
函数去除解密数据中的填充字符,以还原其原始长度
cipher = AES.new(key=key_bytes, mode=AES.MODE_CBC, iv=iv_bytes)
plaintext = cipher.decrypt(decoded_data).hex()
# plaintext = unpad(plaintext, AES.block_size) (是否需要unpad 需根据数据要求,可尝试)
完整代码如下:
from Crypto.Cipher import AES
def decrypt_aes_cbc(ciphertext, key='', iv=''):
try:
key_bytes = bytes.fromhex(key)
iv_bytes = bytes.fromhex(iv)
data = ciphertext.replace(' ', '')
# 将base64解码改为十六进制转换
decoded_data = bytes.fromhex(data)
cipher = AES.new(key=key_bytes, mode=AES.MODE_CBC, iv=iv_bytes)
plaintext = cipher.decrypt(decoded_data).hex()
# plaintext = unpad(plaintext, AES.block_size)
print('解密后数据:', plaintext)
except Exception as e:
print("解密错误:", str(e))