在之前写过提取json数据格式的文章,这次对jmeter读取json数据格式进行整理。

  举例一个接口的response 格式如下:

{
"data" : {
"device_vec" : [
{
"agent_version" : "9.7.0.2225",
"android_id" : "e3d699cf01620531",
"asset_number" : "",
"description" : "89vUwdwfVydEjqNAANxM11c72ujdmn",
"device_name" : "357568061882002",
"email" : "1504487508089@tt.com",
"encryption_log_count" : 0,
"encryption_version" : "",
"engine_version" : "9.715-1024",
"firewall_log_count" : 0,
"firewall_version" : "",
"group_id" : "aa000000-0000-0000-0000-000000000000",
"group_name" : "Default",
"id" : "35756806-1882-0020-0000-000000000000",
"imei" : "357568061882002",
"inactive_reason" : 0,
"install_time" : 1503642124,
"last_connected_time" : 1504742375,
"last_scan_time" : 1503642674,
"meid" : "",
"noncomp_reason" : "",
"os_version" : "4.3",
"pattern_version" : "2.437.00",
"phone_number" : "",
"platform_type" : 512,
"policy_id" : 32,
"policy_name" : "",
"security_status" : 3,
"status" : 3,
"user_name" : "test1504487508089",
"virus_log_count" : 26,
"wtp_log_count" : 0
},
{
"agent_version" : "2.0.0.1518",
"android_id" : "",
"asset_number" : "",
"description" : "3dLAbTlj7UQoOiodnAjDrfX1iI0PCx",
"device_name" : "Michael’s iPhone",
"email" : "1504487508089@tt.com",
"encryption_log_count" : 0,
"encryption_version" : "",
"engine_version" : "",
"firewall_log_count" : 0,
"firewall_version" : "",
"group_id" : "aa000000-0000-0000-0000-000000000000",
"group_name" : "Default",
"id" : "6954500b4f14e50bd20634481ee2c6d9f17b4ee3",
"imei" : "35 445006 267069 9",
"inactive_reason" : 0,
"install_time" : 1503641446,
"last_connected_time" : 1503652862,
"last_scan_time" : 1503641477,
"meid" : "35445006267069",
"noncomp_reason" : "",
"os_version" : "10.3.2",
"pattern_version" : "",
"phone_number" : "",
"platform_type" : 1024,
"policy_id" : 6,
"policy_name" : "",
"security_status" : 1,
"status" : 3,
"user_name" : "test1504487508089",
"virus_log_count" : 0,
"wtp_log_count" : 0
}
],
"total_count" : 2
},
"error_code" : 1,
"message" : "Success",
"timestamp" : 1504765848
}

下面就对device_vec取角标2的agent_version 参数进行提取。

方法一:Jmter Json插件,JSON Path Extractor 提取器。

处理Json数据的方法是使用JMeter的插件,该插件可以使用JSONPath来获取JSON数据中特定位置的数据。类似于XML文件中的XPath,JSONPath可以使用简单的表达式来操作Json对象。JSON Path Extractor是一个开源的增加了post处理器的插件,可以将该插件的Lib文件拷贝到JMeter的lib目录下或者通过Jmeter UI界面的Options-->Plugins Manager下载json插件即可。

可以使用如下的JSONPath进行描述:

$.data.device_vec[1].agent_version

在JMeter中,只需要从PostProcessor菜单中打开JSON Path Extractor然后输入变量名与默认值即可,如下所示:

JSONPath表达式较短并且易于阅读,能够有效提高测试脚本的易维护性,该插件并不随着标准的JMeter一起安装。

方法二:Jmter 正则表达式插件,正则表达式提取

JMeter安装了正则表达式插件之后,可以按照固定的格式从字符串中提取数据,而本例中正则表达式如下所示:

"agent_version":"(.+?)"

使用了该表达式之后会返回所有服从表达式的字符串,但是只有一个表达式是我们所关注的。可以使用1个组作为模板($1$),而2则会返回第二个数据。

方法三:Jmter BeanShell提取器, BeanShell提取器

借用了JMeter的对于BeanShell支持的特性,BeanShell是一个轻量级的面向Java的脚本语言。BeanShell Post Processor允许使用标准的Java语法来处理Json数据,使用方法如下图所示:

1.写一个jsonpath读取代码如下:

import java.util.LinkedHashMap;

import com.jayway.jsonpath.JsonPath;
import com.jayway.jsonpath.Predicate; import net.minidev.json.JSONArray; public class GetJson {
public static String readjson(String json, String jsonPath){
try{
Object value = JsonPath.read(json, jsonPath, new Predicate[0]);
if (value instanceof Integer){
return value.toString();
}else if (value instanceof String){
return value.toString();
}else if (value instanceof Boolean){
return value.toString();
}else if (value instanceof JSONArray){
JSONArray arr = (JSONArray)value;
if(!arr.isEmpty()){
return arr.toJSONString();
}else
return "";
}else if (value instanceof LinkedHashMap){
return value.toString();
}else if (value instanceof Float) {
return value.toString();
}else{
return value.toString();
}
}catch(Exception e){
return "pathnotfound";
}
}
}

然后使用此方法来读取json数据格式

2.导入com.eclipsesource.json 方法直接读取json

com.eclipsesource.json,源码下载路径如下 https://github.com/ralfstx/minimal-json,只需将源码打成jar包放到jmeter的lib/ext目录下即可

