扫二维码与项目经理沟通
我们在微信上24小时期待你的声音
解答本文疑问/技术咨询/运营咨询/技术建议/互联网交流
最近项目中在做http协议的接口测试,其中接口请求报文数据有个字段值需要用到加密后的签名,即出于网络传输过程中,对数据安全的考虑,要对请求的数据进行特定的处理(加密),再进行请求。
创新互联主营卫滨网站建设的网络公司,主营网站建设方案,成都App制作,卫滨h5微信小程序定制开发搭建,卫滨网站营销推广欢迎卫滨等地区企业咨询
刚开始由于项目赶进度的需要,选择的做法是:让开发写个加密处理生成请求报文的代码,然后每次测试发送一次请求都用eclipse跑一遍该代码,测试数据的修改也是在代码中变更。这样跑一轮测试下来,测试同事都反映太累了。
jmeter中的BeanShell,可以用来调用我们的工具类对数据进行处理,然后再进行相关的请求。自己刚好以前工作中使用过,于是就利用jmeter的beanshell来解决这个问题。
解决过程:
这个需要看测试人员是否具有代码查看的权限,如果没有权限,直接要求开发人员把该工具类的代码发过来即可。
在eclipse中建个Java工程,把得到的工具类代码导进去。然后再导出成jar包。
将导出的jar包放到jmeter的lib\ext目录里。也可以不放进该目录,然后在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即可。
通过上述步骤脚本即可解决接口报文需要进行加密后才发送请求的测试处理。
未加密的请求结果:
利用beanshell加密后的请求结果:
至此,接口请求的加密处理已完成,不仅解决需通过代码生成请求报文的繁琐方法,还可以在此脚本的基础上,实现数据驱动的接口自动化测试,测试小伙伴们就可以愉快的进行测试了。
我们在微信上24小时期待你的声音
解答本文疑问/技术咨询/运营咨询/技术建议/互联网交流