requests提交的json.dumps不能被服务器解析
背景:
现有一看上去是内嵌IE应用程序A,可以做一些查询等操作。
目的:
通过借助Wireshark对应用程A的通信过程分析,借助python的requests的库自行构造一个自己能掌控的程序B
状况:
在使用requests库,加载json格式的POST数据,执行特定请求时,遇到对方服务器的报错。
payload_data={"jsonstr":{"pagesize":10,
"pageindex":1,
"start":"2017-03-01",
"end":"2017-03-13",
"keyword":"张三",
"status":"0"
}
}
r = requests.post(url, headers = headers_comm, data = json.dumps(payload_data))
Wireshark对程序A请求的侦听:
自行构造请求时的报错信息:
猜测这个请求的构造基本成功了,但对端应用程序解析我POST的数据时不能正常识别。
尝试过给json.dumps加, ensure_ascii=False的参数,但报错依旧。
如果这个猜测正确的话,POST数据应该怎样正确dumps?
如果这个猜测不正确,那么可能是哪里的原因?
回答:
data = {"jsonstr": json.dumps(jsonstr, ensure_ascii=False)}
r = requests.post(url, json=data)
见https://segmentfault.com/q/10...
感谢@prolifes
回答:
data不需要json.dump,只需要将data中的jsonstr用json.dump来包括以下就可以了,应该是这样,可以试试
回答:
Response Code
是500,是对方反序列化时出错了。
根据exception信息,服务端因该是以下面方式进行反序列化的。
C#:
var jsonObj = (new JavaScriptSerializer()).Deserialize<IDictionary<string, string>>(jsonString);
你的payload_data
格式错了,是嵌套字典。
把payload_data
改成:
Python:
payload_data={"pagesize":10,
"pageindex":1,
"start":"2017-03-01",
"end":"2017-03-13",
"keyword":"张三",
"status":"0"
}
就可以了。
以上是 requests提交的json.dumps不能被服务器解析 的全部内容, 来源链接: utcz.com/a/165738.html