com.eclipsesource.json 适用方法:http://static.javadoc.io/com.eclipsesource.minimal-json/minimal-json/0.9.3/com/eclipsesource/json/JsonObject.html

3.如果是循环读取,那就要算出List的长度做循环---用jsonpath读取方式去循环取(前面的jsonpath方法不再贴)

4.如果是循环读取,那就要算出List的长度做循环---用com.eclipsesource.json api 读取方式循环读

如下:

总结

本文列举出了三种可用的从Json格式的返回值中提取数据的方法,正则表达式对于简单的Json格式的数据的快速标准化非常占优势。而JsonPath插件可以用于创建能够被维护修改的脚本,但是需要额外的插件安装工作。而最后的带JSON库的BeanShell确实非常详细并且依赖于Java语言的灵活性可以进行进一步的开发。

json几种读取方式,ArrayList循环读取【转】的更多相关文章

  1. jmeter ---json几种读取方式,ArrayList循环读取

    在之前写过提取json数据格式的文章,这次对jmeter读取json数据格式进行整理. 举例一个接口的response 格式如下: { "data" : { "devic ...

  2. 第63天:json的两种声明方式

    一. json 两种声明方式 1. 对象声明   var  json = {width:100,height:100} 2. 数组声明   var  man = [        //  数组的 js ...

  3. Perl读取标准输入<STDIN>、读取文件输入<>和chomp函数

    读取标准输入<STDIN> <STDIN>表示从标准输入中读取内容,如果没有,则等待输入.<STDIN>读取到的结果中,如果没有意外,都会自带换行符. 例如,tes ...

  4. C++中文件按行读取和逐词读取 backup

    http://blog.csdn.net/zhangchao3322218/article/details/7930857 #include  <iostream>#include  &l ...

  5. js循环读取json数据,将读取到的数据用js写成表格

    ①js循环读取json数据的方式: var data=[{"uid":"2688","uname":"*江苏省南菁高级中学 022 ...

  6. 5种高大上的yml文件读取方式,你知道吗?

    原创:微信公众号 码农参上,欢迎分享,转载请保留出处. 在上一篇文章中,我们从源码角度分析了SpringBoot解析yml配置文件的全流程,那么我们今天就来点实战,总结一下除了烂大街的@Value和@ ...

  7. Java中9种IO的读取方式

    数据的读写,按照数据类型可以分为两种:字符流和字节流(二者区别?).所以数据读取方式按照数据类型也可以分为两类:字节流的读取和字符流的读取. 一.字节流读取操作: |  | |-----1.FileI ...

  8. .Net中XML,JSON的几种处理方式

    一.XML: 1.基本了解: xml,Extensible markup language可扩展标记语言,用于数据的传输或保存,特点,格式非常整齐数据清晰明了,并且任何语言都内置了xml分析引擎, 不 ...

  9. Matlab如何循环读取文件

    循环读取图片第一种方法①List =dir('*.jpg'); %如需其它图片格式支持,可以自己[重载dir()]函数,实现查找所有图片文件的功能,%如果图片是其它路径,可以用 ["路径&q ...

随机推荐

  1. 如何删除offline数据文件/表空间上的分区

    接上一篇"Oracle 10g RAC全库flashback " http://www.cnblogs.com/cqubityj/p/3265552.html 在打开数据库之前把2 ...

  2. ConfigureAwait(false)

    昨天在做项目的时候,用的dapper查数据用的QueryAsync 异步方法.给上级做代码审核时,上级说最好加上ConfigureAwait(false).能减少一些性能开销. 因为之前没用过所以看了 ...

  3. C#调用带返回值的存储过程

    ()在SQL Server中建立如下的存储过程: set ANSI_NULLS ON set QUOTED_IDENTIFIER ON GO CREATE PROCEDURE [dbo].[GetNa ...

  4. java飞机大战之子弹的自动生成

    import java.awt.Graphics; import java.util.ArrayList; import javax.swing.JFrame; import javax.swing. ...

  5. 深入理解asp.net中的 __doPostBack函数

    前段时间做一个.net网站的时候,用到了模拟前端按钮刷新updatePanel进行局部刷新的时候,遇见了这个问题,当时没顾上记下来,查看网上资料,记下来留着以后查看. 很早以前,当我刚接触asp.NE ...

  6. Ros学习调试——rqt_console

    1.rqt_console rqt_console:ROS日志框架(logging framework)的一部分,用来显示节点的输出信息 rqt_logger_level:允许我们修改节点运行时输出信 ...

  7. Tensorflow学习—— AdamOptimizer

    import tensorflow as tffrom tensorflow.examples.tutorials.mnist import input_data #载入数据集mnist = inpu ...

  8. Linux bc命令

    一.简介 GNU bc是一款基于命令行的计算器程序,支持高精度数字和多种数值类型(例如二进制.十进制.十六进制)的输入输出. 二.实例 http://www.linuxidc.com/Linux/20 ...

  9. loj10104 [POI 2008]Blockade

    传送门 分析 我们知道对于一个割点,我们如果去掉它就会使原来的图被分为若干块,则这是我们将所有块包含的点的个数两两相乘即可,而如果不是割点则对于图的连通性没有影响.注意在最后要加上2*(n-1)表示去 ...

  10. notpad++ 开发php神奇

     开发PHP应具有的插件: 1. Compare: 可以用来比较两个文件不同之处. 2. Explorer:文件浏览器插件,包含收藏夹.Session保存功能.可与NppExec脚本结合使用. 3. ...