前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >JMeter处理器09

JMeter处理器09

作者头像
苦叶子
发布2018-04-04 16:24:12
1.2K0
发布2018-04-04 16:24:12
举报
文章被收录于专栏:开源优测开源优测
前言

在jmeter中提供了两种处理器,用于修改请求数据或处理响应数据。

  • 前置处理器
  • 后置处理器

前置处理器

前置处理器是在请求发送前做相关处理。可以用于在请求发送前修改HTTP协议头、数据部分等等各种需要修改或设置的数据。

其作用范围内的每一个sampler元件之前执行。

  • Bean Shell PreProcessor
  • HTML链接解析器
  • HTTP URL重写修饰符
  • JDBC PreProcessor
  • jp@gc - Raw Data Source PreProcessor
  • JSR223 PreProcessor
  • RegEx User Parameters
  • Sample Timeout
  • 用户参数

注: 一般情况下,大家在实践过程中,用到前置处理器的机会比较少,这里就不一一说明了,重点放在后置处理器的讲解上。

后置处理器

后置处理器是取样器被执行后被触发执行的元素。可用于解析响应数据,提取变量,以便后续使用。

注: json格式的支持需要安装json plugins创建

下面我们对常用的后置处理器进行说明:

  • JSON Extractor

用于处理响应结果为json格式的内容。

Variable names : 变量名称,提取到的值将存放在该变量里,后续通过该变量即可引用提取到的数据

JSONPath Expression:JSON表达式

Match Numbers:匹配哪个,可为空即默认第一个

Default Value:未取到值的时候默认值

示例

例如返回的json串为,我们提取token:
{   "statusCode":200,    
    "data":{        
        "userId":"admin",        
        "token":"12312312312338a5bd20bd"
    }
}

在JSONPath Expression填入: 

$.data.token来获取token的值
例如返回的json串有数组,我们提取第二个token:
{   
    "statusCode":200,    
    "data":[{        
        "userId":"admin",        
        "token":"rwerwerwr0e6138a5bd20bd"
        },
        {
        "userId":"user",
        "token":"123123123123123a5bd20bd"
        }]
}

在JSONPath Expression填入: 

$.data[1].token

来获取第二个token的值(注:数组的索引从0开始表示第一个)
  • jp@gc - JSON Path Extractor 用于处理响应结果为json格式的内容。 Destination Variable Name: 变量名称,提取到的值将存放在该变量里,后续通过该变量即可引用提取到的数据 JSONPath Expression:JSON表达式 Default Value:未取到值的时候默认值 具体示例请参见JSON Extractor的示例。这里不做详细示例了。
  • XPath Extractor 用于处理响应结果为xml格式的内容。 这里对关键参数进行说明: 引用名称:变量名称,提取到的值将存放在该变量里,后续通过该变量即可引用提取到的数据 XPath query:xpath表达式 缺省值:未取到值的时候默认值

示例

假如服务端返回如下格式的内容<title>Apache JMeter</title>
那么我们可以通过,以下xpath表达式获取到Apache JMeter字符串

 //title/text()
 
 将该xpath表达式填入在XPath query对应输入框中。
  • 正则表达式提取器 这是万能的提取模式了,支持使用正则表达式来提取满足要求的数据。当然你得熟练掌握正则表达式相关知识,才能游刃有余的应用。 引用名称:变量名称,提取到的值将存放在该变量里,后续通过该变量即可引用提取到的数据 正则表达式:用于匹配目标数据的正则表达式 模板:表示使用提取到的第几个值 $-1$:表示取所有值 $0$:表示随机取值 $1$:表示取第1个 $2$:表示取第二个 以此类推:$n$:表示取第n个 匹配数字(0代表随机): 0 代表随机取值,1 代表全部取值 缺省值: 如果正则表达式没有搜找到值,则使用此缺省值

具体的示例这里就不列举了,大家自己去尝试。

总结

本次主要就后置处理器中常用的json、xml及正则表达式处理器进行了分享。在日常测试过程中,这三种后置处理器是必须掌握的,需要深入掌握理解,同时需要对json、xpath、和正则表达式相关知识有所掌握才行。

本文参与 腾讯云自媒体分享计划,分享自微信公众号。
原始发表:2017-04-26,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 开源优测 微信公众号,前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 前置处理器
  • 后置处理器
  • 总结
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档