日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程资源 > 综合教程 >内容正文

综合教程

Jmeter压测实战:Jmeter二次开发之自定义函数

發(fā)布時間:2023/10/11 综合教程 119 老码农
生活随笔 收集整理的這篇文章主要介紹了 Jmeter压测实战:Jmeter二次开发之自定义函数 小編覺得挺不錯的,現(xiàn)在分享給大家,幫大家做個參考.

1 前言

Jmeter是Apache基金會下的一款應用場景非常廣的壓力測試工具,具備輕量、高擴展性、分布式等特性。Jmeter已支持實現(xiàn)隨機數(shù)、計數(shù)器、時間戳、大小寫轉換、屬性校驗等多種函數(shù),方便使用人員使用。如果在使用過程中存在和業(yè)務強耦合的常用功能函數(shù),在Jmeter不支持的情況下,那就需要單獨開發(fā)自定義函數(shù)實現(xiàn)特定功能。

本文介紹如何開發(fā)Jmeter自定義函數(shù)實現(xiàn)快速生成京東宙斯下單標準sign,同時深刻理解Jmeter的插件化機制及高擴展性特性。

2 開發(fā)準備

  1. Java基礎開發(fā)
  2. Maven基本使用
  3. 開發(fā)依賴版本

    JDK 1.8.0Maven 3.6.3Jmeter 5.4.3

3 自定義函數(shù)核心實現(xiàn)

3.1 新建項目

  • 新建maven項目,這里項目名為:JSF_Sampler
  • 因為是基于Jmeter的擴展,需要依賴包Jmeter兩個核心包,分別是:
  • ApacheJMeter_core
  • ApacheJMeter_java
  • ApacehJMeter_functions

pom.xml文件核心配置如下

<groupId>com.jd.jmeter.jsf</groupId>
<artifactId>JSF_Sampler</artifactId>
<version>1.0-SNAPSHOT</version>
<properties>
<maven.compiler.source>8</maven.compiler.source>
<maven.compiler.target>8</maven.compiler.target>
<project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
<jmeter-version>5.4.3</jmeter-version>
</properties>
<dependencies>
<dependency>
<groupId>org.apache.jmeter</groupId>
<artifactId>ApacheJMeter_core</artifactId>
<version>${jmeter-version}</version>
</dependency>
<dependency>
<groupId>org.apache.jmeter</groupId>
<artifactId>ApacheJMeter_java</artifactId>
<version>${jmeter-version}</version>
</dependency>
<dependency>
<groupId>org.apache.jmeter</groupId>
<artifactId>ApacheJMeter_functions</artifactId>
<version>${jmeter-version}</version>
</dependency>
</dependencies>

3.2 繼承實現(xiàn)AbstractFunction類

實現(xiàn)類依次實現(xiàn)以下幾個步驟

1)新建實現(xiàn)類并繼承 AbstractFunction

  • 注意:實現(xiàn)類的包名必須包含xxx.functions.xxx,Jmeter使用命名規(guī)則實現(xiàn)實現(xiàn)類的加載。

