浅谈配置元件之HTTP Cookie管理器

news2024/12/21 19:53:12

浅谈配置元件之HTTP Cookie管理器

在进行Web测试时,处理Cookies是非常关键的一环,因为Cookies常用于存储用户会话信息、登录状态等。JMeter中的“HTTP Cookie管理器”(HTTP Cookie Manager)正是为此设计的配置元件,它能自动处理HTTP请求中的Cookie,模拟浏览器的行为,使得测试更加真实和准确。

1. 为什么需要HTTP Cookie管理器

● 维护会话状态:许多Web应用依赖于Cookie来维持用户的会话状态。不处理Cookie可能导致登录后无法访问受保护的页面。
● 自动化处理:手动管理每个请求的Cookie非常繁琐且易出错。HTTP Cookie管理器自动发送、接收并存储Cookie,简化测试脚本编写。
● 真实模拟:模拟浏览器的Cookie处理方式,使测试结果更贴近实际用户操作场景。

2. 添加HTTP Cookie管理器

  1. 打开JMeter,创建或打开一个测试计划(Test Plan)。
  2. 右键点击测试计划下的任意一个合适的层级(如线程组Thread Group),选择“添加”(Add)> “配置元件”(Config Element)> “HTTP Cookie管理器”(HTTP Cookie Manager)。

3. 配置HTTP Cookie管理器

基本设置
● Cookie 策略(Policy):选择Cookie的处理策略。默认为“standard”,适用于大多数情况。其他选项如“compatibility”用于兼容旧版浏览器的Cookie策略。
● 每次反复清楚Cookies(Clear cookies each iteration):如果勾选,每次迭代开始前都会清除所有已存储的Cookie,适用于需要模拟新会话的场景。
● 存储在Cookie管理器中的Cookie:运行待上自己需要的Cookie。

4. 使用示例

首先我们使用SpringBoot框架编写两个测试接口

import com.alibaba.fastjson.JSONObject;
import io.swagger.annotations.ApiImplicitParams;
import io.swagger.annotations.ApiOperation;
import org.springframework.web.bind.annotation.*;

import javax.servlet.http.Cookie;
import javax.servlet.http.HttpServletResponse;

@RestController
public class Welcome {

    @GetMapping(value = "/welcome")
    public String welcome(){
        return "Hello World";
    }

    @GetMapping(value = "/cookie")
    public String getCookieValue(@CookieValue(name = "my-cookie", required = false) String cookieValue, HttpServletResponse response) {
        // 检查cookie是否存在
        if (cookieValue != null) {
            return "上次请求中的cookie值: " + cookieValue;
        } else {
            // 设置一个新的cookie
            String newCookieValue = "setnewcookie";
            Cookie cookie = new Cookie("my-cookie", newCookieValue);
            cookie.setMaxAge(24 * 60 * 60); // 设置cookie的过期时间为24小时
            response.addCookie(cookie);
            return "未找到先前的cookie。\n已设置新cookie值: " + newCookieValue;
        }
    }
}

我们编写这么一个JMeter脚本
在这里插入图片描述
线程组:保持默认
HTTP Cookie管理器:设置默认
获取Cookie(http取样器):
● 协议:http
● 服务器名称或IP:127.0.0.1
● 端口:8091(根据实际情况编写)
● 方法:GET
● 路径:/cookie
● 内容编码:utf-8
调用欢迎接口(http取样器):
● 协议:http
● 服务器名称或IP:127.0.0.1
● 端口:8091(根据实际情况编写)
● 方法:GET
● 路径:/welcome
● 内容编码:utf-8

情况1:勾选每次反复清除Cookies

该种情况下,设置线程组循环次数为2,运行JMeter脚本,通过查看结果树可以看到如下内容:
第一次获取cookie接口获取的响应数据Response Body内容为:

未找到先前的cookie。
已设置新cookie值: setnewcookie

第二次获取cookie接口请求Request Body内容为:

GET http://127.0.0.1:8091/cookie
GET data:
[no cookies]

获取的响应数据Response Body内容为:

未找到先前的cookie。
已设置新cookie值: setnewcookie

查看两次响应数据的Response headers都能够看到如下内容

Set-Cookie: my-cookie=setnewcookie; Max-Age=86400; Expires=Tue, 18-Jun-2024 11:54:24 GMT

情况2:不勾选每次反复清除Cookies

第一次获取cookie接口获取的响应数据Response Body内容为:

未找到先前的cookie。
已设置新cookie值: setnewcookie

第二次获取cookie接口请求Request Body内容为:

