Python + request接口测试中Cookie和Session的获取和使用
Cookie和Session的简单理解
由于Http协议是无状态的,所以产生了cookie和session进行状态的管理。
从哪里来,在哪里,到哪里去:
--> Cookie是由服务端生成,存储在响应头中,返回给客户端,客户端会将cookie存储下来。
--> Session是由服务端生成,存储在服务端的内存、缓存、数据库等地方。
--> 在客户端发送请求时,user-agent会自动获取本地存储的cookie,将cookie信息存储在
请求头中,发送给服务端。
--> 请求都是由客户端发起的,当服务端生成了session,客户端如何获取:
1)在客户端发送请求给服务端后,服务端会根据请求信息生成session,同时生成一个
session_id,通过cookie返回给客户端。
2)客户端再次向服务端发送请求时,会通过cookie将这个session_id发送给服务端,
这样相当于带上了session的标示。
--> cookie可以作为管理session的一种方式,当cookie被禁用时,可以通过表单或重写
url传送session_id。
requests实现cookie操作
--> cookie包含在响应中,要获取响应中的cookie信息,可以用r.cookies.get_dict()获取响应
的cookie信息,并传递给后续请求。
--> 找一个不会被进行验证的网站进行练习,从输出信息中,可以看到,第2个请求使用了第一
个请求响应头中的cookies信息,保持了连接

--> 在已知cookie信息时,需要构造成对应的cookie对象传递给请求时,可以采用Cookie的返回
对象为RequestsCookieJar或者字典构造。
--> RequestsCookieJar构造cookie是已知登录响应返回的cookies信息,通过创建对象,设置对
应的值进行构造传递。

--> 采用字典构造cookies信息,将构造方式更改为:
cookies = dict(zentaosid='5qm86pvshjm3s8u729cmc0mb15')
会话对象session
会话对象让你能够跨请求保持某些参数。它也会在同一个Session实例发出的所有请求之间保持
cookie。所以如果你向同一主机发送多个请求,底层的TCP连接将会被重用,从而带来显著的
性能提升。
--> session会自动管理cookie,一个session对象会保持同一个会话中的所有请求之间的cookie
信息。

总结:
--> 会话对象session比cookie更方便管理请求的cookie信息
--> 服务器返回的cookie信息通常在响应头中
--> 如果需要将响应体中的部分信息传递给后续的请求的cookie,可以构造cookie信息并传递
Python + request接口测试中Cookie和Session的获取和使用的更多相关文章
- flask中cookie和session介绍
flask中cookie和session介绍 一.cookie: 在网站中,http请求是无状态的.也就是说即使第一次和服务器连接后并且登录成功后,第二次请求服务器依然不能知道当前请求是哪个用户.co ...
- 浅谈JS中的!=、== 、!==、===的用法和区别 JS中Null与Undefined的区别 读取XML文件 获取路径的方式 C#中Cookie,Session,Application的用法与区别? c#反射 抽象工厂
浅谈JS中的!=.== .!==.===的用法和区别 var num = 1; var str = '1'; var test = 1; test == num //tr ...
- thinkphp中cookie和session中操作数组的方法
thinkphp中cookie和session中操作数组的方法 一.ThinkPHP模板中如何操作session,以及如果session中保存的是数组的情况 在ThinkPHP的模板中操作sessio ...
- python request接口测试笔记(1)
python request接口测试笔记(1) 涉及到的功能说明: 需要登录拿到token,才能进行下一个接口的请求 读取csv文件中的信息,作为接口的参数 将接口响应结果,写入csv文件,以便分析统 ...
- flask中cookie和session设置
flask中cookie和session介绍 一.cookie: 在网站中,http请求是无状态的.也就是说即使第一次和服务器连接后并且登录成功后,第二次请求服务器依然不能知道当前请求是哪个用户. ...
- PHP中Cookie与Session的异同以及使用
Cookie与Session的异同: 一.cookie机制 Cookies是服务器在本地机器上存储的小段文本并随每一个请求发送至同一个服务器.IETF RFC 2965 HTTP State Mana ...
- Django中cookie和session的操作
一.cookie和session cookie:在网站中,http请求是无状态的.也就是说即使第一次和服务器连接后并且登录成功后,第二次请求服务器依然不能知道当前请求是哪个用户.cookie的出现就是 ...
- 【Python】Flask系列-cookie和session笔记
cookie: 1.cookie出现的原因:在网站中,http请求是无状态的.也就是说即使第一次和服务器连接后并且登录成功后,第二次请求服务器依然不能知道当前请求是哪个用户.cookie的出现就是为了 ...
- Django中cookie和session
cookie Cookie的由来 大家都知道HTTP协议是无状态的. 无状态的意思是每次请求都是独立的,它的执行情况和结果与前面的请求和之后的请求都无直接关系,它不会受前面的请求响应情况直接影响,也不 ...
随机推荐
- Looksery Cup 2015 C. The Game Of Parity —— 博弈
题目链接:http://codeforces.com/problemset/problem/549/C C. The Game Of Parity time limit per test 1 seco ...
- js正则表达式,密码长度要大于6位,由数字和字母组成
var pwd = $("#pwd").val(); var reg = /^(?![0-9]+$)(?![a-zA-Z]+$)[0-9A-Za-z]{6,}$/; if(!reg ...
- nginx ,node 配置项目
nginx ,node 配置项目 1.安装好node,npm 2.安装cnpm,-g是全局的 sudo npm install -g cnpm --registry=https://registry. ...
- zoj 2316 Matrix Multiplication 解题报告
题目链接:http://acm.zju.edu.cn/onlinejudge/showProblem.do?problemCode=2316 题目意思:有 N 个 点,M 条 边.需要构造一个N * ...
- hdu-5749 Colmerauer(单调栈)
题目链接: Colmerauer Time Limit: 10000/5000 MS (Java/Others) Memory Limit: 131072/131072 K (Java/Oth ...
- [转载] Android raw与assets区别
*res/raw和assets的相同点: 1.两者目录下的文件在打包后会原封不动的保存在apk包中,不会被编译成二进制. *res/raw和assets的不同点:1.res/raw中的文件会被映射到R ...
- SPOJ:D-query(非常规主席树求区间不同数的个数)
Given a sequence of n numbers a1, a2, ..., an and a number of d-queries. A d-query is a pair (i, j) ...
- HDU3157 Crazy Circuits
传送门 有源汇的上下界网络流求最小流. 这个其实和上道题差不多--题目描述我没怎么看明白--好像就是让你按照他说的把图建出来就行了,注意这个题的字符处理,可能有长度大于1的字符串,要注意一下.求最小流 ...
- 开发板启动时,内核打印出"can't access tty,job control turned off"
启动后的最后一行提示can't access tty,job control turned off, 这说明没有进入到控制台,原因就在于文件系统的/etc/inittab 这个文件里有问题 vi /e ...
- QC使用常见问题
1.如果出现/qcbin/setup_a.cab this file didn’t pass singnature checking. 请下载capicom.dll文件拷贝到c:windowssyst ...