我目前正在开发一个python应用程序,它可以使用facebook,我们都知道,facebook喜欢他们自己的技术,并且正在使用zstd进行数据压缩。
问题是: facebook用普通的json返回一个未压缩的响应,或者如果响应更长,它将使用zstd压缩的json进行响应。
我当前的代码如下所示:
import zstd
import json
def handle_response(response)
json = None
try:
json = json.loads(zstd.decompress(response.content))
except:
json = json.loads(response.text)
return json我目前想知道,是否有一种更干净的方法来做到这一点,甚至检测zstd。
发布于 2021-08-03 15:25:49
你所做的一切都很好。
我想,您可以检查流是否以四个字节的28 b5 2f fd开始。如果没有,那就不是zstd流。如果是的话,它可能是zstd流。在后一种情况下,您将尝试解压缩,如果它失败,您将回到仅仅复制输入。
这与您正在做的事情完全相同,因为zstd.decompress首先要做的就是查找该签名。
https://stackoverflow.com/questions/68637971
复制相似问题