【P20】JMeter XPath提取器(XPath Extractor)

2023-10-17 06:50

本文主要是介绍【P20】JMeter XPath提取器(XPath Extractor),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

文章目录

    • 一、XPath提取器(XPath Extractor)参数说明
    • 二、准备工作
    • 三、测试计划


一、XPath提取器(XPath Extractor)参数说明

可以采用 Xpath 语法提取所需要的值,功能非常强大(注意取样器返回必须为xml);底层采用 saxon-he 实现,语法参考 https://www.w3school.com.cn/xpath/index.asp 函数:http://saxon.sourceforge.net/saxon7.9.1/functions.html

右键 >>> 添加 >>> 后置处理器 >>> XPath提取器(XPath Extractor)

在这里插入图片描述

Apply to

  • Main sample and sub-samples:匹配范围包括当前父取样器并覆盖子取样器

  • Main sample only:默认;匹配范围是当前父取样器

  • Sub-samples only :仅匹配子取样器

  • JMeter Variable Name to use:支持对 Jemter变量值进行匹配(输入框内可输入jmeter的变量名称)

XML Parsing Options(要解析的XML参数)

  • Use Tidy (tolerant parser):当需要处理的页面是HTML格式时,必须选中该选项;如果是XML或XHTML格式(例如RSS返回),则取消选中

  • Quiet:表示只显示需要的HTML页面

  • 报告异常:表示显示响应报错

  • 显示警告:表示显示警告

  • Use Namespaces:如果启用该选项,后续的XML解析器将使用命名空间来分辨

  • Validate XML:根据页面元素模式进行检查解析

  • Ignore Whitespace:忽略空白内容

  • Fetch external DTDs:如果选中该项,外部将使用DTD规则来获取页面内容

(1)、Return entire XPath fragment instead of text content?:返回文本内容的整个XPath片段

(2)、引用名称(Name of created variables):请求要引用的变量名称,如填写 result_num

(3)、XPath query:用于提取值的XPath表达式

(4)、匹配数字(0代表随机)(Match No. (0 for Random)):0 代表随机取值,n取第几个匹配值,-1匹配所有;比如:取1表示报文中的第1个对象匹配,取2表示报文中的第2个对象匹配

(5)、缺省值(Default Value):如果参数没有取得到值,那默认给一个值让它取

二、准备工作

百度:https://www.w3school.com.cn/example/xmle/cd_catalog.xml

  • 进入网页后,右键检查或按F12,打开调试工具

在这里插入图片描述

如图,使用XPath提取器(XPath Extractor)获取 <TITLE>Empire Burlesque</TITLE>

注:这个地址有时会返回304状态码,网页多刷新几次,让其从缓存中获取数据。测试时,需使用 HTTP缓存管理器 获取缓存

三、测试计划

(1)、测试计划右键 <<< 添加 <<< 配置元件 <<< HTTP缓存管理器

在这里插入图片描述

(2)、网页复制全部的请求标头

在这里插入图片描述

(3)、测试计划右键 <<< 添加 <<< 配置元件 <<< HTTP信息头管理器

在这里插入图片描述

  • 在网页调试中,复制全部的请求标头,点击从剪切板添加按钮,即可全部自动添加好

此请求头必须和网页中的保存一致,且网页不可刷新,否则会改变

(4)、测试计划右键 <<< 添加 <<< 配置元件 <<< HTTP请求默认值

在这里插入图片描述

  • 协议:https

  • 服务器名称或IP:www.w3school.com.cn

  • 端口号:无端口的话,https 默认端口为 443

  • 内容编码:utf-8

(5)、测试计划右键 <<< 添加 <<< 线程(用户)<<< 线程组

(6)、线程组右键 <<< 添加 <<< 取样器 <<< HTTP请求

在这里插入图片描述

  • GET

  • 路径:/example/xmle/cd_catalog.xml

(7)、HTTP请求右键 <<< 添加 <<< 后置处理器 <<< XPath提取器

在这里插入图片描述

  • 勾选 Main sample only

  • 勾选 Return entire XPath fragment instead of text content?

  • 引用名称:xpath

  • XPath query:CATALOG/CD/TITLE

语法参考:https://www.w3school.com.cn/xpath/index.asp

函数:http://saxon.sourceforge.net/saxon7.9.1/functions.html

  • 匹配数字(0代表随机):1

(8)、线程组右键 <<< 添加 <<< 监听器 <<< 查看结果树

(9)、线程组右键 <<< 添加 <<< 取样器 <<< 调试取样器

