查看原文
其他

[接口测试 - http.client篇] 14 源码初探及其工作机制分析

2017-08-28 苦叶子 开源优测

点击上方蓝字“开源优测”一起玩耍

概述

http.client模块定义和实现了一系列类用于实现客户端HTTP和HTTPS协议。

一句话说明: HTTP/1.1 client library

注:

  1. 支持HTTP/1.1版本的协议

  2. HTTPS的支持需要安装SSL才行

http.client工作流程

下面我们看一下http.client工作流程机制,以便加深在原理的理解。

(null)    |    | HTTPConnection() 建立HTTP链接    v Idle    |    | putrequest() 准备请求内容    v Request-started    |    | ( putheader() )*  endheaders() 准备请求头    v Request-sent 发送请求    |\_____________________________    |                              | getresponse() raises 获取服务端响应    | response = getresponse()     | ConnectionError    v                              v Unread-response                Idle [Response-headers-read] 响应头读取    |\____________________    |                     |    | response.read()     | putrequest() 自己往下看吧    v                     v Idle                  Req-started-unread-response                    ______/|                /        | response.read() |        | ( putheader() )*  endheaders()                v        v    Request-started    Req-sent-unread-response                        |                        | response.read()                        v                        Request-sent

说明:

  1. HTTPConnection通过不同的“状态”定义了HTTP客户的行为状态,管理维护着每一个的request和response

  2. 上述的流程图,详细的说明了各“状态”之间的转换,把上图理解,即把http.client理解透彻了。

http.client的类

下面我们看一下在http.client模块中,定义了哪些类

  • HTTPConnection
    一个HTTPConnection实例代表一个与HTTP服务器的事务。

  • HTTPSConnection HTTPConnection的子类,它使用SSL与安全的服务器进行通信。

  • HTTPResponse HTTPResponse的实例代表客户端与服务端成功建立链接后的返回。

  • HTTPException httpc.client模块中的异常基类,其为Exception的子类。

以下均为HTTPException的子类,属于异常类,具体含义这里不一一说明了,大家根据字面意思了解即可

  • NotConnected

  • InvalidURL

  • UnknownProtocol

  • UnknownTransferEncoding

  • UnimplementedFileMode

  • IncompleteRead

  • ImproperConnectionState

  • CannotSendRequest

  • CannotSendHeader

  • ResponseNotReady

  • BadStatusLine

  • LineTooLong

  • RemoteDisconnected


定义的几个常量:

  • http.client.HTTP_PORT HTTP默认端口(80)。

  • http.client.HTTPS_PORT https默认端口(443)。

  • http.client.responses HTTP 1.1状态码映射字典。

例如:

http.client.responses[http.client.NOT_FOUND] is 'Not Found'

注:更多的状态码请参加https://docs.python.org/3/library/http.html#http-status-codes

小结

主要让大家了解下http.client工作流程及该模块下有哪些类和常量。


开源优测

分享软件测试开源技术、经验、方案的首发平台

长按二维码/微信扫描 关注开源优测

QQ群:260407012

苦叶子私人微信:liyimin1912

有问题,可留言或加好友进微信群

苦叶子原创文章首发平台


您可能也对以下帖子感兴趣

文章有问题?点此查看未经处理的缓存