利用JMeter的beanshell进行接口的加密处理
Posted qingxin
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了利用JMeter的beanshell进行接口的加密处理相关的知识,希望对你有一定的参考价值。
最近项目中在做http协议的接口测试,其中接口请求报文数据有个字段值需要用到加密后的签名,即出于网络传输过程中,对数据安全的考虑,要对请求的数据进行特定的处理(加密),再进行请求。
刚开始由于项目赶进度的需要,选择的做法是:让开发写个加密处理生成请求报文的代码,然后每次测试发送一次请求都用eclipse跑一遍该代码,测试数据的修改也是在代码中变更。这样跑一轮测试下来,测试同事都反映太累了。
jmeter中的BeanShell,可以用来调用我们的工具类对数据进行处理,然后再进行相关的请求。自己刚好以前工作中使用过,于是就利用jmeter的beanshell来解决这个问题。
解决过程:
1、获取对应接口加密的工具类,并生成jar包
这个需要看测试人员是否具有代码查看的权限,如果没有权限,直接要求开发人员把该工具类的代码发过来即可。
在eclipse中建个Java工程,把得到的工具类代码导进去。然后再导出成jar包。
2、把jar包放到${jmeter_home}\lib\ext下
将导出的jar包放到jmeter的lib\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 脚本,实现对http请求参数的加密