(重要-利用插件提取json中字段)JMeter中JSON数据处理

 

摘要 

JSON作为一种数据格式,越来越多地被用在Web 2.0和移动应用与后台应用之间的数据交互。本文介绍如何利用JMeter的“JSON Path Extractor“插件对服务器端返回的JSON字符串进行变量抽取。 

 

安装插件 

在开始使用之前,需要先把相应的插件安装到JMeter(作者使用的是JMeter 3.0)。打开网站,下载 plugins-manager.jar并把它放入$JMETER_HOME/lib/ext目录下。如果之前已经启动了JMeter,请关闭并重新启动。启动后,在“Options”菜单下应该会出现一个新的菜单选项“Plugins Manager”。单击该选项,弹出的对话框中可以安装新的插件。如下图所示,请在“Available Plugins”中选择“Dummy Sampler” 和“JSON Path Extractor”,然后单击右下角的“Apply Changes and Restart JMeter”按钮,等待下载完成后就自动重启JMeter。 

3 Basic Graphs 
5 Additional Graphs 
Auto—Stop Listener 
BM.Sense Uploader 
BlazeMeter Step-by—step Debugger 
Cassandra Support 
Command—Line Graph Plotting Tool 
Composite Timeline Graph 
Console Status Logger 
Custom JMeter Functions 
Custom SOAP Sampler 
JMeter Plugins Manager 
Available Plugins 
Version:

插件安装截图 

重启之后,可以打开Plugins Manager确认两个插件是否已经在“Installed Plugins”选项卡下,如果没有出现在该选项卡下,则安装未成功。读者可以查看一下$JMETER_HOME/lib/ext目录下是否有新加入的JAR包,没有的话再重新安装一次。 

 

插件介绍 

Dummy Sampler:该插件可以用于模拟服务器端返回的数据,而且返回的数据可以是手工在“Response Data”文本框中输入,这样可以避免向实际的服务器端发送数据,该插件作为验证JSON Path Extractor或者正则表达式非常有帮助。 

JSON Path Extractor:该插件可以使用JSON路径表达式来提取JSON返回值中的内容,并且可以把提取出的值放入JMeter变量中,供后面的测试步骤来使用。 

 

测试数据 

本文以下面的JSON片段为例来解释如何使用JSON Path Extractor来提取内容。 

{ "store": { 
"book": [ 
{ "category": "reference", 
"author": "Nigel Rees", 
"title": "Sayings of the Century", 
"price": 8.95 
}, 
{ "category": "fiction", 
"author": "Evelyn Waugh", 
"title": "Sword of Honour", 
"price": 12.99 
}, 
{ "category": "fiction", 
"author": "Herman Melville", 
"title": "Moby Dick", 
"isbn": "0-553-21311-3", 
"price": 8.99 
}, 
{ "category": "fiction", 
"author": "J. R. R. Tolkien", 
"title": "The Lord of the Rings", 
"isbn": "0-395-19395-8", 
"price": 22.99 
} 
], 
"bicycle": { 
"color": "red", 
"price": 19.95 
} 
} 
}  

请按照以下的内容来生成一个测试脚本,并在jp@gc - Dummy Sampler的“Response Data”。 

Test Plan 
Thread Croup 
jp@gc — Dummy Sampler 
jp@gc - JSON Path Extractor 
Debug Sampler 
View Results Tree 
WorkBench

 
 

测试脚本截图 

 

在JSON Path Extractor中,“Destination Variable Name”指的是将抽取出来的值放在指定的变量中,如图所示是把抽取出来的值赋值给author变量。JSONPath Expression中输入JSON表达式,如图所示的表达式“$..author”的意思是把JSON表达式中所有的author都取出。 

jp@gc - JSON Path Extractor 
Name: jp@gc - JSON Path Extractor 
Comments: 
O Help on this plugin 
Apply to: 
O Response Text 
JMeter Variable: 
Destination Variable Name: 
author 
JSONPath Expression: S..author 
Default Value:

JSON Path抽取器截图 

 

以上的表达式会生成下列的变量: 

author=["Nigel Rees","Evelyn Waugh","Herman Melville","J. R. R. Tolkien"] 
author_1=Nigel Rees 
author_2=Evelyn Waugh 
author_3=Herman Melville 
author_4=J. R. R. Tolkien 
author_matchNr=4  

可以通过变量${author_1}取得值“Nigel Rees”,${author_2}取得“Evelyn Waugh”等依此类推。 

Destination Variable Name: 
author 
JSONPath Expression: s..book[Ol.author 
Default Value:

 

变量使用表达式 

再看如上所示的表达式,取得数组下标为0的JSON串下的author字段,该插件会生成以下的变量: 

author=["Nigel Rees"] 
author_1=Nigel Rees 
author_matchNr=1  

JSONPath表达式甚至可以根据条件来过滤复合条件的数据,更多关于JSONPath表达式的例子可以参考这里 

JSON数据的其它处理方法 

除了JSONPath表达式之外,读者也可以考虑使用正则表达式来抽取内容,正则表达式的问题在于如果要处理的JSON字符串比较复杂,正则表达式的写法也会变得很复杂,不如JSONPath表达式那么简明易懂。 

另外的一种处理方法是采用BeanShell和第三方JSON库来抽取内容,这种方式下读者可以采用自己比较熟悉的库来解析和抽取相应的内容,但是这种方式需要读者对第三方的JSON库的使用有所了解,而且部署起来也不是特别方便,另外,使用BeanShell会对性能产生一定的影响。 

posted @ 2017-11-28 11:04  春田花花同学会  阅读(267)  评论(0)    收藏  举报