jmeter之json数据参数化、断言设置

在 http Load Testing 中,json 数据的提交是个让人头疼的问题。本文详细介绍如何进行 JMeter 的 json 测试提交,以及如何将其参数化。
Step 1 http json 请求采样器的录制
 这个工具很多,可以使用 JMeter 代理录制,也可以使用 Badboy。

Step 2 为该采样器添加 HTTP 信息管理器
鼠标右击该采样器,右键菜单选择 "添加" -> 配置元件 -> HTTP 信息头管理器,然后信息头添加一条名称为 Content-Type,值为 application/json 即可:

添加好 HTTP 信息管理器之后,选中该采样器,编辑其 Content encoding 为 UTF-8:

Step 3 为该采样器添加响应断言
 比如请求返还的 json 串里,"status":0 代表处理成功,status 值为其他表示各种处理失败。那么鼠标右击该采样器,右键菜单选择 "添加" -> 断言 -> 响应断言,要测试的响应字段选中 "响应文本",模式匹配规则选中 "Substring",要测试的模式添加并编辑其内容为 "status":0。

Step 4 编辑采样器的 json 格式
选中该采样器,Parameters 叶项里复制该 json 串,然后点击 Body Data 叶项,粘贴该 json 串于其中的输入域中(关于 json 串的提取,可以使用 Badboy 自己录制的,也可以使用 Chrome 浏览器自带工具 "JavaScript 控制台 - Network" 进行捕捉),最后调整 json 数据的展现格式如下图所示:

这时可以进行 http json 提交了,但是数据还都是写死的。那么怎么样把这些 json 数据参数化呢,就像其他非 json 提交的采样器一样?
Step 5 使用函数将 http json 数据参数化
 像其他采样器一样使用函数助手生成一个引用字符串,比如

${__Random(0,9,random_num_0_9)}

,它的作用是随机生成 0 - 9 之间的一个数字。
 然后编辑 Body Data 里的 json 串里需要参数化的地方,使用

${__Random(0,9,random_num_0_9)}

覆盖需要参数化的部分:

Step 6 使用 CSV Data Set Config 将 json 数据参数化
右键单击 Thread Group,右键菜单选择 "添加" -> 配置元件 -> CSV Data Set Config,Filename 输入 e:/defonds/work/20141105/json.txt(要使用绝对路径),Variable Names 输入 cityCode,cityName,subCategoryCode,subCategoryName,编辑 e:/defonds/work/20141105/json.txt 内容如下图所示:

最后编辑 Body Data 里的 json 串里需要参数化的地方,使用 ${cityCode} 等参数覆盖需要参数化的部分:

这时候你就可以使用参数化的 json 串进行压力测试啦:

JMeter,可以通过参数化的方式对json数据进行断言。首先,你需要录制http json请求采样器,并获取到json数据。然后,你可以使用函数助手来生成一个引用字符串,用于参数化json数据。接下来,你需要编辑采样器的json格式,将json数据粘贴到Body Data的输。最后,你可以调整json数据的展现格式,并进行断言。具体的步骤如下所示: 1. 使用JMeter代理录制或者其他工具录制http json请求采样器。 2. 获取到录制的json数据,并使用函数助手生成一个引用字符串,比如。 3. 在编辑采样器时,选该采样器,并复制Parameters叶项json串。 4. 然后,点击Body Data叶项,并将复制的json串粘贴到输。 5. 最后,调整json数据的展现格式,确保其符合要求。 通过以上步骤,你可以对json数据进行参数化,并进行断言操作。这样,你就可以在JMeter对http json请求进行测试,并验证其响应结果是否符合预期。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* *2* *3* [jmeterjson数据参数化 断言等](https://blog.csdn.net/weixin_33852020/article/details/85825572)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v92^chatsearchT3_1"}}] [.reference_item style="max-width: 100%"] [ .reference_list ]
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

黑夜照亮前行的路

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值