第一部分:先准备好Jmeter

1.在开始编写脚本之前,先要确保你的Jmeter能够正常运行。若你还没有安装Jmeter,可参考以下方法:

A.Jmeter需要java运行环境,所以需要下载JDK,JDK下载地址:https://www.oracle.com/technetwork/java/javase/downloads/index.html

(最好使用 JDK 8  以上的版本,上述链接下可以下载最新的 JDK 版本)

B.安装JDK,请参考百度教程:https://jingyan.baidu.com/article/6dad5075d1dc40a123e36ea3.html

(注意java环境变量一定要配置正确)

C.下载安装Jmeter

Jmeter下载地址:http://jmeter.apache.org/download_jmeter.cgi

Jmeter安装流程(参考百度教程):https://jingyan.baidu.com/article/acf728fd68e7bef8e510a3cb.html

(注意Jmeter5.0版本的需要要配置环境变量,且要JDK 8 及以上才行)

D.引入MD5加密所需要的jar包。该jar包的名字是:commons-codec-1.9.jar

Jmeter本身就有MD5加密的功能,但是需要该jar包,可以查看Jmeter安装路径下的lib文件夹在有没有这个jar包:D:\apache-jmeter-5.0\apache-jmeter-5.0\lib

如果没有的话,网上下载一个放到lib文件夹下就OK了。

E.永久汉化Jmeter。

找到Jmeter安装路径下的jmeter.properties:D:\apache-jmeter-5.0\apache-jmeter-5.0\bin\jmeter.properties

用编辑器打开(右键用记事本打开也可以):找到  #language=en  ,在下面添加:language=zh_CN 保存并重启Jmeter

第二部分:编写MD5加密-请求验签的脚本

1.编写该脚本需要新建的东西如下:

A.添加一个线程组:测试计划——添加——线程(用户)——线程组

B.线程组下添加一个 前置处理器 BeanShell PreProcessor:线程组——添加——前置处理器——BeanShell PreProcessor

BeanShell PreProcessor 主要是用来完成加密字符串的拼接和MD5 加密

C.线程组下面添加一个 HTTP信息头管理器 :线程组——添加——配置元件——HTTP信息头管理器。

用于设置请求信息头里面的参数。

D.线程组下添加一个 HTTP请求:线程组——添加——取样器——HTTP请求。

E.最后添加 察看结果树 和 聚合报告  :线程组——添加——监听器—— 察看结果树 / 聚合报告

察看结果树的目的是用于:查看我们的请求是否访问成功,已经请求内容和返回内容是否正确

聚合报告:主要是用于统计总的请求数,平均请求时间,响应时长,Err 数,Err率等数据。

2.新建脚本的模型成功后,开始填充脚本的内容,完成脚本MD5加密功能。

A.在前置处理器 BeanShell PreProcessor添加如下内容:

 (Jmeter 5 自带 org.apache.commons.codec.digest  jar,所以只需要导入就可以了)  

(字符串的顺序拼接规则是:按照参数的首字母,对参数进行A-Z的顺序进行排序,并拼接,可以参见图中参数的排序规则)

(字符相互之间连接类似:appVersion=V1.0.0&clientType=XXX&productId=XXX&source=XXX,注:不同公司的拼接规则不同,需询问开发具体的拼接规则)

// 导入MD5加密需要用到的jar包。

import org.apache.commons.codec.digest.DigestUtils;

// 声明你需要拼接的字符串

String requestTime = "${__time(,)}"; //生成时间戳

String appVersion ="XXX";

String clientType ="XXX";

String productId ="XXX";

String source ="XXX";

//拼接需要加密的字符串

String str = "appVersion="+appVersion+"&clientType="+clientType+"&productId="+productId +"&requestTime="+requestTime+"&source="+source+"istarkid2018";

// 加密已拼接的字符串

String sign = DigestUtils.md5Hex(str);

vars.put("signStr",sign.toString()); //把生成的signStr提供给beanshell外部组件引用

vars.put("requestTime",requestTime.toString()); //把生成的时间戳提供给beanshell外部组件引用

vars.put("appVersion",appVersion.toString()); //把生成的版本号提供给beanshell外部组件引用

vars.put("clientType",clientType.toString()); //把生成的clientType提供给beanshell外部组件引用

生成时间戳,方法较多,不同公司所用的时间戳生成方法不同,这点需要询问开发具体的生成规则,以下提供几种生成规则:

生成十三位时间戳:${__time(,)}

生成十位时间戳:${__time(/1000,)}

生成当前日期,精确到天时间戳:${__time(yyyy-MM-dd,)}

生成当前日期,精确到秒时间戳:${__time(YMDHMS,)}

B.HTTP信息头输入接口验签需要验证的所有参数:例如:token,singa等。根据具体情况传入

C.在HTTP请求里面,添加:服务器IP,请求方法,接口路径,接口参数等值。

 第三部分:执行脚本

1.点击:菜单栏上的绿色按钮执行,第一次新建的测试计划会提示你先保存,把已经建好的测试计划保存到任意位置就可以了

2.设置并发数量,进行压测;

3.设置好后,点击执行,进行压测,压测完成后,可以在报告里面查看压测结果。

