利用JMeter的beanshell进行接口的加密处理

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了利用JMeter的beanshell进行接口的加密处理相关的知识,希望对你有一定的参考价值。

    最近项目中在做http协议的接口测试,其中接口请求报文数据有个字段值需要用到加密后的签名,即出于网络传输过程中,对数据安全的考虑,要对请求的数据进行特定的处理(加密),再进行请求。

     刚开始由于项目赶进度的需要,选择的做法是:让开发写个加密处理生成请求报文的代码,然后每次测试发送一次请求都用eclipse跑一遍该代码,测试数据的修改也是在代码中变更。这样跑一轮测试下来,测试同事都反映太累了。

     jmeter中的BeanShell,可以用来调用我们的工具类对数据进行处理,然后再进行相关的请求。自己刚好以前工作中使用过,于是就利用jmeterbeanshell来解决这个问题。

 

解决过程:

1、获取对应接口加密的工具类,并生成jar

    这个需要看测试人员是否具有代码查看的权限,如果没有权限,直接要求开发人员把该工具类的代码发过来即可。

    eclipse中建个Java工程,把得到的工具类代码导进去。然后再导出成jar包。

技术分享

 

技术分享

 

 

2、把jar包放到${jmeter_home}\lib\ext

    将导出的jar包放到jmeterlib\ext目录里。也可以不放进该目录,然后在jmeter的测试计划直接引用即可。

技术分享

 

 

3、创建jmeter脚本

    jmeter中创建一个项目,添加一个httprequest,在这个请求里添加一个BeanShell PreProcessor

技术分享

 

     http请求中根据实际情况填写对应的数据:

技术分享

 

 

    BeanShellPreProcessor中导入我们的jar包,BeanShell PreProcessor中的两个方法是我们最常用到的:vars.get(String paramStr)vars.put(Stringkey,String value),前一个是从jmeter中获得变量值,后一个是将数据存到jmeter变量中。

技术分享

说明:mac是需要签名加密的字段,在BeanShell PreProcessor中主要是利用加密的工具类对报文进行加密,得到加密后的mac值,然后在接口报文中调用mac即可。

 

 

4、执行jmeter脚本

     通过上述步骤脚本即可解决接口报文需要进行加密后才发送请求的测试处理。

 

未加密的请求结果:


 技术分享

 

利用beanshell加密后的请求结果:


 技术分享

 

     

    至此,接口请求的加密处理已完成,不仅解决需通过代码生成请求报文的繁琐方法,还可以在此脚本的基础上,实现数据驱动的接口自动化测试,测试小伙伴们就可以愉快的进行测试了。


本文出自 “半路测试” 博客,请务必保留此出处http://tiantiantesting.blog.51cto.com/10211292/1789571

以上是关于利用JMeter的beanshell进行接口的加密处理的主要内容,如果未能解决你的问题,请参考以下文章

JMeter BeanShell 实现接口签名验签及加解密

Jmeter使用beanshell对数据进行加密传输

Jmeter之BeanShell变量使用讲解

jmeter通过BeanShell 脚本,实现对http请求参数的加密

jmeter-BeanShell PreProcessor的使用

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