Python接口自动化之cookie、session应用详解

作者:软件测试自动化测试 时间:2023-02-02 11:10:35 

在上一篇Python接口自动化测试系列文章:Python接口自动化之浅析requests模块post请求,介绍了post源码,data、json参数应用场景及实战。

以下介绍cookie、session原理及在接口自动化中的应用。

HTTP 协议是一种无状态协议,即每次服务端接收到客户端的请求时,都是一个全新的请求,服务器并不知道客户端的历史请求记录;

Session 和 Cookie 的主要目的就是为了弥补 HTTP 的无状态特性。

如果我们测试的接口有依赖关系怎么办呢(比如购物支付时,需要先登录),这时我们就要用到cookie和session技术来保持客户端与服务器端连接的状态。

一、cookie

1、cookie介绍

cookie是服务器发送到用户浏览器并保存在本地的一小块数据,它会在浏览器下次向同一服务器再发起请求时被携带并发送到服务器上。通常,它用于告知服务端两个请求是否来自同一浏览器,如保持用户的登录状态。

2、cookie原理

① Cookie技术会根据从服务器端发送的响应报文内的一个叫做Set-Cookie的首部字段信息,通知客户端保存Cookie。

Python接口自动化之cookie、session应用详解

② 客户端再向服务器端发送请求的时候,客户端会在请求报文中加入Cookie值后发送出去。服务器端会检查客户端发送的请求中有没有Cookie值,然后对比服务器上的记录,最后确定是哪一个客户端,之前的信息状态是什么。

Python接口自动化之cookie、session应用详解

这样一来,服务器就能够分辨出发送请求的客户端究竟是哪一个了。

二、session

1、session介绍

session是一种在服务端记录用户信息的技术,是在无状态的HTTP协议下,服务端记录用户状态时用于标识具体用户的机制。它是在服务端保存的用来跟踪用户的状态的数据结构,可以保存在文件、数据库或者集群中。

2、session原理

Python接口自动化之cookie、session应用详解

Session是存放在服务器端、用来存放用户数据的(类似于HashTable结构)。

当浏览器第一次发送请求时,服务器自动生成了一个HashTable和一个Session ID用来唯一标识这个HashTable,并将其通过响应发送到浏览器。

当浏览器第二次发送请求,会将前一次服务器响应中的Session ID放在请求中一并发送到服务器上,服务器从请求中提取出Session ID,并和保存的所有Session ID进行对比,找到这个用户对应的HashTable,以此来达到共享数据的目的。

三、cookie和session区别

1. 存储位置不同:

Cookie是将用户数据通过加密的方式保存在客户端,大多数情况Cookie存储在浏览器;Session是用于控制客户端和服务端的连接,Session存储在服务器;

2. 存储容量不同:

单个Cookie保存的数据不得超过4kb,一个站点最多20个Cookie,Session一般情况下没有上限,不过建议不要存放太多东西,否则影响性能;

3. 存取方式不同:

Cookie只能用ASCII字符串,通过编码方式获取Unicode字符或者二进制数据,不好存储复杂的信息,而Session能存储任何类型的数据;

4. 隐私策略/安全性不同:

Cookie放在客户端,可以进行Cookie欺骗,所以不安全,Session放在服务端,更加安全;

5. 有效期不同:

Cookie可以设置属性达到长期有效,Session依赖于JSESSIONID的Cookie,Cookie JSESSIONID的过期时间默认为-1,只需要关闭窗口Session就会失效,就算不依赖Cookie,用UrL重写也不能完成,如果Session超时时间过长,容易导致内存溢出;

6. 服务器压力不同:

Cookie保存在本地,不存在服务端压力,Session保存在服务端,每个用户产生一个Session,当访问增多,会比较占用服务器的性能,如果主要考虑到减轻服务器性能方面,应当使用Cookie。

现在有登录、充值两个接口,在未登录时,直接调用充值接口。


import requests
url = 'http://127.0.0.1:8000/recharge'
payload = {
   "mobilephone":"1530272****",
   "amount":100
}
recharge_res = requests.post(url,data=payload)
print(recharge_res.json())

请求结果:提示请先登录。

{'status': 0, 'code': None, 'data': None, 'msg': '抱歉,请先登录。'}

这时候,今天的主角cookie和session闪亮登场了。

四、cookie应用


import requests
# 登录接口
url = 'http://127.0.0.1:8000/user/login'
payload = {
   "mobilephone":"1530272****",
   "pwd":"123456"
}
login_res = requests.post(url,data=payload)
print(login_res.json())
# 获取响应结果的cookies
cookies = login_res.cookies
print(cookies)
# 充值接口
url = 'http://127.0.0.1:8000/recharge'
payload = {
   "mobilephone":"1530272****",
   "amount":100
}
# 充值接口请求时携带cookies
recharge_res = requests.post(url,data=payload,cookies=cookies)
print(recharge_res.json())

五、session应用


import requests

# 登录接口
url = 'http://127.0.0.1:8000/user/login'
payload = {
   "mobilephone":"1530272****",
   "pwd":"123456"
}
# 创建session会话管理
session = requests.session()
login_res = session.post(url,data=payload)
print(login_res.json())

# 充值接口
url = 'http://127.0.0.1:8000/recharge'
payload = {
   "mobilephone":"1530272****",
   "amount":100
}
recharge_res = session.post(url,data=payload)
print(recharge_res.json())

来源:https://blog.csdn.net/ZangKang1/article/details/119042865

标签:Python,接口自动化,cookie,session
0
投稿

猜你喜欢

  • python Django编写接口并用Jmeter测试的方法

    2021-12-07 21:47:09
  • python多任务之协程的使用详解

    2023-12-29 16:38:23
  • 简介Django框架中可使用的各类缓存

    2022-01-16 13:02:39
  • 最新Python APScheduler 定时任务详解

    2021-05-03 21:58:53
  • Pycharm内置终端及远程SSH工具的使用教程图文详解

    2023-03-26 09:58:30
  • php中运用http调用的GET和POST方法示例

    2023-11-23 02:39:35
  • 如何利用Golang解析读取Mysql备份文件

    2024-01-28 20:51:19
  • 最新整理Python中的type和object的示例详解

    2023-08-10 05:21:44
  • js+xml生成级联下拉框代码

    2024-04-30 10:08:56
  • python神经网络Inception ResnetV2模型复现详解

    2023-02-28 08:51:35
  • js 兼容多浏览器的回车和鼠标焦点事件代码(IE6/7/8,firefox,chrome)

    2024-04-23 09:24:07
  • python traceback捕获并打印异常的方法

    2022-11-06 10:35:30
  • Python浪漫玫瑰盛开表白源代码

    2022-03-18 11:27:00
  • pycharm 终端部启用虚拟环境详情

    2022-04-01 17:52:59
  • Java实现基于JDBC操作mysql数据库的方法

    2024-01-27 04:54:17
  • perl 采集入库脚本分享

    2023-09-13 08:45:40
  • 如何恢复数据库的账号 登录名/用户名等

    2024-01-25 08:08:47
  • javascript常用的方法整理

    2023-08-23 10:57:13
  • JS数组遍历中for,for in,for of,map,forEach各自的使用方法与优缺点

    2024-05-02 16:15:45
  • 使用Python opencv实现视频与图片的相互转换

    2022-03-04 15:20:31
  • asp之家 网络编程 m.aspxhome.com