以上并是一个加了MD5和验签的脚本的具体流程,若有错误的地方,请大家多多指点~

Jmeter接口测试-MD5加密-请求验签(完整流程)的更多相关文章

  1. Java RSA加密以及验签

    签名加密以及验签工具类: 一般秘钥分为3个key 1.自己生成的私钥, 2.通过私钥生成的公钥1 3.通过提交公钥1给某宝,获取的公钥2. RSA公钥加密算法简介 非对称加密算法.只有短的RSA钥匙才 ...

  2. jmeter完成md5加密的接口请求参数

    第一种方法: 这种方法比较简单,jmeter内置了一个md5的函数,可以直接使用.其中参数username是用户名,正常填写,password是密码经过md5加密 第二种方法: 需要有一定的编程技术, ...

  3. jmeter md5加密请求参数

    实际的接口测试过程中,再发生http之前有可能需要对某些参数(或某几个参数的组合)进行md5加密 在jmeter中可通过两种方式来实现md5加密 beanshell实现md5加密 在org.apach ...

  4. Jmeter实现MD5加密

    Jmeter3.0以后的版本不再内置MD5加密函数,只能自己写了. 1.编码 package com.liuke.test; import java.security.MessageDigest; i ...

  5. jmeter 测试MD5加密登录接口

    1.点击options-funciton helper dialog,打开函数助手 在string to  calculate MD5 hash 中填写密码,复制function sysntax中的值 ...

  6. jmeter接口测试 -- Base64加密(函数助手添加自定义函数)

    图片转码 base64 致谢参考博客: https://www.cnblogs.com/qiaoyeye/p/7218770.html https://www.cnblogs.com/lasdaybg ...

  7. RSA加密解密及RSA加签验签

    RSA安全性应用场景说明 在刚接触RSA的时候,会混淆RSA加密解密和RSA加签验签的概念.简单来说加密解密是公钥加密私钥解密,持有公钥(多人持有)可以对数据加密,但是只有持有私钥(一人持有)才可以解 ...

  8. js rsa sign使用笔记(加密,解密,签名,验签)

    你将会收获: js如何加密, 解密 js如何签名, 验签 js和Java交互如何相互解密, 验签(重点) 通过谷歌, 发现jsrsasign库使用者较多. 查看api发现这个库功能很健全. 本文使用方 ...

  9. iOS,一行代码进行RSA、DES 、AES、MD5加密、解密

    本文为投稿文章,作者:Flying_Einstein(简书) 加密的Demo,欢迎下载 JAVA端的加密解密,读者可以看我同事的这篇文章:http://www.jianshu.com/p/98569e ...

随机推荐

  1. the import java.util cannot be resolve

    重新配置一下build path 的jre,如果不行的话就重新设置jre(在add library中installed JREs)

  2. Ajax的基本用法

    1.介绍 2.基本用法 2.1原生写法 $.ajax({ url: url, //是否是异步请求,默认是 // async: false, //请求方式,默认是get //type:'get', // ...

  3. Loki日志系统

    一.概述 背景 Loki的第一个稳定版本于2019年11月19日发布,是 Grafana Labs 团队最新的开源项目,是一个水平可扩展,高可用性,多租户的日志聚合系统. Grafana 对 Loki ...

  4. Python - Asyncio模块实现的生产消费者模型

    [原创]转载请注明作者Johnthegreat和本文链接 在设计模式中,生产消费者模型占有非常重要的地位,这个模型在现实世界中也有很多有意思的对应场景,比如做包子的人和吃包子的人,当两者速度不匹配时, ...

  5. 后端程序员之路 7、Zookeeper

    Zookeeper是hadoop的一个子项目,提供分布式应用程序协调服务. Apache ZooKeeper - Homehttps://zookeeper.apache.org/ zookeeper ...

  6. js 前端MD5加密

    1.引入 <script src="https://cdn.bootcss.com/blueimp-md5/2.10.0/js/md5.js"></script& ...

  7. OpenGL中的简单坐标系初看+VAO/VBO/EBO

    你好,三角形 一: 关于坐标的问题 标准化设备坐标:输入的顶点数据就应该在标准化设备坐标范围里面即:x,y,z的值都在(-1-1)之间.在这个区间之外的坐标都会被丢弃. 1.1一旦顶点数据传入顶点着色 ...

  8. 无需编程,通过配置零代码生成CRUD RESTful API

    Hello,crudapi!(你好,增删改查接口!) 本文通过学生对象为例,无需编程,通过配置实现CRUD RESTful API. 概要 CRUD简介 crud是指在做计算处理时的增加(Create ...

  9. SSRF漏洞利用之Redis大神赐予shell

        0x00实验环境 1.centos靶机(IP为:192.168.11.205,桥接模式) 2.kali黑客攻击主机(IP为:192.168.172.129,NAT模式) 0x01实验原理 这段 ...

  10. Redis 高并发带来的一些问题

    前言 本文讲述Redis在遇到高并发时的一些问题.即遇到大量请求时需要思考的点,如缓存穿透 缓存击穿 缓存雪崩 热key处理.一般中小型传统软件企业,很难碰到这个问题.如果有大并发的项目,流量有几百万 ...