JMeter测试attack5a接口---2022-9-12

jmeter如何测试WebGoat中的attack5a接口----2022-9-12

参考此网址https://www.sohu.com/a/522629977_121312086,为jmeter入门案例教程

JMeter性能测试,完整入门篇

2022-02-14 14:10

Apache JMeter是一款纯java编写负载功能测试和性能测试开源工具软件。相比Loadrunner而言,JMeter小巧轻便且免费,逐渐成为了主流的性能测试工具,是每个测试人员都必须要掌握的工具之一。

本文为JMeter性能测试完整入门篇,从Jmeter下载安装到编写一个完整性能测试脚本、最终执行性能测试并分析性能测试结果。

运行环境为Windows 10系统,JDK版本为1.8,JMeter版本为3.3。

2. Jmeter安装

2.1 JDK安装

由于Jmeter是基于java开发,首先需要下载安装JDK (目前JMeter只支持到Java 8,尚不支持 Java 9)

\1. 官网下载地址:http://www.oracle.com/technetwork/java/javase/downloads/index.html

\2. 选择Java SE 8u151/ 8u152,点击JDK下载

img

\3. 安装下载的JDK

\4. 配置系统环境变量

2.2 JMeter安装

  1. 官网下载地址:http://jmeter.apache.org/download_jmeter.cgi
  2. 下载最新JMeter 3.3版本:apache-jmeter-3.3.zip

img

  1. 下载完成后解压zip包
  2. 启动JMeter
  3. 双击JMeter解压路径(apache-jmeter-3.3\bin)bin下面的jmeter.bat即可

img

3. 测试实例

我们选取最常见的百度搜索接口:

3.1 接口地址

http://www.baidu.com/s?ie=utf-8&wd=jmeter性能测试

3.2 请求参数

ie:编码方式,默认为utf-8

wd: 搜索词

3.3 返回结果

搜索结果,我们可以通过校验结果中是否含有搜索词wd来判断本次请求成功或失败。

4. JMeter脚本编写

4.1 添加线程组

右键点击“测试计划” -> “添加” -> “Threads(Users)” -> “线程组”

img

这里可以配置线程组名称,线程数,准备时长(Ramp-Up Period(in seconds))循环次数,调度器等参数:

img

线程组参数详解:

\1. 线程数:虚拟用户数。一个虚拟用户占用一个进程或线程。设置多少虚拟用户数在这里也就是设置多少个线程数。

\2. Ramp-Up Period(in seconds)准备时长:设置的虚拟用户数需要多长时间全部启动。如果线程数为10,准备时长为2,那么需要2秒钟启动10个线程,也就是每秒钟启动5个线程。

\3. 循环次数:每个线程发送请求的次数。如果线程数为10,循环次数为100,那么每个线程发送100次请求。总请求数为10*100=1000 。如果勾选了“永远”,那么所有线程会一直发送请求,一到选择停止运行脚本。

\4. Delay Thread creation until needed:直到需要时延迟线程的创建。

\5. 调度器:设置线程组启动的开始时间和结束时间(配置调度器时,需要勾选循环次数为永远)

持续时间(秒):测试持续时间,会覆盖结束时间

启动延迟(秒):测试延迟启动时间,会覆盖启动时间

启动时间:测试启动时间,启动延迟会覆盖它。当启动时间已过,手动只需测试时当前时间也会覆盖它。

结束时间:测试结束时间,持续时间会覆盖它。

因为接口调试需要,我们暂时均使用默认设置,待后面真正执行性能测试时再回来配置。

4.2 添加HTTP请求

右键点击“线程组” -> “添加” -> “Sampler” -> “HTTP请求”

img

对于我们的接口http://www.baidu.com/s?ie=utf-8&wd=jmeter性能测试,可以参考下图填写:

img

Http请求主要参数详解:

  1. Web服务器
  2. 协议:向目标服务器发送HTTP请求协议,可以是HTTP或HTTPS,默认为HTTP
  3. 服务器名称或IP :HTTP请求发送的目标服务器名称或IP
  4. 端口号:目标服务器的端口号,默认值为80
  5. 2.Http请求
  6. 方法:发送HTTP请求的方法,可用方法包括GET、POST、HEAD、PUT、OPTIONS、TRACE、DELETE等。
  7. 路径:目标URL路径(URL中去掉服务器地址、端口及参数后剩余部分)
  8. Content encoding :编码方式,默认为ISO-8859-1编码,这里配置为utf-8
  9. 同请求一起发送参数
  10. 在请求中发送的URL参数,用户可以将URL中所有参数设置在本表中,表中每行为一个参数(对应URL中的 name=value),注意参数传入中文时需要勾选“编码”