(10)、点击启动,点击查看结果树,查看请求及取样器信息

在这里插入图片描述

如图,可以看到 HTTP请求返回成功,响应数据下响应体中,数据正确

(11)、点击查看结果树中的调试取样器,查看响应数据下的响应体

在这里插入图片描述

xpath=<TITLE>Empire Burlesque</TITLE>:获取到的变量值

xpath_1=<TITLE>Empire Burlesque</TITLE>:匹配的第一个值

xpath_matchNr=1:统计匹配的个数,一共1个

这篇关于【P20】JMeter XPath提取器(XPath Extractor)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/223662

相关文章

使用Python在Excel中插入、修改、提取和删除超链接

《使用Python在Excel中插入、修改、提取和删除超链接》超链接是Excel中的常用功能,通过点击超链接可以快速跳转到外部网站、本地文件或工作表中的特定单元格,有效提升数据访问的效率和用户体验,这... 目录引言使用工具python在Excel中插入超链接Python修改Excel中的超链接Python

C#从XmlDocument提取完整字符串的方法

《C#从XmlDocument提取完整字符串的方法》文章介绍了两种生成格式化XML字符串的方法,方法一使用`XmlDocument`的`OuterXml`属性,但输出的XML字符串不带格式,可读性差,... 方法1:通过XMLDocument的OuterXml属性,见XmlDocument类该方法获得的xm

C#提取PDF表单数据的实现流程

《C#提取PDF表单数据的实现流程》PDF表单是一种常见的数据收集工具,广泛应用于调查问卷、业务合同等场景,凭借出色的跨平台兼容性和标准化特点,PDF表单在各行各业中得到了广泛应用,本文将探讨如何使用... 目录引言使用工具C# 提取多个PDF表单域的数据C# 提取特定PDF表单域的数据引言PDF表单是一

C#实现添加/替换/提取或删除Excel中的图片

《C#实现添加/替换/提取或删除Excel中的图片》在Excel中插入与数据相关的图片,能将关键数据或信息以更直观的方式呈现出来,使文档更加美观,下面我们来看看如何在C#中实现添加/替换/提取或删除E... 在Excandroidel中插入与数据相关的图片,能将关键数据或信息以更直观的方式呈现出来,使文档更

Java后端接口中提取请求头中的Cookie和Token的方法

《Java后端接口中提取请求头中的Cookie和Token的方法》在现代Web开发中,HTTP请求头(Header)是客户端与服务器之间传递信息的重要方式之一,本文将详细介绍如何在Java后端(以Sp... 目录引言1. 背景1.1 什么是 HTTP 请求头?1.2 为什么需要提取请求头?2. 使用 Spr

使用Java解析JSON数据并提取特定字段的实现步骤(以提取mailNo为例)

《使用Java解析JSON数据并提取特定字段的实现步骤(以提取mailNo为例)》在现代软件开发中,处理JSON数据是一项非常常见的任务,无论是从API接口获取数据,还是将数据存储为JSON格式,解析... 目录1. 背景介绍1.1 jsON简介1.2 实际案例2. 准备工作2.1 环境搭建2.1.1 添加

python解析HTML并提取span标签中的文本

《python解析HTML并提取span标签中的文本》在网页开发和数据抓取过程中,我们经常需要从HTML页面中提取信息,尤其是span元素中的文本,span标签是一个行内元素,通常用于包装一小段文本或... 目录一、安装相关依赖二、html 页面结构三、使用 BeautifulSoup javascript

ROS - C++实现RosBag包回放/提取

文章目录 1. 回放原理2. 回放/提取 多个话题3. 回放/提取数据包,并实时发布 1. 回放原理 #include <ros/ros.h>#include <rosbag/bag.h>#include <std_msgs/String.h>int main(int argc, char** argv){// 初始化ROS节点ros::init(argc, argv,

css选择器和xpath选择器在线转换器

具体前往:Css Selector(选择器)转Xpath在线工具

jmeter之仅一次控制器

仅一次控制器作用: 不管线程组设置多少次循环,它下面的组件都只会执行一次 Tips:很多情况下需要登录才能访问其他接口,比如:商品列表、添加商品到购物车、购物车列表等,在多场景下,登录只需要1次,我们期望的是重复执行登陆后面的接口来做压测,这就和事务相关,例如 事务1: 登录—>添加购物车 事务2: 登录—>购物车列表 事务3: 登录—>商品列表—>添加购物车 … 一、仅一次控制器案例 在