前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >[接口测试 - http.client篇] 14 源码初探及其工作机制分析

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

作者头像
苦叶子
发布2018-04-09 16:39:28
5330
发布2018-04-09 16:39: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工作流程及该模块下有哪些类和常量。

本文参与 腾讯云自媒体分享计划,分享自微信公众号。
原始发表:2018-02-21,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 开源优测 微信公众号,前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • http.client工作流程
  • http.client的类
  • 小结
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档