Jmeter之JSON提取器
作者:互联网
在接口测试的时候,通常会遇到上一个接口的响应数据在下一个接口需要使用,那么这里就可以使用JSON 提取器来进行关联。
如查询天气的接口,返回的数据如下格式
{ "result": { "realtime": { "wid": "08", "temperature": "27", "direct": "东北风", "aqi": "37", "humidity": "89", "power": "2级", "info": "中雨" }, "city": "深圳", "future": [ { "date": "2021-09-06", "wid": { "night": "03", "day": "03" }, "temperature": "26\/33℃", "weather": "阵雨", "direct": "持续无风向" }, { "date": "2021-09-07", "wid": { "night": "01", "day": "01" }, "temperature": "27\/32℃", "weather": "多云", "direct": "东风" }, { "date": "2021-09-08", "wid": { "night": "00", "day": "00" }, "temperature": "27\/33℃", "weather": "晴", "direct": "持续无风向" }, { "date": "2021-09-09", "wid": { "night": "00", "day": "00" }, "temperature": "27\/33℃", "weather": "晴", "direct": "持续无风向" }, { "date": "2021-09-10", "wid": { "night": "03", "day": "03" }, "temperature": "27\/33℃", "weather": "阵雨", "direct": "持续无风向转东风" } ] }, "reason": "查询成功!", "error_code": 0 }
一、获取某一个字段
如,想要获取realtime下面的city信息:
1.$.result.city
2. $..city
在http请求下面添加JSON提取器,如下
此处responCity是变量名,如果下一个接口需要使用到,那么直接引用变量名称即可。
比如下一个接口也是此接口,仍然是查询深圳的天气,引用变量
可以增加一个 Debug Sample查看的到json提取器获取到的值,添加即可,不需要任何操作设置
二、获取相同字段的多个值
如上面响应中date的值,在future下面有未来5天的天气信息,其中包括date值。
获取所有的五个date值
1. $.result.future[*].date 获取所有的date的值
2. $.result.future[0].date 获取第一个date的值,以此类推
3. Match No.:取第几个值,-1表示取所有的值,0表示取所有值中任意一个,1表示取所有值中第一个,以此类推
4. 引用获取到的所有的date的值,首先可以查看debug sample,输出的每一个值的变量名称
一共获取到了五个值,date_matchNr即表示获取的总个数,上面的date_1/2/3/4/5代表五个值得变量。所以是在基础变量上面加上了编码。
那么我们可以使用计数器进行引用
又因为需要在变量中嵌套另一个变量,所以要用到__V函数,最后引用为 ${__V(date_${__counter(,)})}
添加一个循环控制器,然后将请求标题加上date的变量进行测试
三、提取多个字段
如想要提取realtime下面的temperature以及info两个值
使用英文分号隔开,如果获取三个四个同理分号隔开。
Default Values即默认的值,如果没有获取到则变量默认是啥值。
结果可以看到
标签:wid,提取,temperature,09,direct,获取,JSON,date,Jmeter 来源: https://www.cnblogs.com/longlongleg/p/15235029.html