fix: 修复Mock服务Get-rest、POST请求模式下的问题
修复Mock服务Get-rest请求下自定义参数取值错误的问题、POST请求模式下xml、raw取值取不到的问题
This commit is contained in:
parent
c98c4af1e7
commit
6eec56c1cc
|
@ -14,13 +14,14 @@ import io.metersphere.commons.utils.JsonPathUtils;
|
||||||
import io.metersphere.commons.utils.SessionUtils;
|
import io.metersphere.commons.utils.SessionUtils;
|
||||||
import io.metersphere.i18n.Translator;
|
import io.metersphere.i18n.Translator;
|
||||||
import org.apache.commons.lang3.StringUtils;
|
import org.apache.commons.lang3.StringUtils;
|
||||||
|
import org.json.XML;
|
||||||
import org.springframework.stereotype.Service;
|
import org.springframework.stereotype.Service;
|
||||||
import org.springframework.transaction.annotation.Transactional;
|
import org.springframework.transaction.annotation.Transactional;
|
||||||
|
|
||||||
import javax.annotation.Resource;
|
import javax.annotation.Resource;
|
||||||
import javax.servlet.http.HttpServletRequest;
|
import javax.servlet.http.HttpServletRequest;
|
||||||
import javax.servlet.http.HttpServletResponse;
|
import javax.servlet.http.HttpServletResponse;
|
||||||
import java.io.IOException;
|
import java.io.*;
|
||||||
import java.util.*;
|
import java.util.*;
|
||||||
import java.util.stream.Collectors;
|
import java.util.stream.Collectors;
|
||||||
|
|
||||||
|
@ -410,10 +411,39 @@ public class MockConfigService {
|
||||||
e.printStackTrace();
|
e.printStackTrace();
|
||||||
}
|
}
|
||||||
return object;
|
return object;
|
||||||
} else {
|
} else if (StringUtils.equalsIgnoreCase("text/xml", request.getContentType())) {
|
||||||
Enumeration<String> paramNameItor = request.getParameterNames();
|
String xmlString = this.readXml(request);
|
||||||
|
System.out.println(xmlString);
|
||||||
|
|
||||||
|
org.json.JSONObject xmlJSONObj = XML.toJSONObject(xmlString);
|
||||||
|
String jsonStr = xmlJSONObj.toString();
|
||||||
|
JSONObject object = null;
|
||||||
|
try {
|
||||||
|
object = JSONObject.parseObject(jsonStr);
|
||||||
|
} catch (Exception e) {
|
||||||
|
}
|
||||||
|
return object;
|
||||||
|
} else if (StringUtils.equalsIgnoreCase("application/x-www-form-urlencoded", request.getContentType())) {
|
||||||
JSONObject object = new JSONObject();
|
JSONObject object = new JSONObject();
|
||||||
|
Enumeration<String> paramNameItor = request.getParameterNames();
|
||||||
|
while (paramNameItor.hasMoreElements()) {
|
||||||
|
String key = paramNameItor.nextElement();
|
||||||
|
String value = request.getParameter(key);
|
||||||
|
object.put(key, value);
|
||||||
|
}
|
||||||
|
return object;
|
||||||
|
} else {
|
||||||
|
JSONObject object = new JSONObject();
|
||||||
|
String bodyParam = this.readBody(request);
|
||||||
|
if (!StringUtils.isEmpty(bodyParam)) {
|
||||||
|
try {
|
||||||
|
object = JSONObject.parseObject(bodyParam);
|
||||||
|
} catch (Exception e) {
|
||||||
|
e.printStackTrace();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
Enumeration<String> paramNameItor = request.getParameterNames();
|
||||||
while (paramNameItor.hasMoreElements()) {
|
while (paramNameItor.hasMoreElements()) {
|
||||||
String key = paramNameItor.nextElement();
|
String key = paramNameItor.nextElement();
|
||||||
String value = request.getParameter(key);
|
String value = request.getParameter(key);
|
||||||
|
@ -423,40 +453,103 @@ public class MockConfigService {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
private String readXml(HttpServletRequest request) {
|
||||||
|
{
|
||||||
|
String inputLine = null;
|
||||||
|
// 接收到的数据
|
||||||
|
StringBuffer recieveData = new StringBuffer();
|
||||||
|
BufferedReader in = null;
|
||||||
|
try {
|
||||||
|
in = new BufferedReader(new InputStreamReader(
|
||||||
|
request.getInputStream(), "UTF-8"));
|
||||||
|
while ((inputLine = in.readLine()) != null) {
|
||||||
|
recieveData.append(inputLine);
|
||||||
|
}
|
||||||
|
} catch (IOException e) {
|
||||||
|
} finally {
|
||||||
|
try {
|
||||||
|
if (null != in) {
|
||||||
|
in.close();
|
||||||
|
}
|
||||||
|
} catch (IOException e) {
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
return recieveData.toString();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
private String readBody(HttpServletRequest request) {
|
||||||
|
String result = "";
|
||||||
|
try {
|
||||||
|
InputStream inputStream = request.getInputStream();
|
||||||
|
ByteArrayOutputStream outSteam = new ByteArrayOutputStream();
|
||||||
|
byte[] buffer = new byte[1024];
|
||||||
|
int len;
|
||||||
|
while ((len = inputStream.read(buffer)) != -1) {
|
||||||
|
outSteam.write(buffer, 0, len);
|
||||||
|
}
|
||||||
|
outSteam.close();
|
||||||
|
inputStream.close();
|
||||||
|
result = new String(outSteam.toByteArray(), "UTF-8");
|
||||||
|
} catch (Exception e) {
|
||||||
|
e.printStackTrace();
|
||||||
|
}
|
||||||
|
return result;
|
||||||
|
}
|
||||||
|
|
||||||
public JSONObject getSendRestParamMapByIdAndUrl(ApiDefinitionWithBLOBs api, String urlParams) {
|
public JSONObject getSendRestParamMapByIdAndUrl(ApiDefinitionWithBLOBs api, String urlParams) {
|
||||||
// ApiDefinitionWithBLOBs api = apiDefinitionMapper.selectByPrimaryKey(apiId);
|
// ApiDefinitionWithBLOBs api = apiDefinitionMapper.selectByPrimaryKey(apiId);
|
||||||
JSONObject returnJson = new JSONObject();
|
JSONObject returnJson = new JSONObject();
|
||||||
if (api != null) {
|
if (api != null) {
|
||||||
String path = api.getPath();
|
String path = api.getPath();
|
||||||
|
if (path.startsWith("/")) {
|
||||||
|
path = path.substring(1);
|
||||||
|
}
|
||||||
String[] pathArr = path.split("/");
|
String[] pathArr = path.split("/");
|
||||||
List<String> sendParams = new ArrayList<>();
|
String[] sendParamArr = urlParams.split("/");
|
||||||
for (String param : pathArr) {
|
|
||||||
|
//获取 url的<参数名-参数值>,通过匹配api的接口设置和实际发送的url
|
||||||
|
for (int i = 0; i < pathArr.length; i++) {
|
||||||
|
String param = pathArr[i];
|
||||||
if (param.startsWith("{") && param.endsWith("}")) {
|
if (param.startsWith("{") && param.endsWith("}")) {
|
||||||
param = param.substring(1, param.length() - 1);
|
param = param.substring(1, param.length() - 1);
|
||||||
sendParams.add(param);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
try {
|
|
||||||
JSONObject requestJson = JSONObject.parseObject(api.getRequest());
|
|
||||||
if (requestJson.containsKey("rest")) {
|
|
||||||
JSONArray jsonArray = requestJson.getJSONArray("rest");
|
|
||||||
for (int i = 0; i < jsonArray.size(); i++) {
|
|
||||||
JSONObject object = jsonArray.getJSONObject(i);
|
|
||||||
if (object.containsKey("name") && object.containsKey("enable") && object.getBoolean("enable")) {
|
|
||||||
String name = object.getString("name");
|
|
||||||
if (sendParams.contains(name)) {
|
|
||||||
String value = "";
|
String value = "";
|
||||||
if (object.containsKey("value")) {
|
if (sendParamArr.length > i) {
|
||||||
value = object.getString("value");
|
value = sendParamArr[i];
|
||||||
}
|
}
|
||||||
returnJson.put(name, value);
|
returnJson.put(param, value);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
|
||||||
}
|
// List<String> sendParams = new ArrayList<>();
|
||||||
} catch (Exception e) {
|
// for (String param : pathArr) {
|
||||||
e.printStackTrace();
|
// if (param.startsWith("{") && param.endsWith("}")) {
|
||||||
}
|
// param = param.substring(1, param.length() - 1);
|
||||||
|
// sendParams.add(param);
|
||||||
|
// }
|
||||||
|
// }
|
||||||
|
// try {
|
||||||
|
// JSONObject requestJson = JSONObject.parseObject(api.getRequest());
|
||||||
|
// if (requestJson.containsKey("rest")) {
|
||||||
|
// JSONArray jsonArray = requestJson.getJSONArray("rest");
|
||||||
|
// for (int i = 0; i < jsonArray.size(); i++) {
|
||||||
|
// JSONObject object = jsonArray.getJSONObject(i);
|
||||||
|
// if (object.containsKey("name") && object.containsKey("enable") && object.getBoolean("enable")) {
|
||||||
|
// String name = object.getString("name");
|
||||||
|
// if (sendParams.contains(name)) {
|
||||||
|
// String value = "";
|
||||||
|
// if (object.containsKey("value")) {
|
||||||
|
// value = object.getString("value");
|
||||||
|
// }
|
||||||
|
// returnJson.put(name, value);
|
||||||
|
// }
|
||||||
|
// }
|
||||||
|
// }
|
||||||
|
// }
|
||||||
|
// } catch (Exception e) {
|
||||||
|
// e.printStackTrace();
|
||||||
|
// }
|
||||||
}
|
}
|
||||||
return returnJson;
|
return returnJson;
|
||||||
}
|
}
|
||||||
|
@ -577,7 +670,8 @@ public class MockConfigService {
|
||||||
return this.assemblyMockConfingResponse(configList);
|
return this.assemblyMockConfingResponse(configList);
|
||||||
}
|
}
|
||||||
|
|
||||||
public String checkReturnWithMockExpectByBodyParam(String method, String projectId, HttpServletRequest request, HttpServletResponse response) {
|
public String checkReturnWithMockExpectByBodyParam(String method, String projectId, HttpServletRequest
|
||||||
|
request, HttpServletResponse response) {
|
||||||
String returnStr = "";
|
String returnStr = "";
|
||||||
String urlSuffix = this.getUrlSuffix(projectId, request);
|
String urlSuffix = this.getUrlSuffix(projectId, request);
|
||||||
List<ApiDefinitionWithBLOBs> aualifiedApiList = apiDefinitionService.preparedUrl(projectId, method, urlSuffix, urlSuffix);
|
List<ApiDefinitionWithBLOBs> aualifiedApiList = apiDefinitionService.preparedUrl(projectId, method, urlSuffix, urlSuffix);
|
||||||
|
@ -599,7 +693,8 @@ public class MockConfigService {
|
||||||
return returnStr;
|
return returnStr;
|
||||||
}
|
}
|
||||||
|
|
||||||
public String checkReturnWithMockExpectByUrlParam(String get, String projectId, HttpServletRequest request, HttpServletResponse response) {
|
public String checkReturnWithMockExpectByUrlParam(String get, String projectId, HttpServletRequest
|
||||||
|
request, HttpServletResponse response) {
|
||||||
String returnStr = "";
|
String returnStr = "";
|
||||||
String urlSuffix = this.getUrlSuffix(projectId, request);
|
String urlSuffix = this.getUrlSuffix(projectId, request);
|
||||||
List<ApiDefinitionWithBLOBs> aualifiedApiList = apiDefinitionService.preparedUrl(projectId, "GET", null, urlSuffix);
|
List<ApiDefinitionWithBLOBs> aualifiedApiList = apiDefinitionService.preparedUrl(projectId, "GET", null, urlSuffix);
|
||||||
|
|
Loading…
Reference in New Issue