python - 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?如果这个猜测不正确,那么可能是哪里的原因?
问题解答
回答1:data不需要json.dump,只需要将data中的jsonstr用json.dump来包括以下就可以了,应该是这样,可以试试
回答2: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'}
就可以了。
相关文章:
1. word-wrap该如何使用?2. mysql主从,从库锁表会导致复制阻塞吗?3. mysql中的join on查询语句的on能否改为where4. 为什么HTML5规范中会包含一些和html无关的东西?如本地存储等。5. mysql - 我用SQL语句 更新 行的时候,发现全部 中文都被清空了,请问怎么解决?6. update方法不能更新字段值为0的数据7. javascript - ES5的闭包用ES6怎么实现8. javascript - 小米浏览器中,图片导致fixed定位的元素无法显示9. javascript - 为什么!function foo(){}返回false,!function foo(){}()返回true?10. html - 特殊样式按钮 点击按下去要有凹下和弹起的效果
