首页 > 解决方案 > 使用 python 解密 Amazon SP API 报告文档。AES、CBC、base64

问题描述

我正在尝试解密报告文档。我有以下解密细节:

{
"payload": {
    "reportDocumentId": "XXXX",
    "encryptionDetails": {
        "standard": "AES",
        "initializationVector": "XXXX",
        "key": "XXXX"
    },
    "url": "https://XXXXX"
}}

使用这些细节,我尝试编写各种代码,给出不同的错误 1。

from base64 import b64encode 
import hashlib 
import pyaes 
import os
from sys import getsizeof

content = requests.get(url)
ciphertext = content.text
#ciphertext = b64encode(bytes(content.text))
print(getsizeof(key))
print(getsizeof(iv))
decrypter = pyaes.Decrypter(pyaes.AESModeOfOperationCBC(key, iv)) 
decryptedData = decrypter.feed(ciphertext) 
decryptedData += decrypter.feed()
print(decryptedData)

这显示了以下错误:ValueError:初始化向量必须为 16 字节 我的初始化向量和键在 base64 中。它们的大小分别为 73 和 93

2.

content = requests.get(url)

message = content.text
print(len(message))

obj = AES.new(key, AES.MODE_CBC, iv)
print(obj.decrypt(message))

这会产生以下错误:ValueError: Incorrect AES key length (44 bytes)

我该如何解决这个问题?除此之外的任何方法也将非常有帮助

AWS KMS 是否有助于解密此类数据?

标签: pythonencryptionaespython-cryptographyamazon-kms

解决方案


content = requests.get(url)
message = content.content
dec_key = b64decode(key)
dec_iv = b64decode(iv)
obj = AES.new(dec_key, AES.MODE_CBC, dec_iv)
decrypt_text = obj.decrypt(message)

修改后的代码给出了所需的输出。解码密钥和iv。这个答案不是我的,我是从关于stackoverflow的各种问题中收集的。为任何可能需要它的人编写它。


推荐阅读