4.3 添加察看结果树

右键点击“线程组” -> “添加” -> “监听器” -> “察看结果树”

img

这时,我们运行Http请求,修改响应数据格式为“HTML Source Formatted”,可以看到本次搜索返回结果页面标题为”jmeter性能测试_百度搜索“。

img

4.4 添加用户自定义变量

我们可以添加用户自定义变量用以Http请求参数化,右键点击“线程组” -> “添加” -> “配置元件” -> “用户定义的变量”:

img

新增一个参数wd,存放搜索词:

img

并在Http请求中使用该参数,格式为:${wd}

img

4.5 添加断言

右键点击“HTTP请求” -> “添加”-> “断言” -> “响应断言”

img

我们校验返回的文本中是否包含搜索词,添加参数${wd}到要测试的模式中:

img

4.6 添加断言结果

右键点击“HTTP请求” -> “添加”-> “监听器” -> “断言结果”

img

这时,我们再运行一次就可以看到断言结果成功或失败了

img

4.7 添加聚合报告

右键点击“线程组” -> “添加” -> “监听器” -> “聚合报告”,用以存放性能测试报告

img

这样,我们就完成了一个完整Http接口的JMeter性能测试脚本编写。

5. 执行性能测试

5.1 配置线程组

点击线程组,配置本次性能测试相关参数:线程数,循环次数,持续时间等,这里我们配置并发用户数为10,持续时间为60s

img

5.2 执行测试

点击绿色小箭头按钮即可启动测试,测试之前需要点击小扫把按钮清除之前的调试结果。

img

6. 分析测试报告

待性能测试执行完成后,打开聚合报告可以看到:

img

聚合报告参数详解:

\1. Label:每个 JMeter 的 element(例如 HTTP Request)都有一个 Name 属性,这里显示的就是 Name 属性的值

\2. #Samples:请求数——表示这次测试中一共发出了多少个请求,如果模拟10个用户,每个用户迭代10次,那么这里显示100

\3. Average:平均响应时间——默认情况下是单个 Request 的平均响应时间,当使用了 Transaction Controller 时,以Transaction 为单位显示平均响应时间

\4. Median:中位数,也就是 50% 用户的响应时间

\5. 90% Line:90% 用户的响应时间

\6. Min:最小响应时间

\7. Max:最大响应时间

\8. Error%:错误率——错误请求数/请求总数

\9. Throughput:吞吐量——默认情况下表示每秒完成的请求数(Request per Second),当使用了 Transaction Controller 时,也可以表示类似 LoadRunner 的 Transaction per Second 数

\10. KB/Sec:每秒从服务器端接收到的数据量,相当于LoadRunner中的Throughput/Sec

一般而言,性能测试中我们需要重点关注的数据有: #Samples 请求数,Average 平均响应时间,Min 最小响应时间,Max 最大响应时间,Error% 错误率及Throughput 吞吐量。

7. 源码下载

至此,我们使用JMeter完成了一个完整的Http接口性能测试流程,从脚本编写,执行到最终结果分析。

=====================================================================================================

如何测试WebGoat中attack5a接口?

首先在byteman-aop-version3项目中启动,脚本如下:

##安装Byteman代理和ECA规则脚本:终端3
bminstall -b -Dorg.jboss.byteman.transform.all Bootstrap
bmsubmit -b C:\Users\ln13277429609\.m2\repository\org\antlr\antlr4-runtime\4.9.2\antlr4-runtime-4.9.2.jar
bmsubmit -b C:\Users\ln13277429609\Desktop\gitcode\git-study\byteman-aop-version3\tainted-helper\target\tainted-helper-1.0-SNAPSHOT.jar
bmsubmit -l traceGetParameter.btm
bmsubmit -l propagation4.btm
bmsubmit -l traceExecuteQuery.btm


