使用背景
之前在LS公司时,产品有多端,要走完一个完整的业务流程,手动测试造数据,总时很麻烦;
![a01e7d09d50fbab00342e28b6ae12ce7.png](https://i-blog.csdnimg.cn/blog_migrate/b6cf74415d2a9a4dc9b98c8fd0585989.jpeg)
但是UI测试又不是那么的稳定,维护起来效果也不太好;
![73a7ca615bae410d2768d3c36c4ba18a.png](https://i-blog.csdnimg.cn/blog_migrate/608083253d4d881cdc589bd34c518ec7.jpeg)
所以呢,通过jmeter接口实现业务流程的自动化了,但是CRM并没有前后端分离,那怎么通过接口来实现呢,当时的处理方法,就是通过jmeter自身的代理,抓包后,处理下相应参数来衔接周边系统;
当然,因为要跨端,有些接口headers里面的Content-Type是不一样的,这样的话,就要用多线程了,而且前后顺序也是有规定的。
主题分享
今天要分享的就是,抓包的接口返回的结果是html时,怎么来截取自己想要的内容
通过抓包的方式,抓过来的接口,有些返回结果是html的;一般简单的,可以用jmeter自带的正则表达式匹配出来;但是有些复杂的,甚至要同时取到返回结果的多个值时,貌似就有点力不从心了。
还好jmeter提供了可以编写java代码的beanshell,可以通过后置处理器(BeanShell PostProcessor)来处理,当时用到的代码如下:
import java.util.regex.Matcher;import java.util.regex.Pattern;import java.util.*;String respo= prev.getResponseDataAsString();//System.out.println("响应结果是: " + repos);Pattern p = Pattern.compile("data-id="(.+?)"");Matcher m = p.matcher(respo); list = new ArrayList(); while(m.find()) { list.add(m.group(1)); } HashSet h = new HashSet(list);//去重list.clear();list.addAll(h);//System.out.println(list);int a=list.size();//System.out.println(a); Random random = new Random();int b= random.nextInt(a);//随机取System.out.println(b);vars.put("xuqid",list.get(b));