Python HTTP响应

http或超文本传输协议适用于客户端服务器模型。通常,Web浏览器是客户端,托管网站的计算机是服务器。在收到客户端的请求后,服务器会生成响应并将其以某种格式发送回客户端。

在接收并解释了请求消息后,服务器将以HTTP响应消息进行响应:

  • 状态行
  • 零个或多个标头(General | Response | Entity)字段,后跟CRLF
  • 空行(即CRLF之前没有任何内容的行)指示标题字段的末尾
  • 可选的消息正文

以下各节说明了HTTP响应消息中使用的每个实体。

1. 消息状态行

状态行由协议版本,后面的数字状态代码及其关联的文本短语组成。元素由空格SP字符分隔。

 
# Filename : example.py
# Copyright : 2020 By Codebaoku
# Author by : www.codebaoku.com
# Date : 2020-08-25
Status-Line = HTTP-Version SP Status-Code SP Reason-Phrase CRLF

2. HTTP版本

支持HTTP版本1.1的服务器将返回以下版本信息:

 
# Filename : example.py
# Copyright : 2020 By Codebaoku
# Author by : www.codebaoku.com
# Date : 2020-08-25
HTTP-Version = HTTP/1.1

3. 状态码

Status-Code元素是一个三位数的整数,其中Status-Code的第一位定义响应的类别,最后两位不具有任何分类作用。第一位数字有5个值:

编号 状态码 描述
1 1xx 信息性:表示已收到请求,并且该过程正在继续。
2 2xx 成功:表示已成功接收,理解并接受了该动作。
3 3xx 重定向:表示必须采取进一步的措施才能完成请求。
4 4xx 客户端错误:请求包含不正确的语法或无法实现。
5 5xx 服务器端错误:服务器无法满足有效的请求。

HTTP状态代码是可扩展的,不需要HTTP应用程序来了解所有已注册状态代码的含义。

4. 使用Python请求

在下面的python程序中,使用urllib3模块发出http GET请求并接收包含数据的响应。它还提供了响应代码,该响应代码也由模块中的功能管理。PoolManager对象处理连接池的所有详细信息,还处理线程安全性。

 
# Filename : example.py
# Copyright : 2020 By Codebaoku
# Author by : www.codebaoku.com
# Date : 2020-08-25
import urllib3
http = urllib3.PoolManager()
resp = http.request('GET', 'http://codebaoku.com/robots.txt')
print resp.data
# get the status of the response
print resp.status

当我们运行上面的程序时,得到类似以下输出 :

 
# Filename : example.py
# Copyright : 2020 By Codebaoku
# Author by : www.codebaoku.com
# Date : 2020-08-25
User-agent: *
Disallow: /tmp
Disallow: /logs
Disallow: /rate/*
Disallow: /cgi-bin/*
Disallow: /video/video_course_view.php?*
Disallow: /video/course_view.php?*
Disallow: /videos/*
Disallow: /*/*_question_bank/*
Disallow: //*/*/*/*/src/*
200

客户端和服务器之间的请求和响应涉及消息中的标头和正文。标头包含特定于协议的信息,这些信息出现在通过TCP连接发送的原始消息的开头。消息的正文与标头使用空白行分隔。标头字段http响应中的标头可以分为以下类型。以下 ...