##启动WebGoat:终端2
java -Dfile.encoding=UTF-8 -jar webgoat-server-8.0.0.M21.jar

然后启动BurpSuite,开启其专属浏览器

在这里插入图片描述

进入attack5a测试界面

在这里插入图片描述

拦截结果如下:
在这里插入图片描述

##请求信息
POST /WebGoat/SqlInjection/attack5a HTTP/1.1
Host: localhost:8080
Content-Length: 13
sec-ch-ua: "Chromium";v="105", "Not)A;Brand";v="8"
Accept: */*
Content-Type: application/x-www-form-urlencoded; charset=UTF-8
X-Requested-With: XMLHttpRequest
sec-ch-ua-mobile: ?0
User-Agent: Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/105.0.5195.102 Safari/537.36
sec-ch-ua-platform: "Windows"
Origin: http://localhost:8080
Sec-Fetch-Site: same-origin
Sec-Fetch-Mode: cors
Sec-Fetch-Dest: empty
Referer: http://localhost:8080/WebGoat/start.mvc
Accept-Encoding: gzip, deflate
Accept-Language: zh-CN,zh;q=0.9
Cookie: JSESSIONID=54A57DE22CE53DDC29CBB69014B0C9B7
Connection: close

account=Smith

打开JMeter

在这里插入图片描述

线程组

在这里插入图片描述

HTTP请求

在这里插入图片描述

察看结果树

在这里插入图片描述

HTTP信息头管理器

在这里插入图片描述

设置HTTP请求

在这里插入图片描述

在这里插入图片描述

由于是POST请求,需要信息头管理器设置

在这里插入图片描述

在这里插入图片描述
在这里插入图片描述

若没有去除空格,则会出现错误,参考网址:https://cxybb.com/article/bingyunjunqing/102782420#:~:text=%E6%8A%A5%E9%94%99%E4%BF%A1%E6%81%AF%EF%BC%9Ajava.lang.IllegalArgumentException%3A%20Host%20name%20may,not%20contain%20blanks%EF%BC%8C%E5%A6%82%E4%B8%8B%E5%9B%BE%EF%BC%9A%20%E6%8A%A5%E9%94%99%E5%8E%9F%E5%9B%A0%EF%BC%9AHTTP%E4%BF%A1%E6%81%AF%E5%A4%B4%E7%AE%A1%E7%90%86%E5%99%A8%E4%B8%AD%E7%9A%84%E6%95%B0%E6%8D%AE%E5%8C%85%E5%90%AB%E7%A9%BA%E6%A0%BC%EF%BC%8C%E6%9C%89%E5%8F%AF%E8%83%BD%E6%98%AF%E8%AF%AF%E6%93%8D%E4%BD%9C%EF%BC%8C%E4%B9%9F%E6%9C%89%E5%8F%AF%E8%83%BD%E6%98%AF%E7%9B%B4%E6%8E%A5%E4%BB%8E%E6%8A%93%E5%8C%85%E5%B7%A5%E5%85%B7%E4%B8%AD%E5%A4%8D%E5%88%B6%E7%B2%98%E8%B4%B4%E5%AF%BC%E8%87%B4%E7%9A%84%EF%BC%8C%E5%A6%82%E4%B8%8B%E5%9B%BE

在这里插入图片描述

点击请求测试按钮,出现测试结果如下:

在这里插入图片描述

此处bug没有解决处理,重新启动jmeter测试无问题。

在这里插入图片描述

修改请求参数

在这里插入图片描述

请求结果:

在这里插入图片描述

=========================================================================================================

在HTTP请求下添加响应断言

在这里插入图片描述

即返回的文本中是否包含amnesia.SQLIAException

在HTTP请求下添加断言结果:

!](https://img-blog.csdnimg.cn/c2420cc81439475586f3ee7cee4d1e7c.png#pic_center)

察看结果树如下:

在这里插入图片描述
在这里插入图片描述

=========================================================================================================

参数化进行批量测试(接口测试)

参考网址:https://blog.csdn.net/weixin_34255055/article/details/91504414

在这里插入图片描述

添加CSV数据集配置,并设置相关信息

在这里插入图片描述

在这里插入图片描述

设置HTTP请求

在这里插入图片描述

csv文件由Excel来创建并另存为csv格式

在这里插入图片描述

运行后的测试结果为:

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值