GET http://127.0.0.1:8091/cookie
GET data:
Cookie Data:
my-cookie=setnewcookie

获取的响应数据Response Body内容为:

上次请求中的cookie值: setnewcookie

情况3:不勾选每次反复清除Cookies,存储在Cookie管理中的Cookie填写内容

参数如下:
● 名称:my-cookie
● 值:112345678
● 域:127.0.0.1
● 路径:/
第一次获取cookie接口获取的请求Request Body内容为:

GET http://127.0.0.1:8091/cookie
GET data:
Cookie Data:
my-cookie=12345678

第一次获取cookie接口获取的响应数据Response Body内容为:

上次请求中的cookie值: 12345678

第二次获取cookie接口请求Request Body内容为:

GET http://127.0.0.1:8091/cookie
GET data:
Cookie Data:
my-cookie=12345678

获取的响应数据Response Body内容为:

上次请求中的cookie值: 12345678

情况4:Cookie策略:ignoreCookies,其它默认

第一次获取cookie接口获取的请求Request Body内容为:

GET http://127.0.0.1:8091/cookie
GET data:
[no cookies]

第二次获取cookie接口获取的请求Request Body内容为:

GET http://127.0.0.1:8091/cookie
GET data:
[no cookies]

5. 注意事项

● 安全与隐私:JMeter会明文存储Cookie信息,注意保护敏感数据。
● 性能影响:大量或复杂的Cookie管理可能会对测试性能造成一定影响,尤其是在高并发测试场景下。
● 测试设计:合理配置Cookie管理器,避免不必要的清除操作,以更准确地模拟用户行为。

6.结语

HTTP Cookie管理器是JMeter中不可或缺的配置元件,对于准确模拟Web应用的用户交互至关重要。通过合理配置,可以显著提升测试脚本的真实性和测试效率。掌握其使用方法,是进行高效Web性能测试的关键一步。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1843988.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

后端学习笔记:Python基础

后端学习笔记:Python基础 数据类型: Python中主要有以下几种常用的基本数据类型: String 字符串类型,用单引号或者双引号引用Number 数字类型,包括浮点数,整数,长整数和复数List 列表项&…

24年计算机等级考试22个常见问题解答❗

24年9月计算机等级考试即将开始,整理了报名中容易遇到的22个问题,大家对照入座,避免遇到了不知道怎么办? 1、报名条件 2、报名入口 3、考生报名之后后悔了,不想考了,能否退费? 4、最多能够报多少…

【MySQL】(基础篇十五) —— 增删改数据

增删改数据 本文介绍如何利用SQL的INSERT语句将数据插入表中。以及如何利用UPDATE和DELETE语句进一步操纵表数据。 数据插入 INSERT是用来插入(或添加)行到数据库表的。插入可以用几种方式使用 插入完整的行;插入行的一部分;插…

目标检测技术学习

