我正在尝试从http://erdos.sdslabs.co/users/shagun.json获取JSON响应。使用浏览器/ Python的Requests库会导致身份验证错误,但是curl似乎可以正常工作。
curl http://erdos.sdslabs.co/users/shagun.json
返回JSON响应。
为什么普通浏览器或基于请求的请求失败时,curl请求将起作用?
使用telnet检查:
$ telnet erdos.sdslabs.co 80
Trying 62.141.37.215...
Connected to erdos.sdslabs.co.
Escape character is '^]'.
GET http://erdos.sdslabs.co/users/shagun.json HTTP/1.0
HTTP/1.1 302 Found
Date: Sat, 26 Jul 2014 11:18:58 GMT
Server: Apache
Set-Cookie: PHPSESSID=juvg7vrg3vs4t00om3a95m4sc7; path=/
Expires: Thu, 19 Nov 1981 08:52:00 GMT
Cache-Control: no-store, no-cache, must-revalidate, post-check=0, pre-check=0
Pragma: no-cache
Location: /login
Access-Control-Allow-Origin: http://erdos.sdslabs.co
X-Powered-By: PleskLin
Content-Length: 1449
Connection: close
Content-Type: application/json
{"email":"[email protected]","username":"shagun","name":"Shagun
[...]
我们看到Web服务器正在响应302-重定向到Location / login。请求和Web浏览器正在遵循该要求,并到达登录提示。但是,我们看到Web服务器也用您需要的json进行响应,并且curl(和telnet)非常简单,只接受该数据即可。
最佳实践是修复Web服务器,使其既不需要您登录,也不会在要求用户登录的同时不提供受密码保护的数据。
如果您无法更改Web服务器,则可以告诉请求模块忽略重定向:
import requests
result = requests.get('http://erdos.sdslabs.co/users/shagun.json', allow_redirects=False)
print result.content
本文收集自互联网,转载请注明来源。
如有侵权,请联系[email protected] 删除。
我来说两句