1、XPath提取器介绍

有些WEB项目是前后端不分离的,接口返回的内容不是Json格式的数据,而返回的是一个HTML页面。并且有些参数是隐藏在HTML页面里面的,需要从HTML页面中提取出这些隐藏参数,这个时候就会用到XPath提取器组件。

XPath提取器组件常用于接口返回值为HTML或XML格式数据的时候,进行数据的提取。

XPath提取器组件在后置处理器元件中,后置处理器主要的作用,在请求结束或者返回响应结果时发挥作用。

2、XPath提取器界面详解

添加XPath提取器组件操作:选中“取样器”右键 —> 添加 —> 后置处理器 —> XPath提取器

界面如下图所示:

下面是XPath提取器组件的详细说明:

  • 名称XPath提取器组件的自定义名称,见名知意最好。
  • 注释:即添加一些备注信息,对该XPath提取器组件的简短说明,以便后期回顾时查看。

(1)Apply to:作用范围(返回内容的取值范围)

  • Main sample and sub-samples:作用于父节点的取样器及对应子节点的取样器。
  • Main sample only:仅作用于父节点的取样器。
  • Sub-samples only:仅作用于子节点的取样器。
  • JMeter Variable Name to use:作用于JMeter变量(输入框内可输入JMeter的变量名称),从指定变量中提取需要的值。

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

  • Use Tidy (tolerant parser):当需要处理的页面是HTML格式时,必须选中该选项;如果是XML或XHTML格式,则取消选中。
  • Quiet:表示只显示需要的HTML页面。
  • Report errors:表示显示响应报错。
  • Show warnings:表示显示警告。
  • Use Namespaces:如果启用该选项,后续的XML解析器将使用命名空间来分辨。
  • Validate XML:根据页面元素模式进行检查解析。
  • Ignore Whitespace:忽略空白内容。
  • Fetch external DTDs:如果选中该项,外部将使用DTD规则来获取页面内容。

(3)第三部分内容

  • Return entire XPath fragment of text content:表示是否返回文本内容的整个XPath片段。
  • Reference Name:定义提取值的变量名称。
  • XPath Query:用于提取值的XPath表达式。
  • 匹配数字(0代表随机):表示取值是第几个匹配结果,因为有可能XPath表达式会匹配到多个值。0表示随机,-1表示全部,1代表第一个,2代表第二个,以此类推。
  • Default Value:参数的默认值。也就是取不到值时的默认值。

总结XPath提取器组件:

对所有符合条件的取样器按顺序进行取样。

例如,如果有一个主取样器和三个子取样器,每个取样器都有一个符合条件的匹配结果(总共4个)。

当设置为Sub-samples only时,匹配数字为3,则第三个子取样器的匹配结果返回;

当匹配数字为0或者负数,所有的合格的取样器都将被处理,而当匹配数字>0,一旦找到足够的匹配,比对就停止下来。

3、XPath提取器的使用

需求

  1. 访问网易官网,获取title值。
  2. 将title值放入百度搜索框,进行搜索。

(1)测试计划内包含的元件

添加元件操作步骤

  1. 创建测试计划。
  2. 创建线程组:选中“测试计划”右键 —> 添加 —> 线程(用户) —> 线程组
  3. 在线程组下,添加取样器“HTTP请求”组件:选中“线程组”右键 —> 添加 —> 取样器 —> HTTP请求
  4. 在取样器下,添加后置处理器“XPath提取器”组件:选中“取样器”右键 —> 添加 —> 后置处理器 —> XPath提取器
  5. 在线程组下,添加监听器“察看结果树”组件:选中“线程组”右键 —> 添加 —> 监听器 —> 察看结果树

提示:需要重复添加的组件这里不重复描述。

最终测试计划中的元件如下:

点击运行按钮,会提示你先保存该脚本,脚本保存完成后会直接自动运行该脚本。

提示:提取器一定要添加在你指定的某个请求下面,作为他的子请求,否则提取不到指定的数据!

(2)网易首页请求界面内容

非常简单的Get请求,之前说了很多次了,这里就不做解释了。

