Jmeter获取登陆态场景脚本设计
2023-04-18 14:46:23 时间
项目中大多数接口的请求都是基于登陆态的,使用jmeter模拟接口压测时需要获取登陆态保证请求成功。以下有2种方法可参考。
1. 提取响应体的token并存入本地文件
1.1 场景描述:
该接口功能是进行短信/验证码登陆,登陆后接口返回值中携带token值,可作为其他接口的传参保证登陆态。因此将该token提取并存到本地txt或者csv文件,其余依赖登陆态的接口可读取本地文件保证登陆态。
1.2 使用插件:
Json提取器、Beanshell断言
1.3 具体步骤:
1)观察接口返回值,分析token在data数据体中结构
2)添加Json提取器,设置提取变量名为token,表达式为$.data.token
3)添加Beanshell断言,将以下代码拷贝至脚本框中,只需替换文件路径即可
//FileOutputStream fps=new FileOutputStream(${token_file_path},true);
FileOutputStream fps=new FileOutputStream("/Users/divywei/Desktop/token.csv",true);
OutputStreamWriter osw=new OutputStreamWriter(fps);
BufferedWriter bw=new BufferedWriter(osw);
String token = "${token}";
bw.append(token +"
");
if(bw!=null){bw.close();}
if(osw!=null){osw.close();}
if(fps!=null){fps.close();}
4)运行脚本,查看本地路径下已存在token.csv的文本,并且token值已存在
2. http cookie manager获取响应头的cookie值
2.1 场景描述:
该接口getUserMessage功能是获取当前登陆用户收到的消息条数,是需要登陆态的。这个登陆态同样需要从登陆接口的返回体中获取。这里登陆login接口没有把获取到的cookie值存入本地文本,而是直接透传给getUserMessage接口(进行压测不建议该方法)。
2.2 使用插件:
HTTP Cookie Manager、HTTP信息头管理器
2.3 具体步骤:
1)脚本结构设计:一个线程组下添加两个http request组件,一个登录请求,一个获取消息
2)登录请求下添加HTTP Cookie Manager,不做任何更改
3)调试登录接口,查看登陆态字段的结构,发现是响应头中的三个值w_uid、w_open、w_skey,如下所示:
4)获取用户消息条数请求下添加HTTP信息头管理器,设置cookie变量,传值的表达式标准写法:w_uid=${COOKIE_w_uid}
5)设置完成后运行该线程组,通过查看结果树检查是否获取成功
相关文章
- 【技术种草】cdn+轻量服务器+hugo=让博客“云原生”一下
- CLB运维&运营最佳实践 ---访问日志大洞察
- vnc方式登陆服务器
- 轻松学排序算法:眼睛直观感受几种常用排序算法
- 十二个经典的大数据项目
- 为什么使用 CDN 内容分发网络?
- 大数据——大数据默认端口号列表
- Weld 1.1.5.Final,JSR-299 的框架
- JavaFX 2012:彻底开源
- 提升as3程序性能的十大要点
- 通过凸面几何学进行独立于边际的在线多类学习
- 利用行动影响的规律性和部分已知的模型进行离线强化学习
- ModelLight:基于模型的交通信号控制的元强化学习
- 浅谈Visual Source Safe项目分支
- 基于先验知识的递归卡尔曼滤波的代理人联合状态和输入估计
- 结合网络结构和非线性恢复来提高声誉评估的性能
- 最佳实践丨云开发CloudBase多环境管理实践
- TimeVAE:用于生成多变量时间序列的变异自动编码器
- 具有线性阈值激活的神经网络:结构和算法
- 内网渗透之横向移动 -- 从域外向域内进行密码喷洒攻击