我有一个用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
使用str
而不是bytes
。我最初的想法是我可能需要编写一个JSON序列化程序。并不是说这么简单的事情很困难,但我不愿意,如果我能用其他方式做到这一点(例如将字典翻译为使用字符串而不是字节)。
答案 0 :(得分: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']}
因此,您首先需要将文件读取字节字符串解码为常规字符串。