前置知识
1 两个接口
1-1 readData需要上传文件
- 参数
// formData类型
sdbh:""
file: "上传一个压缩包"
- 响应
{
"code": 1000,
"status": "success",
"message": "操作成功",
"data":
{
"name": "脱敏.gdb.zip",
"layers":
[
"czkfbjtztb_lx",
"dzxm_lx",
"gdtztb_lx",
"jsydtztb_lx",
"lsldtztb_lx",
"sdqy_lx",
"xzxm_lx",
"yjjbnttztb_lx",
"zzdy_lx",
"gbznttztb_lx",
"mzxm_lx",
"edqydltb_lx",
"edqylxdw_lx",
"edqyxzdw_lx",
"edqyzzhdltb_lx",
"edqyzzhlxdw_lx",
"edqyzzhxzdw_lx",
"sdqydltb_lx",
"sdqyzzhdltb_lx"
]
}
}
1-2 appendData 需要依赖于第一个接口的返回结果
layerName和fieldContent里面的name都依赖于第一个接口的返回结果。
- 参数
param: "{"layerNames":"czkfbjtztb_lx,dzxm_lx,gdtztb_lx,jsydtztb_lx,lsldtztb_lx,sdqy_lx,xzxm_lx,yjjbnttztb_lx,zzdy_lx,gbznttztb_lx,mzxm_lx,edqydltb_lx,edqylxdw_lx,edqyxzdw_lx,edqyzzhdltb_lx,edqyzzhlxdw_lx,edqyzzhxzdw_lx,sdqydltb_lx,sdqyzzhdltb_lx","updateData":[{"fieldContent":"{\"xmbh\":\"脱敏\",\"bsm\":\"\",\"sdmc\":\"脱敏05042023\",\"xmc\":\"脱敏\",\"xdm\":\"脱敏\"}"}],"bh":"3308252023289","name":"脱敏.gdb.zip","isUpdate":true}"
实操
1 首先对于第一个接口生成一个csv文件每次从文件中拿一个bh作为第一个参数(sdbh)的值
csv文件内容如下:
需要注意csv的表头字段就可以被我们当做环境变量进行使用了
2 新建一个前置处理脚本随机一个文件
#我们在这个目录下放我们需要的文件
File folder = new File("E:\\data\\test");
File[] audioFiles = folder.listFiles();
Random rnd = new Random();
#随机生成一个路径放入环境变量中
vars.put("CURRENT_FILE", audioFiles[rnd.nextInt(audioFiles.length)].getAbsolutePath());
log.info("CURRENT_FILE: " + vars.get("CURRENT_FILE"));
3 readData调用
这样我们已经随机拿了一个bh和随机了一个文件传入了接口readData
4 下一步就是拿到readData的返回结果进行后置处理
#我们对返回结果进行处理并且按照第二个接口的参数形式进行组织放入环境变量中
import org.json.JSONObject;
import org.json.JSONArray;
String response = prev.getResponseDataAsString();
String sdbh = vars.get("sdbh");
JSONObject jsonObject = new JSONObject(response);
JSONArray layersArray = jsonObject.getJSONObject("data").getJSONArray("layers");
String gdbName = jsonObject.getJSONObject("data").getString("name");
String layersString = String.join(",", layersArray.toList());
JSONObject paramObject = new JSONObject();
paramObject.put("layerNames", layersString);
JSONArray updateDataArray = new JSONArray();
JSONObject fieldContentObject = new JSONObject();
fieldContentObject.put("xmbh", sdbh);
fieldContentObject.put("bsm", "");
fieldContentObject.put("sdmc", "脱敏");
fieldContentObject.put("xmc", "脱敏");
fieldContentObject.put("xdm", "330825");
JSONObject updateDataObject = new JSONObject();
updateDataObject.put("fieldContent", fieldContentObject.toString());
updateDataArray.put(updateDataObject);
paramObject.put("updateData", updateDataArray);
paramObject.put("bh", sdbh);
paramObject.put("name", gdbName);
paramObject.put("isUpdate", true);
vars.put("param", paramObject.toString());
// 进行调试
log.info("param: " + vars.get("param"));
5 调用接口appendData
总结:整个流程第一是通过csv获得编号,第二是需要对第一个接口的返回值进行处理并存入环境变量,便于直接使用。