本篇介绍线上日志回放|线上流量回放、测试左移-http解析篇,接入报警篇见https://blog.csdn.net/weixin_42498050/article/details/105439833
线上日志回放
平时测试可以访问 :
JSON和GET请求字符串互转
https://qqe2.com/jsontool/json2get
1.背景:由于搜索就2个接口,接口返回数据在6000-8000行。每次客户端不同版本请求接口,接口返回的格式,取决于客户端传的sdkver、version、ver这三个字段。
每次在接口上线之前,读取线上请求参数日志,在预发环境改变以上3个传参的最新值,做线上日志回放,保证预发环境最新接口正常
2.用HashMap对appScene的来源做去重统计,再筛选出搜索业务线的场景
3.从数据库读取出日志,每次读取5000行,版本号为线上最新版本即可,获取每条SQL的查询字段内是否存在content字段(里面为所有日志,origialParam为客户端全部传参)
4.解析xx.content.origialParam的json:找到字符串中{第一次出现的位置,截取字符串
5.把日志里的json请求转化为get请求,调用httpClient,拼接域名+接口名+传参,解析response请求,对key value做断言
// 参数格式化
private static List<NameValuePair> getParamsList(Map<String, String> paramsMap) {
if (paramsMap != null && paramsMap.size() != 0) {
List<NameValuePair> params = new ArrayList();
Iterator var2 = paramsMap.entrySet().iterator();
while (var2.hasNext()) {
Map.Entry<String, String> map = (Map.Entry) var2.next();
// 预发环境最新版本日志回放,请求参数打开以下if else,注释掉最后一行
if (map.getKey().equals("sdkver")){
params.add(new NameValuePair(map.getKey() + "", "310"));
}else if(map.getKey().equals("version")){
params.add(new NameValuePair(map.getKey() + "", "8.6.4"));
}else if(map.getKey().equals("ver")){
params.add(new NameValuePair(map.getKey()+"","8.6.4"));
}else{
// 参数格式化,commons-httpclient自带的方法NameValuePair会自动将==转为=,还有特殊符号格式化
// NameValuePair是简单名称值对节点类型。多用于Java像url发送Post请求。在发送post请求时用该list来存放参数
params.add(new NameValuePair(map.getKey() + "", map.getValue() + ""));
}
// 线上版本日志回放,请求参数注释掉以上3个if else
// params.add(new NameValuePair(map.getKey() + "", map.getValue() + ""));
}
待续。。。