若是想用python作接口测试,咱们首先有不得不了解和学习的模块。它就是第三方模块:Requests。 虽然Python内置的urllib模块,用于访问网络资源。可是,它用起来比较麻烦,并且,缺乏不少实用的高级功能。更好的方案是使用html
requests。它是一个Python第三方库,处理URL资源特别方便。查看其中文官网:cn.python-requests.org/zh_CN/lates… 英文官网:www.python-requests.org/en/master/ 能够看一下它的不少实用的高级功能。python
Requests 彻底知足今日 web 的需求。web
.netrc
您若是安装了Anaconda,requests就已经可用了。不然,须要在命令行下经过pip安装:json
pip install requests复制代码
注意:pip很容易就会版本升级,浏览器
方法1:检测并更新bash
pip list –outdated复制代码
方法2:服务器
♦先卸载:微信
pip uninstall packagename复制代码
♦在用:easy_install.exe安装cookie
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访问一个URL地址的网页页面,如:https://www/douban.com
二、这里的 r 也就是 response,请求后的返回值,能够调用 response 里的 status_code 方法查看状态码
三、状态码 200 只能说明这个接口访问的服务器地址是对的,并不能说明功能 OK,通常要查看响应的内容,r.text 是返回文本信息
看吧!这个就是requests的威力,看起来是否是很神奇很牛逼:
一、再发一个带参数的 get 请求,如在豆瓣网搜索:西游记,url 地址为:https://www.douban.com/search?q=西游记
二、请求参数:q=西游记,能够以字典的形式传参:{"q": "西游记"}
三、多个参数格式:{"key1": "value1", "key2": "value2", "key3": "value3"}
这部分最容易犯错的部分,就是一、豆瓣网址后没有+/search;二、params错误的写成param
一、豆瓣网首页若是用 r.text 会发现获取到的内容有乱码,由于豆瓣网首页响应内容是 gzip 压缩的(非 text 文本)
二、若是是在 fiddler 工具乱码,是能够点击后解码的,在代码里面能够用 r.content 这个方法,content 会自动解码 gzip 和 deflate 压缩(这个就是开始介绍requests的高级功能:自动解码和自动解压)
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 响应)抛出异常
用requests发送get请求的接口,就是这么简单!想要学的赶快行动起来,键盘敲起来,你能够用本身的博客园练习一下。
【python接口自动化交流群】:984942724
您的确定就是我进步的动力。若是你感受还不错,就请鼓励一下吧!记得点波 推荐哦!!!(点击右边的小球便可!(^__^) 嘻嘻……)
我的公众号
微信群 (微信群已满100,能够加宏哥的微信拉你进群,请备注:进群)