界面内容如下图所示:

(3)XPath提取器界面内容

我们在编辑XPath提取器组件之前,一般先请求一下需要提取返回数据的接口。

因为我们需要先查看一下需要提取的数据在什么位置,如下图所示:

然后选择XPath Tester视图模式,先手动编写XPath表达式,看看是否能够取到需要的数据。

如下图所示:

注意两点:

  1. 选择XPath Tester模式进行XPath表达式的编写验证。
  2. 如果是在HTML页面源码中提取数据,Use Tidy (tolerant parser)选择一定要勾选,否则会报错。

之后我们就可以编写XPath提取器组件界面了,如下:

编写引用名称、XPath表达式、匹配数据选择,还有Use Tidy选项一定要勾选,否则不能取到数据。

XPath提取器组件提取出来的数据,会存储在线程变量中,供其他后续接口使用。

关于XPath表示的写法,可以看Selenium相关的文章,里面有详细的写法。

(4)百度首页请求界面内容

填写接口的基本请求信息,然后把XPath提取器提取出来的数据,作为参数化变量应用到请求中。

如下图所示:

提示:如果此时直接执行该脚本,请求百度搜索网易的接口会执行,但是没有返回数据的,因为百度拒绝你的访问,我们需要设置请求头User-Agent属性,来模拟是一个浏览器访问,如User-Agent=Mozilla/5.0 (Windows NT 10.0; WOW64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/70.0.3538.25 Safari/537.36 Core/1.70.3861.400 QQBrowser/10.7.4313.400,这样百度就不会拒绝访问了。

(5)查看结果

我们可以看到再第二个请求中,拿到了第一个请求提取出来的数据“网易”。

如下图所示:

再来看看第二个请求响应的结果,可以看到有网易_百度搜索title属性,说明在百度已经进行了网易搜索。

如下图所示:

提示:可以添加Debug PostProcessor(调试后置处理器),或者Debug Sampler(调试取样器),来查看Xpath提取器中,提取出的内容是否正确。

注意:正常跑用例时删除或禁用它们。

4、总结

XPath提取器通常是从网页源文件中,提取数据时用的比较多。提取完参数后,相当于把参数以 key-value 的形式,存放到参数池中,以便后面的请求使用。

注意:不能超前引用。

『动善时』JMeter基础 — 34、JMeter接口关联【XPath提取器】的更多相关文章

  1. 『动善时』JMeter基础 — 33、JMeter察看结果树的显示模式详解

    目录 1.CSS Selector Tester视图 2.HTML查看器 (1)HTML视图 (2)HTML(download resources)视图 (3)HTML Source Formatte ...

  2. 『动善时』JMeter基础 — 36、JMeter接口关联【正则表达式提取器】

    目录 1.正则表达式提取器介绍 2.正则表达式提取器界面详解 3.正则表达式提取器的使用 (1)测试计划内包含的元件 (2)请求一界面内容 (3)正则表达式提取器界面内容 (4)请求二界面内容 (5) ...

  3. 『动善时』JMeter基础 — 6、使用JMeter发送一个最基础的请求

    目录 步骤1:创建一个测试计划 步骤2:创建线程组 步骤3:创建取样器 步骤4:创建监听器 步骤5:完善信息 步骤6:保存测试计划 步骤7:查看结果 总结:JMeter测试计划要素 当我们第一次打开J ...

  4. 『动善时』JMeter基础 — 8、JMeter主要元件介绍

    目录 1.测试计划(Test Plan) 2.线程组 3.取样器(sampler) 4.逻辑控制器(Logic Controller) 5.配置元件(Config Element) 6.定时器(Tim ...

  5. 『动善时』JMeter基础 — 37、将JMeter测试结果写入Excel

    目录 1.环境准备 (1)引入操作Excel文件的基础JAR包 (2)引入封装自定义操作Excel文件的JAR包 2.准备测试需要的数据 3.测试结果写入Excel演示 (1)测试计划内包含的元件 ( ...

  6. 『动善时』JMeter基础 — 40、JMeter中ForEach控制器详解

    目录 1.什么是逻辑控制器 2.ForEach控制器介绍 3.ForEach控制器的使用 (1)测试计划内包含的元件 (2)获取学院列表请求内容 (3)JSON提取器内容 (4)ForEach控制器内 ...

  7. 『动善时』JMeter基础 — 7、jmeter.properties文件常用配置

    目录 1.默认语言设置 2.配置默认编码格式 3.GUI图标放大比例设置 4.功能区工具栏图标大小设置 5.视图区目录树图标大小设置 6.内容区编辑字体设置 7.添加JMeter元素快捷键设置 8.捕 ...

  8. 『动善时』JMeter基础 — 15、使用JMeter实现上传文件

    目录 1.用于演示的项目说明 2.测试计划内包含的元件 3.HTTP请求界面内容 4.查看结果 5.总结 6.补充:MIME类型简介 (1)MIME说明 (2)常见类型 在上一篇文章[使用JMeter ...

  9. 『动善时』JMeter基础 — 29、JMeter响应断言详解

    目录 1.JMeter断言介绍 2.响应断言组件界面详解 3.响应断言组件的使用 (1)测试计划内包含的元件 (2)登陆接口请求界面内容 (3)响应断言界面内容 (4)查看运行结果 (5)断言结果组件 ...

随机推荐

  1. 三. 初步认识Eureka注册中心

    Eureka Eureka是Netflix公司出品,英文直译:发现了,找到了! 认识Eureka (一)首先我们来解决第一问题,服务的管理. Ⅰ.早期开发模式中出现的问题 再早期开发时业务时,首先模块 ...

  2. 👰🏿‍♂️

    出于利益我便是绝对的利己主义者,凡事以自己为根本,以求自己利益最大化而不顾他人.社会.国家: 出于兴趣考我便希望全天下的人都好,都可爱,都不必受餐食无饱和居无定所的困苦,不必因感情的躁动而心情颠簸,因 ...

  3. 🍎

    江湖中有一本练了就能天下无敌的葵花宝典,大家都想得到它.如果有一天葵花宝典被公开了,人人都有机会练,到底是好事还是坏事呢? 这会成为一个灾难. 因为一个人拥有时,练不练是一个人的事.大家都拥有,练不练 ...

  4. 缓冲区溢出分析第07课:MS06-040漏洞研究——静态分析

    前言 我在之前的课程中讨论过W32Dasm这款软件中的漏洞分析与利用的方法,由于使用该软件的人群毕竟是小众群体,因此该漏洞的危害相对来说还是比较小的.但是如果漏洞出现在Windows系统中,那么情况就 ...

  5. 我为Dexposed续一秒——论ART上运行时 Method AOP实现

    转载于:http://weishu.me/2017/11/23/dexposed-on-art/ 两年前阿里开源了 Dexposed 项目,它能够在Dalvik上无侵入地实现运行时方法拦截,正如其介绍 ...

  6. Win64 驱动内核编程-15.回调监控注册表

    回调监控注册表 在 WIN32 平台上,监控注册表的手段通常是 SSDT HOOK.不过用 SSDT HOOK 的方式监控注册表实在是太麻烦了,要 HOOK 一大堆函数,还要处理一些 NT6 系统有而 ...

  7. Python视频压缩

    html, body { font-family: "SF UI Display", ".PingFang SC", "PingFang SC&quo ...

  8. (一)安装mysql

    数据库 数据库的相关概念 DB:数据库(database):存储数据的"仓库".它保存了一系列有组织的数据. DBMS:数据库管理系统(Database Management Sy ...

  9. php实现微信推送消息

    一.<?phpnamespace Org\Weixin;class OrderPush{ protected $appid; protected $secrect; protected $acc ...

  10. 微服务架构开发电商系统需要用Redis、ES和MQ吗?

    如果不用什么很高大上的东西,就是有多个微服务就行这种技术架构会很难吗? 我看了一些视频,他们都用到了es.mq.redis的东西,我想不用这些东西,就简单的有多个服务,这样可行吗? 01 使用微服务你 ...