最近公司做一个目标检测相关的项目,对目标检测以及相关的深度学习知识有一些了解。这里整理一下。 一、目标检测定义 什么是目标检测?最近还碰到一个朋友做的项目,是无人机目标检测的,很有意思(据说还是军事用途&…

SpringBoot的冬奥会科普平台 LW +PPT+源码

3 平台分析 3.1 平台可行性分析 3.1.1 经济可行性 由于本平台是作为毕业设计平台,且平台本身存在一些技术层面的缺陷,并不能直接用于商业用途,只想要通过该平台的开发提高自身学术水平,不需要特定服务器等额外花费。所有创造及工…

python离线安装第三方库、及其依赖库(单个安装,非批量移植)

文章目录 1.外网下载第三方库、依赖库2.内网安装第三方库3.补充附录内网中离线安装python第三方库,这时候只能去外网手动下载第三方库,再传回内网进行安装。 问题是python第三方库往往有其前置依赖包,你很难清楚某个第三方库依赖的是哪些依赖包,更难受的是依赖包可能还有其…

谷歌个人号14天封闭测试,又添新要求?怎么提高封测通过率?

相信不少在Google Play上架应用的开发者们,对谷歌个人号的20人连续14天的封闭测试感到头疼。谷歌对个人号提出周期长达14天的封测要求,主要是希望开发者们能上架质量更好、体验感更好的app到谷歌商店。 而随着谷歌行业的发展,这项政策要求的执…

双网卡设置路由网络不通原因之一:静态ip设置失败

1.主要现象: 外网通,内网不通 外网IP设置 内网IP设置 路由表设置 内网不通 2.主要原因:在适配器中设置的内网静态IP没有成功 设置静态IP失败 在命令行使用ipconfig命令看到内网适配器的静态IP为192.168.0.55,并不是我们设置的1…

密码学及其应用——GMP库在密码学中的应用

GMP(GNU Multiple Precision arithmetic library,GNU多精度算术库)是一个针对大整数运算的库。这个库提供了许多针对多种多精度类型的计算函数: - 大整数:Z - 大有理数:Q - 大浮点数:R 1. 密码学…

Unity URP简单烘焙场景步骤

Unity URP简单烘焙场景步骤 前言项目场景布置灯光模型Lighting设置环境设置烘焙前烘焙后增加角色 前言 项目中要烘焙一个3D场景,用的URP渲染管线,简单记录一下。 项目 场景布置 灯光 因为场景中有能动的东西,需要一部分实时光照&#xf…

vuejs3+elementPlus后台管理系统,左侧菜单栏制作,跳转、默认激活菜单

默认激活菜单,效果&#xff1a; 默认激活菜单&#xff0c;效果1&#xff1a; 默认激活菜单&#xff0c;效果2&#xff1a; 跳转链接效果&#xff1a; 制作&#xff1a; <script setup> import {useUserStore} from "/stores/userStore.js"; import {ref} fr…

FKA总结

问题点&#xff1a; 原因分析: 工作状态下进入充电模式&#xff0c;程序检测到的电压会降低&#xff0c;比如8.07V的电池电压&#xff0c;它处于充满的临界状态&#xff0c;开机情况下程序检测的电压会降到7.98V&#xff0c;然后进入充电模式显示红灯 关机状态下进入充电模式…

volatile关键字(juc编程)

volatile关键字 3.1 看程序说结果 分析如下程序&#xff0c;说出在控制台的输出结果。 Thread的子类 public class VolatileThread extends Thread {// 定义成员变量private boolean flag false ;public boolean isFlag() { return flag;}Overridepublic void run() {// 线…

数据结构与算法3---栈与队

一、栈 1、顺序栈 #define _CRT_SECURE_NO_WARNINGS 1 #include <stdio.h> #include <stdlib.h> //开辟空间#define MAXSIZE 50//顺序栈的基本算法 typedef struct {int stack[MAXSIZE];int top; }SqStack;//初始化 void InitStack(SqStack* S) {S->top …

[BUUCTF从零单排] Web方向 01.Web入门篇之粗心的小李解题思路

这是作者新开的一个专栏《BUUCTF从零单排》&#xff0c;旨在从零学习CTF知识&#xff0c;方便更多初学者了解各种类型的安全题目&#xff0c;后续分享一定程度会对不同类型的题目进行总结&#xff0c;并结合CTF书籍和真实案例实践&#xff0c;希望对您有所帮助。当然&#xff0…

JEnv-for-Windows 详细使用

管理员执行jenv.bat文件 执行正常, 接下来就是按照官网的命令就行了 文件下载地址 https://download.csdn.net/download/qq_43071699/89462664 JEnv 是一个强大的Java版本管理工具&#xff0c;允许开发者在多个Java版本之间轻松切换。以下是一些常用的JEnv命令&#xff0c;这…

【网络安全产品】---网闸

了解了不少安全产品&#xff0c;但是对网闸的理解一直比较模糊&#xff0c;今天 what 网闸是安全隔离与信息交换系统的简称&#xff0c;使得在不影响数据正常通信的前提下&#xff0c;让络在不连通的情况下数据的安全交换和资源共享&#xff0c;对不同安全域/网络之间实现真正…

vue项目——前端CryptoJS加密、解密

1、vue项目需要安装CryptoJS安装包 npm install crypto-js 2、在项目中引入CryptoJS import CryptoJS from crypto-js 3、使用&#xff0c;代码如下 // 此处key为16进制let key jiajiajiajiajiajiajiajia;console.log(密钥&#xff1a;, key);// key格式化处理key Crypt…

web中间件漏洞-weblogic漏洞-弱口令war包上传

web中间件漏洞-weblogic漏洞-弱口令war包上传 弱口令war包上传 制作war包 jar cvf ma.war.(最后的.代表打包当前目录) 弱口令weblogic/weblogic123 点击部署后、一直点击下一步 访问webshell

网络基础篇:网络模型

目录 一、初识网络 二、网络的分层 OSI七层模型 TCP/IP四层模型 网络与系统的关系 网络传输基本流程 数据包封装和分用 三、IP地址与MAC地址 认识IP地址 认识MAC地址 IP与MAC的关系 一、初识网络 同一台设备上的进程间通信有很多种方式 &#xff1a; 管道&#xff08…