【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从Word文档中提取图片并生成PPT的操作代码

《Python从Word文档中提取图片并生成PPT的操作代码》在日常办公场景中,我们经常需要从Word文档中提取图片,并将这些图片整理到PowerPoint幻灯片中,手动完成这一任务既耗时又容易出错,... 目录引言背景与需求解决方案概述代码解析代码核心逻辑说明总结引言在日常办公场景中,我们经常需要从 W

Java+AI驱动实现PDF文件数据提取与解析

《Java+AI驱动实现PDF文件数据提取与解析》本文将和大家分享一套基于AI的体检报告智能评估方案,详细介绍从PDF上传、内容提取到AI分析、数据存储的全流程自动化实现方法,感兴趣的可以了解下... 目录一、核心流程:从上传到评估的完整链路二、第一步:解析 PDF,提取体检报告内容1. 引入依赖2. 封装

Java使用正则提取字符串中的内容的详细步骤

《Java使用正则提取字符串中的内容的详细步骤》:本文主要介绍Java中使用正则表达式提取字符串内容的方法,通过Pattern和Matcher类实现,涵盖编译正则、查找匹配、分组捕获、数字与邮箱提... 目录1. 基础流程2. 关键方法说明3. 常见场景示例场景1:提取所有数字场景2:提取邮箱地址4. 高级

Python 字符串裁切与提取全面且实用的解决方案

《Python字符串裁切与提取全面且实用的解决方案》本文梳理了Python字符串处理方法,涵盖基础切片、split/partition分割、正则匹配及结构化数据解析(如BeautifulSoup、j... 目录python 字符串裁切与提取的完整指南 基础切片方法1. 使用切片操作符[start:end]2

使用Python提取PDF大纲(书签)的完整指南

《使用Python提取PDF大纲(书签)的完整指南》PDF大纲(Outline)​​是PDF文档中的导航结构,通常显示在阅读器的侧边栏中,方便用户快速跳转到文档的不同部分,大纲通常以层级结构组织,包含... 目录一、PDF大纲简介二、准备工作所需工具常见安装问题三、代码实现完整代码核心功能解析四、使用效果控

Linux从文件中提取特定内容的实用技巧分享

《Linux从文件中提取特定内容的实用技巧分享》在日常数据处理和配置文件管理中,我们经常需要从大型文件中提取特定内容,本文介绍的提取特定行技术正是这些高级操作的基础,以提取含有1的简单需求为例,我们可... 目录引言1、方法一:使用 grep 命令1.1 grep 命令基础1.2 命令详解1.3 高级用法2

Python实现批量提取BLF文件时间戳

《Python实现批量提取BLF文件时间戳》BLF(BinaryLoggingFormat)作为Vector公司推出的CAN总线数据记录格式,被广泛用于存储车辆通信数据,本文将使用Python轻松提取... 目录一、为什么需要批量处理 BLF 文件二、核心代码解析:从文件遍历到数据导出1. 环境准备与依赖库

Python中提取文件名扩展名的多种方法实现

《Python中提取文件名扩展名的多种方法实现》在Python编程中,经常会遇到需要从文件名中提取扩展名的场景,Python提供了多种方法来实现这一功能,不同方法适用于不同的场景和需求,包括os.pa... 目录技术背景实现步骤方法一:使用os.path.splitext方法二:使用pathlib模块方法三

Python实现精准提取 PDF中的文本,表格与图片

《Python实现精准提取PDF中的文本,表格与图片》在实际的系统开发中,处理PDF文件不仅限于读取整页文本,还有提取文档中的表格数据,图片或特定区域的内容,下面我们来看看如何使用Python实... 目录安装 python 库提取 PDF 文本内容:获取整页文本与指定区域内容获取页面上的所有文本内容获取

C/C++的OpenCV 进行图像梯度提取的几种实现

《C/C++的OpenCV进行图像梯度提取的几种实现》本文主要介绍了C/C++的OpenCV进行图像梯度提取的实现,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的... 目录预www.chinasem.cn备知识1. 图像加载与预处理2. Sobel 算子计算 X 和 Y