python接口请求之requests详解

一、requests

1.1、简介

Requests 是用 Python 语言编写, 基于 urllib,采用 Apache2 Licensed 开源协议的 HTTP 库。 它比 urllib 更加方便,可以节约我们大量的工作,完全满足 HTTP 测试需求。 Requests 的是以 PEP 20 的习语为中心开发的, 所以它比 urllib 更加 Python 智能化。 更重要的一点是它支持 Python3

1.2、Requests 安装

1、python(选择 3.7 或者 3.6 版本)
2、安装方式:

  • cmd 下 输入 pip install requests
  • pycharm安装


    image.png

    点击+按钮,进入添加界面


    image.png

1.3、Requests常用参数

method: 请求方式 get,或者 post,put,delete 等
url 请求的: url 地址 接口文档标注的接口请求地址
params:请求数据中的链接,常见的一个 get 请求,请求参数都是在 url 地址中
data :请求数据,参数 表单的数据格式
json: 接口常见的数据请求格式
headers:请求头信息,http 请求中,比如说编码方式等内容添加
cookie:保存的用户登录信息,比如做一些充值功能,但是需要用户已经登录,需要 cookie 信息的请求信息传输
file:接口中上传文件
timeout :超时处理 proxys 设置代理
stream :文件下载功能,通过请求方式,下载文件

1.4、Requests响应内容

r.encoding #获取当前的编码
r.encoding = 'utf-8' #设置编码
r.text #以encoding解析返回内容。字符串方式的响应体,会自动根据响应头部的字符编码进行解码。
r.cookies #返回cookie
r.headers #以字典对象存储服务器响应头,但是这个字典比较特殊,字典键不区分大小写,若键不存在则返回None
r.status_code #响应状态码
r.json() #Requests中内置的JSON解码器,以json形式返回,前提返回的内容确保是json格式的,不然解析出错会抛异常
r.content #以字节形式(二进制)返回。字节方式的响应体,会自动为你解码 gzip 和 deflate 压缩。

二、requests使用

2.1、Requests 中 get 请求

1、把参数添加到 url 链接中

接口与参数之间用?链接,参数用key=value的形式表示,多个参数用&符号链接

import requests
url='http://tcc.taobao.com/cc/json/mobile_tel_segment.htm?tel=13163750276'
r = requests.get(url=url)
print (r.text)

#返回数据
__GetZoneResult_ = {
    mts:'1316375',
    province:'广东',
    catName:'中国联通',
    telString:'13163750276',
    areaVid:'30517',
    ispVid:'137815084',
    carrier:'广东联通'
}
2、把参数添加到params中
import requests
url='http://tcc.taobao.com/cc/json/mobile_tel_segment.htm'
params={'tel':'13163750276'}
r = requests.get(url=url,params=params)
print (r.text) #打印接口请求返回的值

与第一种效果相同

2.2、Requests 中 post 请求

主要讲 2 种请求数据格式,data 与 json

2.2.1、From-data 数据格式的接口

注册接口,
数据格式是 data 格式
url 地址:http://127.0.0.1:8000/register
请求方式:post
请求 请求参数:username password

import requests 
url="http://127.0.0.1:8000/register" 
#表单数据格式,参数 data ,数据都是字典去保存 
data={"username":"liang001", "password":"123456" }
r_reg=requests.post(url=url,data=data) 
print (r_reg.text)
2.2.2、json 数据格式的接口

登录接口,数据格式是 json 格式
url 地址:http://127.0.0.1:8000/login
请求方式:post 请求
请求参数:username,password

import requests 
url="http://127.0.0.1:8000/login" 
#表单数据格式,参数 data ,数据都是字典去保存 
data={"username":"liang001", "password":"123456" }
r_login=requests.post(url=url,json=data) 
print (r_login.text)

如果要用参数data传参的话,在请求头要声明参数格式

import requests 
import json
url="http://127.0.0.1:8000/login" 
header={'content-type':'application/json'}
data={"username":"liang001", "password":"123456" }
r_login=requests.post(url=url,data=json.dumps(data)) 
print (r_login.text)

2.3、Requests 中 的定制头和cookie信息

在HTTP应用中Cookies和Header处理是非常普遍的事情,一般情况下用于记录用户的持久化信息和验证等功能,在运用requests库进行接口请求时,我们往往也会遇到需要带上请求头或者cookie的情况。

header = {'user-agent': 'my-app/0.0.1''}
cookie = {'key':'value'}
r = requests.get/post('your url',headers=header,cookies=cookie) 
data = {'some': 'data'}
headers = {'content-type': 'application/json',
           'User-Agent': 'Mozilla/5.0 (X11; Ubuntu; Linux x86_64; rv:22.0) Gecko/20100101 Firefox/22.0'}
 
r = requests.post('https://api.github.com/some/endpoint', data=data, headers=headers)
print(r.text)

2.4 Requests 之 https 请求处理

当协议是 https 的协议的时候,有些系统,需要校验 https 证书,如果校验失败,可能会有警告提示等信息

import requests 
url="https://www.ctrip.com/" 
#解决方案 # 发送请求时候忽略证书,证书的参数 verify-用的比较多 r=requests.get(url=url,verify=False) #verify 参数默认为 True,值为 False 表示忽略证书 
print (r.text) 
#第二种解决方案,verify 里面添加证书的路径 
r=requests.get(url=url,verify='证书的路径') 
print (r.text)

2.5 Requests 之文件上传接口

当需要到上传文件接口时候,我们需要 files 参数处理

import requests

url = 'https://127.0.0.1:8000/UploadPhoto'  
#filename 为 liang.jpg 文件
#open('D:\\test_data\\liang.jpg','rb') 打开本地的一个文件 
files = {'file':open('D:\\test_data\\liang.jpg','rb')}
r=requests.post(url=url,files=files,verify=False) 
print (r.text)

2.6、Requests之文件下载

一次性下载
import requests

url = 'http://www.xxxx/demo.zip'
r = requests.get(url)
with open("filename.zip", "wb") as code:
    code.write(r.content)
大文件下载:

如果文件比较大的话,那么下载下来的文件先放在内存中,内存还是比较有压力的。所以为了防止内存不够用的现象出现,我们要想办法把下载的文件分块写到磁盘中,需要用到request的参数stream

import requests
url = 'http://www.xxxx/demo.zip'
r = requests.get(url, stream=True)  ##stream-true,限制文件的大小
with open("filename.zip", "wb") as code:
    for chunk in r.iter_content(chunk_size=1024):#iter_content 循环去读取信息写入,chunk_size 文件大 小
        if chunk:
            code.write(chunk) #把循环读取的值,写入 文件里面

2.7、Requests 中 timeout 参数

1、python 的requests请求都可以使用timeout参数。
2、timeout参数可以传入一个简单的浮点数,它将请求的连接部分和读取部分设为相同的超时时间。
3、timeout参数也可以传入一个包含两个简单浮点数的元组,用来分别设置请求超时时间和读取超时时间。
4、参数值设为None或者不设置该参数为一直等待,知道请求成功或错误

url = "http://127.0.0.1:8000/login"
# 表单数据格式,参数 data ,数据都是字典去保存
data = {"username": "liang001", "password": "123456"}
r_login = requests.post(url=url, json=data, timeout=0.5)
print(r_login.text)

推荐阅读更多精彩内容