在 Python3 中尝试创建新的 AES 密码时收到类型错误

Receiving a TypeError in trying to create a new AES cipher in Python3

刚刚在 Pycharm 安装了 PyCryptodome。我有 3 行代码。我正在尝试为 AES 函数提供硬 iv 和键值。它抛出这个:

  File "C:\Users\user\PycharmProjects\CS\venv\lib\site-packages\Crypto\Cipher\AES.py", line 92, in _create_base_cipher
if len(key) not in key_size:
TypeError: object of type 'int' has no len()

这是我的代码。

iv = 0x0008739a3043314e614c4b764f234189
key = 0xf188c2f6176502368ab346a0b40f1098ed350c3c46595e998147ab1db9d865b7
cipher = AES.new(key, AES.MODE_CBC, iv)

我试过转换为二进制,但我得到的 AES 密钥长度不正确 (258)

iv = 0x0008739a3043314e614c4b764f234189
biv = bin(iv)
key = 0xf188c2f6176502368ab346a0b40f1098ed350c3c46595e998147ab1db9d865b7
bkey = bin(key)

cipher = AES.new(bkey, AES.MODE_CBC, biv)    


ValueError: Incorrect AES key length (258 bytes)

密钥应以字节为单位。将整数转换为字节:

key = 0xf188c2f6176502368ab346a0b40f1098ed350c3c46595e998147ab1db9d865b7
bkey = key.to_bytes(32, 'big')
>>> bkey
b'\xf1\x88\xc2\xf6\x17e\x026\x8a\xb3F\xa0\xb4\x0f\x10\x98\xed5\x0c<FY^\x99\x81G\xab\x1d\xb9\xd8e\xb7'

请注意,bin() 将整数转换为字符串,将数字表示为“0”和“1”字符的序列,这在这里用处不大。