Jmeter是Apache基金会下的一款应用场景非常广的压力测试工具,具备轻量、高扩展性、分布式等特性。Jmeter已支持实现随机数、计数器、时间戳、大小写转换、属性校验等多种函数,方便使用人员使用。如果在使用过程中存在和业务强耦合的常用功能函数,在Jmeter不支持的情况下,那就需要单独开发自定义函数实现特定功能。
本文介绍如何开发Jmeter自定义函数实现快速生成京东宙斯下单标准sign,同时深刻理解Jmeter的插件化机制及高扩展性特性。
pom.xml文件核心配置如下
-
com.jd.jmeter.jsf JSF_Sampler 1.0-SNAPSHOT -
8 -
8 -
UTF-8 -
5.4.3 -
-
org.apache.jmeter -
ApacheJMeter_core -
${jmeter-version} -
-
-
org.apache.jmeter -
ApacheJMeter_java -
${jmeter-version} -
-
-
org.apache.jmeter -
ApacheJMeter_functions -
${jmeter-version} -
-
实现类依次实现以下几个步骤
1)新建实现类并继承 AbstractFunction
2)重写以下方法,每个方法的用途见下方代码注释
- /**
- * 京东宙斯 下单标准字段常量
- */
- 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中自定义的函数名,在Jmeter的函数助手中可以看到
- */
- private static final String FUNC_NAME = "__GenSignFunction";
-
- /**
- * 自定义函数的描述,入参,出参,方便使用人员参考使用
- */
- private static final List
desc = new ArrayList<>(); -
- static {
- desc.add("This function is used to generate the JD's JOS sign value");
- }
- /**
- * 此为自定义函数核心实现类,其中,入参SampleResult为上次运行的结果,Sampler为当前的采集器;
- * 返回值为该函数的返回值
- * @param sampleResult
- * @param sampler
- * @return
- * @throws InvalidVariableException
- */
- @Override
- public String execute(SampleResult sampleResult, Sampler sampler) throws InvalidVariableException {
- // 入参处理
- String param = String.valueOf((CompoundVariable)paramValues[0]);
- String signResult = paramHandler(param);
-
- return signResult;
- }
-
- /**
- * 按京东宙斯sign加密规则生成标准sign
- * @param param
- * @return
- */
- public String paramHandler(String param){
- Map
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;
- }
-
- /**
- * 配置入参,jmeter函数助手入参
- */
- @Override
- public void setParameters(Collection
collection) throws InvalidVariableException { - paramValues = collection.toArray();
- }
- /**
- * 此方法返回自定义的函数名称
- */
- @Override
- public String getReferenceKey() {
- return FUNC_NAME;
- }
- /**
- * 此方法返回函数描述信息
- */
- @Override
- public List
getArgumentDesc() { - return desc;
- }

以上开发完成,打包此项目,注意这里的打包要包含依赖包。
-
-
${project.artifactId} -
install -
-
-
org.apache.maven.plugins -
maven-compiler-plugin -
-
1.8 -
1.8 -
-
-
-
org.apache.maven.plugins -
maven-assembly-plugin -
-
-
jar-with-dependencies -
-
-
-
- <id>assemble-allid>
-
package -
-
single -
-
-
-
-
-
- 打包指令如下
- mvn package -Dmaven.test.skip=true

将打包后的扩展包放置到Jmeter的ext目录:apache-jmeter-5.4.3/lib/ext/

启动Jmeter后,Jmeter会自动加载ext目录中的扩展包

打开Jmeter函数助手后,可以看到本次实现类中打印的相关日志



这里使用京东快递获取预制运单号接口,输入GET请求后,直接点击运行函数【Generate & Copy to clipboard】,出参返回32位sign值。
- GET请求入参
- 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


本文通过自定义函数实现了京东宙斯下单标准sign的生成,希望通过本项目大家可以学习到:
最后感谢每一个认真阅读我文章的人,礼尚往来总是要有的,虽然不是什么很值钱的东西,如果你用得到的话可以直接拿走:

这些资料,对于【软件测试】的朋友来说应该是最全面最完整的备战仓库,这个仓库也陪伴上万个测试工程师们走过最艰难的路程,希望也能帮助到你!