2)重寫以下方法,每個方法的用途見下方代碼注釋

  • execute()
  • setParameters()
  • getReferenceKey()
  • getArgumentDesc()
   /**
* 京東宙斯 下單標準字段常量
*/
private static final String APP_KEY = "app_key";
private static final String APP_SECRET = "app_secret";
private static final String ACCESS_TOKEN = "access_token";
private static final String TIMESTAMP = "timestamp";
private static final String V = "v";
private static final String METHOD = "method";
private static final String BUY_PARAM_JSON = "360buy_param_json";
/**
* Jmeter中自定義的函數(shù)名,在Jmeter的函數(shù)助手中可以看到
*/
private static final String FUNC_NAME = "__GenSignFunction"; /**
* 自定義函數(shù)的描述,入?yún)ⅲ鰠ⅲ奖闶褂萌藛T參考使用
*/
private static final List<String> desc = new ArrayList<>(); static {
desc.add("This function is used to generate the JD's JOS sign value");
}
/**
* 此為自定義函數(shù)核心實現(xiàn)類,其中,入?yún)ampleResult為上次運行的結果,Sampler為當前的采集器;
* 返回值為該函數(shù)的返回值
* @param sampleResult
* @param sampler
* @return
* @throws InvalidVariableException
*/
@Override
public String execute(SampleResult sampleResult, Sampler sampler) throws InvalidVariableException {
// 入?yún)⑻幚?br /> String param = String.valueOf((CompoundVariable)paramValues[0]);
String signResult = paramHandler(param); return signResult;
} /**
* 按京東宙斯sign加密規(guī)則生成標準sign
* @param param
* @return
*/
public String paramHandler(String param){
Map<String,String> valueMap = new HashMap();
// 按&符號分割
String[] paramArray = param.split("&");
for (int i = 0; i < paramArray.length-1; i++) {
String key = paramArray[i].split("=")[0];
String value = paramArray[i].split("=")[1];
valueMap.put(key,value);
};
// 京東宙斯標準sign
String josGign = EncryptUtil.getSignature(valueMap.get("app_secret")+BUY_PARAM_JSON+valueMap.get("360buy_param_json")
+ACCESS_TOKEN+valueMap.get("access_token")
+APP_KEY+valueMap.get("app_key")
+METHOD+valueMap.get("method")
+TIMESTAMP+valueMap.get("timestamp")
+V+valueMap.get("v")
+valueMap.get("app_secret"));
return josGign;
} /**
* 配置入?yún)ⅲ琷meter函數(shù)助手入?yún)?br /> */
@Override
public void setParameters(Collection<CompoundVariable> collection) throws InvalidVariableException {
paramValues = collection.toArray();
}
/**
* 此方法返回自定義的函數(shù)名稱
*/
@Override
public String getReferenceKey() {
return FUNC_NAME;
}
/**
* 此方法返回函數(shù)描述信息
*/
@Override
public List<String> getArgumentDesc() {
return desc;
}

3.3 最終項目結構

4 Jmeter加載擴展包

以上開發(fā)完成,打包此項目,注意這里的打包要包含依賴包。

4.1 maven構建配置

<build>
<finalName>${project.artifactId}</finalName>
<defaultGoal>install</defaultGoal>
<plugins>
<plugin>
<groupId>org.apache.maven.plugins</groupId>
<artifactId>maven-compiler-plugin</artifactId>
<configuration>
<source>1.8</source>
<target>1.8</target>
</configuration>
</plugin>
<plugin>
<groupId>org.apache.maven.plugins</groupId>
<artifactId>maven-assembly-plugin</artifactId>
<configuration>
<descriptorRefs>
<descriptorRef>jar-with-dependencies</descriptorRef>
</descriptorRefs>
</configuration>
<executions>
<execution>
<id>assemble-all</id>
<phase>package</phase>
<goals>
<goal>single</goal>
</goals>
</execution>
</executions>
</plugin>
</plugins>
</build>

4.2 項目打包

打包指令如下
mvn package -Dmaven.test.skip=true

4.3 Jmeter加載擴展包

將打包后的擴展包放置到Jmeter的ext目錄:apache-jmeter-5.4.3/lib/ext/

啟動Jmeter后,Jmeter會自動加載ext目錄中的擴展包

打開Jmeter函數(shù)助手后,可以看到本次實現(xiàn)類中打印的相關日志

5 自定義函數(shù)調用調試

5.1 打開Jmeter函數(shù)助手,選擇自定義函數(shù)

5.2 京東宙斯接口驗證

這里使用京東快遞獲取預制運單號接口,輸入GET請求后,直接點擊運行函數(shù)【Generate & Copy to clipboard】,出參返回32位sign值。

GET請求入?yún)?br />
method=jingdong.etms.waybillcode.get&app_key=349559FAE87E66826499890862E40A44&access_token=c8c2bdc8d1684630bb771a503d5b5a7fkyzh×tamp=2022-01-28 15:10:00&360buy_param_json={"preNum":"1","customerCode":"10K43816","orderType":"0"}&v=2.0&sign=EBB52C6CEDA34703ADE72D4AA4D8F316&app_secret=29959e4cadc14ff4998d4fc26d1e5063

6 總結

本文通過自定義函數(shù)實現(xiàn)了京東宙斯下單標準sign的生成,希望通過本項目大家可以學習到:

  • 如何二次開發(fā)Jmeter,實現(xiàn)自己特有的自定義函數(shù)。
  • 理解為何官方介紹Jmeter是插件化的,高擴展性特性。
  • 更好的理解Jmeter內部處理機制。

作者:京東物流 苗浩沖

來源:京東云開發(fā)者社區(qū)

總結

以上是生活随笔為你收集整理的Jmeter压测实战:Jmeter二次开发之自定义函数的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網(wǎng)站內容還不錯,歡迎將生活随笔推薦給好友。