美文网首页Python接口测试
python接口请求之requests详解

python接口请求之requests详解

作者: 小啊小狼 | 来源:发表于2020-12-24 14:37 被阅读0次

    一、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)
    

    相关文章

      网友评论

        本文标题:python接口请求之requests详解

        本文链接:https://www.haomeiwen.com/subject/xmfunktx.html