在 Python 中使用字节数组作为 AES 算法的密钥

Using a byte array as key for AES algorithm in Python

我有一个字节数组,它是一个 128 位的 AES 密钥,我想在 Python 脚本中使用它来使用上述密钥加密一些信息。

我将密钥存储为十六进制字符串,类似于“27821D90D240EA4F56D0E7612396C69E”(显然这不是真正的密钥,但具有相同的格式)。

我已经从那个密钥生成了一个字节数组,这就是我到目前为止在其他语言(Java、C# 和 PHP)中使用 AES 密钥的方式,如下所示:

AES_KEY = bytearray.fromhex('27821D90D240EA4F56D0E7612396C69E')

工作正常,但是当我尝试使用它来创建密码时,它抱怨说它需要第一个参数中的字符串:

cipher = AES.new(AES_KEY, AES.MODE_CBC, os.urandom(16));

TypeError: argument 1 must be string or read-only buffer, not bytearray

我尝试从字节数组中获取一个字符串,如:

AES_KEY = bytearray.fromhex('27821D90D240EA4F56D0E7612396C69E').decode()

AES_KEY = bytearray.fromhex('27821D90D240EA4F56D0E7612396C69E').decode('utf-8')

无济于事,因为该键中有非 ascii 和非 unicode 值。

不能更换钥匙。

有什么想法吗?

非常感谢,

显然这可以解决问题:

AES_KEY = str(bytearray.fromhex('27821D90D240EA4F56D0E7612396C69E'))

现在看起来很明显,不是吗?