5

我有一个用 Python3 编写的简单 Web 服务器(使用来自 的类http.server),我将其从 2 移植到 3。

我有以下代码:

# More code here...
postvars = cgi.parse_qs(self.rfile.read(length),
                        keep_blank_values=1)
something.json_run(json.dumps(postvars))

哪个抛出:

TypeError: keys must be a string

通过检查数据,我确定parse_qs似乎将键编码为字节,这就是引发错误的原因(json显然不喜欢字节)。

import json
json.dumps({b'Throws error' : [b"Keys must be a string"]})
json.dumps({'Also throws error': [b'TypeError, is not JSON serializable']})
json.dumps({'This works': ['No bytes!']})

这里最好的解决方案是什么?在 Python 2 中,代码运行良好,因为parse_qs使用strbytes. 我最初的想法是我可能需要编写一个 JSON 序列化程序。并不是说这么简单的事情很难,但如果我能以其他方式做到这一点,我宁愿不这样做(例如,将字典翻译成使用字符串而不是字节)。

4

1 回答 1

2

首先,该cgi.parse_qs函数已被弃用,仅是 的别名urllib.parse.parse_qs,您可能需要调整导入路径。

其次,您将一个字节字符串传递给 parse 方法。如果您传入常规(unicode)字符串,则该parse_qs方法返回常规字符串:

>>> from urllib.parse import parse_qs
>>> parse_qs(b'a_byte_string=foobar')
{b'a_byte_string': [b'foobar']}
>>> parse_qs('a_unicode_string=foobar')
{'a_unicode_string': ['foobar']}

因此,您需要先将文件读取的字节字符串解码为常规字符串。

于 2012-06-11T17:14:34.690 回答