通过一个案例来分析在HTTP的请求中403错误的解决以及HTTP的状态码中403怎么理解,见发送一个请求后,返回的状态码,见如下的信息:
在如上的的截图中,可以看到返回了HTTP状态码是403,那么如何这个过程了,在HTTP的状态码中,403 Forbidden表示对请求资源的访问被拒绝,而且服务端没有给出为什么拒绝的理由,比如我们在浏览器访问如上链接,见访问后服务端的回应:
{
"error": "Unauthorized access"
}
见General的内容:
Request URL:http://localhost:5000/hotel/username/
Request Method:GET
Status Code:403 FORBIDDEN
Remote Address:127.0.0.1:5000
见Response Headers部分的内容:
Content-Length:37
Content-Type:application/json
Date:Sun, 01 Apr 2018 14:04:36 GMT
Server:Werkzeug/0.11.13 Python/2.7.12
WWW-Authenticate:Basic realm="Authentication Required"
在如上的信息中,首部字段WWW-Authenticate用于HTTP访问认证,它会告诉客户端用于请求URI所指定资源的认证方案(Basic或者是Digest)。显示Basic,那么我们得到认证方案使用的是Basic Auth,在使用postman请求的时候需要鉴权,鉴权后再次访问,HTTP的状态码不再是403,而是200。见鉴权后的请求结果:
在请求中,headers中必须带上Authorization,要不就会再次出现403的错误。
下面实现使用python语言来处理403的错误,以及请求的时候带上鉴权,见实现的代码:
#!/usr/bin/env python
#-*-coding:utf-8-*-
import requests
r=requests.get(
url='http://localhost:5000/hotel/username/',
auth=('wuya','admin'))
print r.text
见执行如上代码后,打印的结果:
{
"datas": [
{
"check in": "2018-03-08 08:20:10",
"check out": "2018-03-09 14:00:00",
"identity card": "23012919950425723X",
"phone": "13691729932",
"room number": "1104",
"userid": 1,
"username": "\u674e\u56db",
"vpl": "\u4eacAJ3585"
}
]
}
本文暂时没有评论,来添加一个吧(●'◡'●)