python+requests实现接口测试 - get与post请求使用

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

一、安装

使pip安装:

pip install requests

安装完后,运行一个简单的例子查看是否安装成功:

import requests                                 #导入requests包
r=requests.get(url=‘https://www.baidu.com/‘)
print(r.status_code)                            #查看请求返回的状态
#结果
200

  

二、几种请求类型

  ①get请求:requests.get(‘url‘)

  ②post请求:requests.post("url/post")

  ③put请求:requests.put("url/put")

  ④delete请求:requests.delete("url/delete")

  ⑤head请求:requests.head("url/get")

  ⑥options请求:requests.options("url/get")

三、get请求

传递url参数

在get请求中,允许使用params关键字,以一个字典来传递这些参数,例如:

content={‘pageIndex‘:1,‘pageSize‘:10,‘categoryId‘:9}
r=requests.get(‘http://www.xxxxx.com/api/v2/activities‘,params=content)
print (r.url)                       #获取请求内容
print (r.text)                      #获取响应内容
#结果
http://www.xxxx.com/api/v2/activities?pageIndex=1&pageSize=10&categoryId=9
{"data":[],"pageIndex":1,"totalNum":0,"hasMore":false,"pageSize":0}

如果字典中存在None的值,是不会添加到url请求中的

content={‘pageIndex‘:1,‘pageSize‘:10,‘categoryId‘:None}
r=requests.get(‘http://www.xxxxx.com/api/v2/activities‘,params=content)
print (r.url)                      

#结果
http://www.xxxx.com/api/v2/activities?pageIndex=1&pageSize=10

  

ps:不使用params的话,也可在请求中输入全部的地址,效果相同,如:

r=requests.get(‘http://m.xxxxx.com/api/v2/activities?pageIndex=1&pageSize=10&categoryId=9‘)

注意:在某些get请求中,需要辨别用户身份,因此会需要在请求中发送cookie内容,如某些需要用户登录才能访问的页面,在接下来的文章中会进行讲解 

四、post请求

1.以表单形式传递参数:

想要发送一些表单形式的数据,只需简单的传递一个字典给data关键字,在发送请求的时候,会自动编码为表单的形式,例如:

content={‘key1‘:‘value1‘,‘key2‘:‘value2‘}
r=requests.post(‘http://www.xxx/api/v1/user/login‘,data=content)

2.以json形式传递参数:

在很多情况下,想要发送的数据并非为表单形式,而是一个json格式的字符串,如果传递给data关键字的内容不是一个dict,而是

一个string,那么在发送的时候,数据会被直接发送出去,不会自动编码为表单形式。

为了将一个数据结构转换为json格式的字符串,首先得需要导入一个json包,两种常用的方法为:json.dumps()与json.loads()

import json
content={‘name‘:‘Nee‘,‘age‘:‘18‘}
str_content=json.dumps(content)      #把dick编码为json格式的字符串
print (str_content)
print (type(str_content))
#结果:
{"name": "Nee", "age": "18"}
<class ‘str‘>                        #此时的类型为str

content=json.loads(str_content)      #把json格式的字符串解码为原先的数据结构
print (content)
print (type(content))
#结果
{‘name‘: ‘Nee‘, ‘age‘: ‘18‘}
<class ‘dict‘>

注意:1.json编码支持的基本类型有:None, bool, int, float, string, list, tuple, dict。对于字典,json会假设key是字符串(字典中的任何非字符串key都会在编            码时转换为字符串),要符合JSON规范,应该只对python列表和字典进行编码。此外,在WEB应用中,把最顶层对象定义为字典是一种标准做法。                    2.json编码的格式几乎和python语法一致,略有不同的是:True会被映射为true,False会被映射为false,None会被映射为null,元组()会被映射为列表[],如:

content={‘a‘:None,‘b‘:True,‘c‘:False,‘d‘:(1,2)}
str_content=json.dumps(content)
print (str_content)

#结果:
{"a": null, "b": true, "c": false, "d": [1, 2]}

因此 想要在post请求中使用data关键字来传递json格式的字符窜,首先得把dict转为string,例如:

import requests
import json
url=‘http://www.xxx.com/api/v1/user/login‘
data={"ua":"13700002000","pw":"12qwaszx","ct":12}
r=requests.post(url,data=json.dumps(data))         #在一些post请求中,还需要用到headers部分,此处未加,在下文中会说到
print (r.text)

#结果
{"newUser":false,"user":{"userId":531,"mobileNo":"13700002000","userName":"测试用户2000".......}

除了可以对dick编码后以string的方式传递参数外,还可以直接使用json关键字直接传递,在传递时会自行进行编码为string类型

import requests            #不需要导入json模块
url=‘http://xxxx/api/v1/user/login‘
data={"ua":"13700002000","pw":"12qwaszx","ct":12}
r=requests.post(url,json=data)

在post请求中用到的head部分和cookie部分。在之后的文章中会进行讲解

五、响应

1.响应状态

在请求发送成功后,可以用status_code来查看相应状态(每个状态代表的具体意义不在此文介绍)

import requests
r=requests.get(url)
print(r.status_code)

-----结果-----
200

2.响应内容

在上面的内容中,已经展示了用text来获取相应的内容,返回的内容为string

import requests
r=requests.get(url)
print (r.text)
print (type(r.text))       #查看返回内容的类型

-----结果-----
..........                 #返回的具体内容
<class ‘str‘>              #类型为string 

除此之外,requests中也带有带有一个内置的json解码器,将返回的内容转换为dict

import requests
r.requests.get(url)
print (r.json())
print (type(r.json()))

-----结果-----
......
<class ‘dict‘>

那么通过json解码器转为dict后,想要查看到返回内容中某个具体参数的值,就比较方便啦!

3.响应内容编码格式

在获取响应内容的时候,可以使用r.encoding来查看相应内容的编码格式

import requests
r=requests.get(url)
print(r.encoding)

-----结果-----
UTF-8

也可以进行指定编码,当改变了编码方式是后,每次获取响应内容,都会使用新的编码方式

import requests
r=requests.get(url)
r.encoding=‘ISO-8859-1‘
print(r.text)

4.响应头内容

import requests
r=requests.get(url)
print (r.headers)

5.cookies

import requests
r=requests.get(url)
print (r.cookies)

  

p.p1 { margin: 0.0px 0.0px 0.0px 0.0px; font: 11.0px Menlo; color: #ffffff; background-color: #000000 }
span.s1 { }

时间: 2024-12-04 23:22:16

python+requests实现接口测试 - get与post请求使用的相关文章

python+requests——不带参数的get请求

import requests url = "http://www.baidu.com" #请求网址 yctime = 0.05 #不能超过的时间 resp = requests.get(url,timeout=yctime) print("#-----------------------------------------------------------------------------------------------1") print(type(res

python+requests——发送带参数的get请求

Requests 允许你使用 params 关键字参数,以一个字符串字典来提供这些参数. 举例来说,如果你想传递 key1=value1 和 key2=value2 到 httpbin.org/get ,那么你可以使用如下代码: payload = {'key1': 'value1', 'key2': 'value2'} resp = requests.get("http://httpbin.org/get", params=payload,timeout=0.5) 原文地址:http

Python+Requests接口测试教程(1):Fiddler抓包工具

本书涵盖内容:fiddler.http协议.json.requests+unittest+报告.bs4.数据相关(mysql/oracle/logging)等内容.刚买须知:本书是针对零基础入门接口测试和python+requests自动化的,首先本书确实写的比较基础,对基础内容也写的很详细,所以大神绕道. 为什么要先学fiddler? 学习接口测试必学http协议,如果直接先讲协议,我估计小伙伴们更懵,为了更好的理解协议,先从抓包开始.结合抓包工具讲http协议更容易学一些. 1.1 抓fir

基于Python Requests的数据驱动的HTTP接口测试

发表于:2017-8-30 11:56  作者:顾翔   来源:51Testing软件测试网原创 http://www.51testing.com/html/69/n-3720769-2.html 1.测试金字塔 图 1软件测试金字塔 图 1是Main Cohn提出的软件测试金字塔,他认为作为一个测试工程师应该把大量的工作花在单元测试和接口测试,而其余的发在UI测试以及探索式测试.纵然,单元测试的优点很突出,它接近于代码本身,运行速度快,开发可以一边写产品代码一边写单元测试代码,一旦在单元测试中

让http服务人类(python之requests做接口测试)

让http服务人类 最优雅的http请求库(python的http请求库有很多,比如urllib2,urllib3,httplib). requests库简介 requests库是基于urllib3库封装的第三方http请求库,在python中requests应用最广泛的应该属网络爬虫方面,对于测试来说,我们对于requests的应用主要是接口测试方面. 实例(1)创建一个请求: httpbin:这个网站专门是为了给http做测试用的. import requests #导入requests模块

大概看了一天python request源码。写下python requests库发送 get,post请求大概过程。

python requests库发送请求时,比如get请求,大概过程. 一.发起get请求过程:调用requests.get(url,**kwargs)-->request('get', url, **kwargs)-->session.request(method="get", url=url, **kwargs)-->session.send(request, **kwargs)-->adapter.send(request, **kwargs)-->

python爬虫 - python requests网络请求简洁之道

http://blog.csdn.net/pipisorry/article/details/48086195 requests简介 requests是python的一个HTTP客户端库,跟urllib,urllib2类似,但是python的标准库urllib2提供了大部分需要的HTTP功能,但是API太逆天了,一个简单的功能就需要一大堆代码. Requests 使用的是 urllib3,因此继承了它的所有特性.Requests 支持 HTTP 连接保持和连接池,支持使用 cookie 保持会话

python+requests——发送post请求——各种情况

requests库是 python3 中非常优秀的第三方库,它使用 Apache2 Licensed 许可证的 HTTP 库,用 Python 编写,真正的为人类着想. requests 使用的是 urllib3(python3.x中的urllib),因此继承了它的所有特性. Requests 会自动实现持久连接keep-alive,Requests 支持 HTTP 连接保持和连接池,支持使用 cookie 保持会话,支持文件上传, 支持自动确定响应内容的编码,支持国际化的 URL 和 POST

python 爬虫 基于requests模块发起ajax的get请求

基于requests模块发起ajax的get请求 需求:爬取豆瓣电影分类排行榜 https://movie.douban.com/中的电影详情数据 用抓包工具捉取 使用ajax加载页面的请求 鼠标往下下滚轮拖动页面,会加载更多的电影信息,这个局部刷新是当前页面发起的ajax请求, 用抓包工具捉取页面刷新的ajax的get请求,捉取滚轮在最底部时候发起的请求 这个get请求是本次发起的请求的url ajax的get请求携带参数 获取响应内容不再是页面数据,是json字符串,是通过异步请求获取的电影