Python中,系统自带的urllib和urllib2都提供了功能强大的HTTP支持,但是API接口确实太难用了。Requests 作为更高一层的封装,在大部分情况下对得起它的slogan——HTTP for Humans。
让我们一起来看看 Requests 这个 HTTP库在我们接口自动化测试中的使用吧
发送请求
在使用 Requests发送网络请求非常简单,经常使用一两行代码就可以搞定。
Requests是一个第三方库,在使用它之前需要先安装这个库:
发送GET请求示例:
响应数据的获取也非常简单明了。
示例:
Requests 会自动解码来自服务器的内容。大多数 unicode 字符集都能被无缝地解码。请求发出后,Requests 会基于 HTTP 头部对响应的编码作出有根据的推测。当访问应答正文时,,Requests 会使用其推测的文本编码。你可以找出 Requests 使用了什么编码,并且能够使用 response.encoding 属性来改变它。
发送POST请求示例:
重定向、
超时和代理
Requests 之所以称为“HTTP for human”,因为其封装层次很高,其中一处体现就在:Requests会自动处理服务器响应的重定向。
注:
allow_redirects参数为False则表示不会主动重定向。
有时候对方网站的响应时间太长了,我们希望在指定时间内完事,或者直接停止这个请求。示例:
注:
timeout表示这次请求最长只等待多少秒,超过设置的时间后报错。
为了防止反爬虫之类机制,Requests 套上一层代理的做法也非常简单:
会话对象
会话对象能够跨请求保持某些参数。它也会在同一个 Session 实例发出的所有请求之间保持 cookie, 期间使用 urllib3 的 connection pooling 功能。所以如果向同一主机发送多个请求,底层的 TCP 连接将会被重用,从而带来显著的性能提升。
我们以 Django Web 应用的登录请求操作,需要前面一个GET请求中的csrf_token值为例:
后记
当然 Requests 的功能不止这么一些,我们使用 Requests 作为基于 HTTP 协议的接口自动化测试还需要学习的内容也很多,大家可以参考官方文档进行更多的学习:
https://requests.readthedocs.io/en/master/
总结:
感谢每一个认真阅读我文章的人!!!
作为一位过来人也是希望大家少走一些弯路,如果你不想再体验一次学习时找不到资料,没人解答问题,坚持几天便放弃的感受的话,在这里我给大家分享一些自动化测试的学习资源,希望能给你前进的路上带来帮助。
文章来源:https://www.toymoban.com/news/detail-716676.html
视频文档获取方式:
这份文档和视频资料,对于想从事【软件测试】的朋友来说应该是最全面最完整的备战仓库,这个仓库也陪伴我走过了最艰难的路程,希望也能帮助到你!以上均可以分享,点下方进群即可自行领取。 文章来源地址https://www.toymoban.com/news/detail-716676.html
到了这里,关于接口自动化测试之Requests模块详解的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!