简介
如果想用python做接口测试,我们首先有不得不了解和学习的模块。它就是第三方模块:Requests。 虽然Python内置的urllib模块,用于访问网络资源。但是,它用起来比较麻烦,而且,缺少很多实用的高级功能。更好的方案是使用
requests。它是一个Python第三方库,处理URL资源特别方便。查看其中文官网:Requests: 让 HTTP 服务人类 — Requests 2.18.1 文档 英文官网:http://www.python-requests.org/en/master/ 可以看一下它的很多实用的高级功能。‘’
功能特性
Requests 完全满足今日 web 的需求。
- Keep-Alive & 连接池
- 国际化域名和 URL
- 带持久 Cookie 的会话
- 浏览器式的 SSL 认证
- 自动内容解码
- 基本/摘要式的身份认证
- 优雅的 key/value Cookie
- 自动解压
- Unicode 响应体
- HTTP(S) 代理支持
- 文件分块上传
- 流下载
- 连接超时
- 分块请求
- 支持
.netrc
环境安装(安装requests)
您如果安装了Anaconda,requests就已经可用了。否则,需要在命令行下通过pip安装:
pip install requests
注意:pip很容易就会版本升级,
方法1:检测并更新
pip list –outdated
方法2:
♦先卸载:
pip uninstall packagename
♦在用:easy_install.exe安装
easy_install.exe pip
出现Installing collected packages: idna, chardet, certifi, requests
Successfully installed certifi-2019.3.9 chardet-3.0.4 idna-2.8 requests-2.21.0 说明requests模块安装成功!
使用requests(get请求无参数param)
1、将安装好的requests模块导入后,通过GET访问一个URL地址的网页页面,如:https://www/douban.com
2、这里的 r 也就是 response,请求后的返回值,可以调用 response 里的 status_code 方法查看状态码
3、状态码 200 只能说明这个接口访问的服务器地址是对的,并不能说明功能 OK,一般要查看响应的内容,r.text 是返回文本信息
看吧!这个就是requests的威力,看起来是不是很神奇很牛逼:
使用requests(get请求有参数param)
1、再发一个带参数的 get 请求,如在豆瓣网搜索:西游记,url 地址为:https://www.douban.com/search?q=西游记
2、请求参数:q=西游记,可以以字典的形式传参:{"q": "西游记"}
3、多个参数格式:{"key1": "value1", "key2": "value2", "key3": "value3"}
这部分最容易犯错的部分,就是1、豆瓣网址后没有+/search;2、params错误的写成param
使用request(get获取响应文本content)
1、豆瓣网首页如果用 r.text 会发现获取到的内容有乱码,因为豆瓣网首页响应内容是 gzip 压缩的(非 text 文本)
2、如果是在 fiddler 工具乱码,是可以点击后解码的,在代码里面可以用 r.content 这个方法,content 会自动解码 gzip 和 deflate 压缩(这个就是开始介绍requests的高级功能:自动解码和自动解压)
附录response返回的其他信息
1.response 的返回内容(content)还有其它更多信息
-- r.status_code #响应状态码
-- r.content #字节方式的响应体,会自动为你解码 gzip 和deflate 压缩
-- r.headers #以字典对象存储服务器响应头,但是这个字典比较特殊,字典键不区分大小写,若键不存在则返回 None
-- r.json() #Requests 中内置的 JSON 解码器,requests的方便之处还在于,对于特定类型的响应,例如JSON,可以直接获取
-- r.url # 获取 url
-- r.encoding # 编码格式,requests自动检测编码
-- r.cookies # 获取 cookie
-- r.raw #返回原始响应体-- r.text #字符串方式的响应体,会自动根据响应头部的字符编码进行解码
-- r.raise_for_status() #失败请求(非 200 响应)抛出异常