[英]Python: requests.post not posting
我正在尝试将json字符串发布到Google Firebase。
相同的命令可以在不使用curl的情况下工作,但是如果我使用Python进行操作,则数据库中没有数据。
这是代码:
postdata = {"pm10": pm10, "pm2.5": pm25, "lat": gps_data.get('latitude'), "lon": gps_data.get('longitude'), "alt": gps_data.get('speed'), "spd": gps_data.get('altitude2'), "satt": gps_data.get('satellites')}
logging.info(args.url)
logging.info(postdata)
r = requests.post(args.url, data=postdata, headers={'content-type': 'application/json'})
logging.debug(r)
我使用以下命令调用脚本:
python l.py -u http://blabla.firebaseio.com/test1.json
输出为:
INFO:Serial device initialized
INFO:Posting to http://blabla.firebaseio.com/test1.json
INFO:http://blabla.firebaseio.com/test1.json
INFO:{'satt': 10, 'pm10': 30, 'lon': XX.XXXXX, 'pm2.5': 27, 'lat': YY.YYYYY, 'alt': 0.037, 'spd': 336.8}
INFO:PM 10: 30
INFO:PM 2.5: 27
INFO:Latitude: XX.XXXX
INFO:longitude: YY.YYYYY
但是当我打开数据库时,没有数据。
使用具有相同参数的curl可以正常工作。
更新:
日志调试提供了以下信息:
DEBUG:requests.packages.urllib3.connectionpool:Starting new HTTP connection (1): blabla.firebaseio.com
DEBUG:requests.packages.urllib3.connectionpool:http://blabla.firebaseio.com:80 "POST /test1.json HTTP/1.1" 404 1571
DEBUG:root:<Response [404]>
因此,问题出在,其中一个变量传递为json包含无效的char。
该值为pm2.5,因此我将其重命名为pm25。
关键是不要包含任何字符。 -或类似的东西。
之后,它开始工作。
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.