极兔ncc 自定义sql用{mainTable}代替当前表名代码同步

jingwei
wangxuanran 2023-05-31 10:07:27 +08:00
parent 7e6fa007e0
commit 685240f2f8
30 changed files with 1058 additions and 473 deletions

View File

@ -8,8 +8,8 @@ const threeMonthIndex = 1;
const submitWaitNode = WfForm.convertFieldNameToId("sftjddjd"); const submitWaitNode = WfForm.convertFieldNameToId("sftjddjd");
// 下次超时提醒日期 // 下次超时提醒日期
const timeoutRemindDateFiled = WfForm.convertFieldNameToId("cstxrq"); const timeoutRemindDateFiled = WfForm.convertFieldNameToId("cstxrq");
// 跟踪天数 // 跟踪天数 <= 1 ? 15 : 30;
const trackingDays = WfForm.getFieldValue(trackTimeField) <= 1 ? 15 : 30; const trackingDaysField = WfForm.convertFieldNameToId("gzts")
// 跟踪触发行数 // 跟踪触发行数
const trackingLineField = WfForm.convertFieldNameToId("gzcfxs"); const trackingLineField = WfForm.convertFieldNameToId("gzcfxs");
$(() => { $(() => {
@ -44,6 +44,7 @@ function getNodeNum(){
let currentDate = getCurrentDate(); let currentDate = getCurrentDate();
let dayDiff = getDaysDiff(firstSaleDate, currentDate); let dayDiff = getDaysDiff(firstSaleDate, currentDate);
console.log('当前天数与首台销售日期相差天数 : ', dayDiff) console.log('当前天数与首台销售日期相差天数 : ', dayDiff)
let trackingDays = WfForm.getFieldValue(trackingDaysField);
return Math.floor(dayDiff / trackingDays) + 1; return Math.floor(dayDiff / trackingDays) + 1;
} }
@ -52,6 +53,7 @@ function initTimeoutDate(){
let firstSaleDate = WfForm.getFieldValue(firstSaleDateField); let firstSaleDate = WfForm.getFieldValue(firstSaleDateField);
const nodeNum = getNodeNum(); const nodeNum = getNodeNum();
console.log('到达节点次数 ', nodeNum); console.log('到达节点次数 ', nodeNum);
let trackingDays = WfForm.getFieldValue(trackingDaysField);
console.log('跟踪天数 ', trackingDays); console.log('跟踪天数 ', trackingDays);
let computeTimeoutDate = addDays(firstSaleDate, nodeNum * trackingDays); let computeTimeoutDate = addDays(firstSaleDate, nodeNum * trackingDays);
console.log('计算下次超时日期 ', computeTimeoutDate); console.log('计算下次超时日期 ', computeTimeoutDate);

View File

@ -45,12 +45,12 @@ public class OtherSystemToOAController {
// 获取重定向地址和secret // 获取重定向地址和secret
Map<String, String> redirectUrlAndCorpsecret = service.getRedirectUrlAndCorpsecret(appId); Map<String, String> redirectUrlAndCorpsecret = service.getRedirectUrlAndCorpsecret(appId);
String redirectUrl = Util.null2DefaultStr(redirectUrlAndCorpsecret.get("REDIRECTURL"),""); String redirectUrl = Util.null2DefaultStr(redirectUrlAndCorpsecret.get("REDIRECTURL"),"");
log.info("successSendRedirectUrl : " + redirectUrl);
if(StringUtils.isBlank(redirectUrl)){ if(StringUtils.isBlank(redirectUrl)){
throw new CustomerException("redirectUrl is null! " + JSONObject.toJSONString(redirectUrlAndCorpsecret)); throw new CustomerException("redirectUrl is null! " + JSONObject.toJSONString(redirectUrlAndCorpsecret));
} }
int userId = service.getUserFromOtherSys(code, redirectUrlAndCorpsecret); int userId = service.getUserFromOtherSys(code, redirectUrlAndCorpsecret);
SessionUtil.createSession(userId + "", request, response); SessionUtil.createSession(String.valueOf(userId), request, response);
log.info("successSendRedirectUrl : " + redirectUrl);
response.sendRedirect(redirectUrl); response.sendRedirect(redirectUrl);
}catch (Exception e){ }catch (Exception e){
log.error("sso error : " + e.getMessage()); log.error("sso error : " + e.getMessage());

View File

@ -1,8 +1,11 @@
package com.api.xuanran.wang.sh_bigdata.sso.mapper; package com.api.xuanran.wang.sh_bigdata.sso.mapper;
import aiyh.utils.Util;
import aiyh.utils.annotation.recordset.ParamMapper; import aiyh.utils.annotation.recordset.ParamMapper;
import aiyh.utils.annotation.recordset.Select; import aiyh.utils.annotation.recordset.Select;
import aiyh.utils.annotation.recordset.SqlMapper; import aiyh.utils.annotation.recordset.SqlMapper;
import aiyh.utils.annotation.recordset.SqlString;
import weaver.xuanran.wang.sh_bigdata.common.util.ShBigDataUtil;
import java.util.Map; import java.util.Map;
@ -21,8 +24,8 @@ public interface OtherSystemToOAMapper {
* @param outKey id * @param outKey id
* @return oa ID * @return oa ID
**/ **/
@Select("select id from hrmresource where outkey = #{outKey}") @Select(custom = true)
int selectUserIdByOutKey(@ParamMapper("outKey") String outKey); int selectUserIdByOutKey(@SqlString String sql, @ParamMapper("outKey") String outKey);
/** /**
* <h1>appId </h1> * <h1>appId </h1>
* @author xuanran.wang * @author xuanran.wang

View File

@ -21,7 +21,7 @@ public interface OtherSystemToOAService {
* @param cusSuccess / * @param cusSuccess /
* @return * @return
**/ **/
int getUserIdByCode(String url, Map<String, Object> params, Map<String, String> headers, CusSuccess cusSuccess, Map<String, String> redirectUrlSecret); Object getUserIdByCode(String url, Map<String, Object> params, Map<String, String> headers, CusSuccess cusSuccess, Map<String, String> redirectUrlSecret);
/** /**
* <h1>codeoaid</h1> * <h1>codeoaid</h1>
* @author xuanran.wang * @author xuanran.wang

View File

@ -28,12 +28,13 @@ public class OtherSystemToOAServiceImpl implements OtherSystemToOAService {
.successField("code") .successField("code")
.successValue(0) .successValue(0)
.errorMsg("msg") .errorMsg("msg")
.dataKey("data.id") .dataKey("data." + Util.null2DefaultStr(ShBigDataUtil.getPropertiesValByKey("ssoInterfaceCompareField"), "id"))
.build(); .build();
private final OtherSystemToOAMapper otherSystemToOAMapper = Util.getMapper(OtherSystemToOAMapper.class); private final OtherSystemToOAMapper otherSystemToOAMapper = Util.getMapper(OtherSystemToOAMapper.class);
private final Logger log = Util.getLogger(); private final Logger log = Util.getLogger();
@Override @Override
public int getUserIdByCode(String url, Map<String, Object> params, Map<String, String> headers, CusSuccess cusSuccess, Map<String, String> redirectUrlSecret) { public Object getUserIdByCode(String url, Map<String, Object> params, Map<String, String> headers, CusSuccess cusSuccess, Map<String, String> redirectUrlSecret) {
String secret = Util.null2DefaultStr(redirectUrlSecret.get("SECRET"), ""); String secret = Util.null2DefaultStr(redirectUrlSecret.get("SECRET"), "");
log.info("secret : " + secret); log.info("secret : " + secret);
if(StringUtils.isBlank(secret)){ if(StringUtils.isBlank(secret)){
@ -48,7 +49,7 @@ public class OtherSystemToOAServiceImpl implements OtherSystemToOAService {
params.put("code", code); params.put("code", code);
// 获取第三方系统id // 获取第三方系统id
String getUserInfoByCodeUrl = ShBigDataUtil.getPropertiesValByKey("getUserInfoByCodeUrl"); String getUserInfoByCodeUrl = ShBigDataUtil.getPropertiesValByKey("getUserInfoByCodeUrl");
int codeId; Object codeId;
try { try {
codeId = getUserIdByCode(getUserInfoByCodeUrl, params, new HashMap<>(), cusSuccess, redirectUrlSecret); codeId = getUserIdByCode(getUserInfoByCodeUrl, params, new HashMap<>(), cusSuccess, redirectUrlSecret);
}catch (Exception e){ }catch (Exception e){
@ -61,10 +62,12 @@ public class OtherSystemToOAServiceImpl implements OtherSystemToOAService {
throw new CustomerException(e.getMessage()); throw new CustomerException(e.getMessage());
} }
} }
if(codeId < 0){ String oaOutKey = Util.null2DefaultStr(codeId, "");
if(StringUtils.isBlank(oaOutKey)){
throw new CustomerException(Util.logStr("code : {}, not found in {} .", code, getUserInfoByCodeUrl)); throw new CustomerException(Util.logStr("code : {}, not found in {} .", code, getUserInfoByCodeUrl));
} }
int id = otherSystemToOAMapper.selectUserIdByOutKey(codeId + ""); String sql = "select id from hrmresource where " + Util.null2DefaultStr(ShBigDataUtil.getPropertiesValByKey("ssoOaCompareField"),"outkey") + " = #{outKey}";
int id = otherSystemToOAMapper.selectUserIdByOutKey(sql, oaOutKey);
if(id < 0){ if(id < 0){
throw new CustomerException(Util.logStr("code : {} not found in OA!", id)); throw new CustomerException(Util.logStr("code : {} not found in OA!", id));
} }

View File

@ -680,6 +680,12 @@ public class DealWithMapping extends ToolUtil {
} }
} }
} }
// 自定义sql用{mainTable}代替当前表名 解决极兔ncc问题
if(StringUtils.isNotBlank(mainTable)){
valueContext = valueContext.replace("{mainTable}", mainTable);
}else {
logger.error("mainTable is null!");
}
String requestId = Util.null2String(mainMap.get("requestid")); String requestId = Util.null2String(mainMap.get("requestid"));
tempValue = "'" + tempValue + "'"; tempValue = "'" + tempValue + "'";
value = this.getValueByChangeRule(valueContext, tempValue, requestId, detailId); value = this.getValueByChangeRule(valueContext, tempValue, requestId, detailId);
@ -1028,6 +1034,12 @@ public class DealWithMapping extends ToolUtil {
tempValue = Util.null2String(tempRs.getString(fieldName)); tempValue = Util.null2String(tempRs.getString(fieldName));
} }
} }
// 自定义sql用{mainTable}代替当前表名 解决极兔ncc问题
if(StringUtils.isNotBlank(mainTable)){
valueContext = valueContext.replace("{mainTable}", mainTable);
}else {
logger.error("mainTable is null!");
}
tempValue = "'" + tempValue + "'"; tempValue = "'" + tempValue + "'";
value = this.getValueByChangeRule(valueContext, tempValue, requestId, detailId); value = this.getValueByChangeRule(valueContext, tempValue, requestId, detailId);
} }

View File

@ -1,17 +1,14 @@
package weaver.xuanran.wang.eighty_five_degreec.sap.action; package weaver.xuanran.wang.eighty_five_degreec.sap.action;
import aiyh.utils.ThreadPoolConfig;
import aiyh.utils.action.SafeCusBaseAction; import aiyh.utils.action.SafeCusBaseAction;
import aiyh.utils.annotation.ActionDesc; import aiyh.utils.annotation.*;
import aiyh.utils.annotation.PrintParamMark; import aiyh.utils.excention.CustomerException;
import aiyh.utils.annotation.RequiredMark;
import weaver.hrm.User; import weaver.hrm.User;
import weaver.soa.workflow.request.RequestInfo; import weaver.soa.workflow.request.RequestInfo;
import weaver.xuanran.wang.eighty_five_degreec.sap.entity.eneity.MainRequestConfig; import weaver.xuanran.wang.eighty_five_degreec.sap.entity.eneity.MainRequestConfig;
import weaver.xuanran.wang.eighty_five_degreec.sap.service.WorkflowToSapService; import weaver.xuanran.wang.eighty_five_degreec.sap.service.WorkflowToSapService;
import weaver.xuanran.wang.eighty_five_degreec.sap.service.impl.WorkflowToSapServiceImpl; import weaver.xuanran.wang.eighty_five_degreec.sap.service.impl.WorkflowToSapServiceImpl;
import java.util.concurrent.ExecutorService;
/** /**
* <h1>sap</h1> * <h1>sap</h1>
@ -23,31 +20,53 @@ import java.util.concurrent.ExecutorService;
public class WorkflowToSap extends SafeCusBaseAction { public class WorkflowToSap extends SafeCusBaseAction {
private final WorkflowToSapService service = new WorkflowToSapServiceImpl(); private final WorkflowToSapService service = new WorkflowToSapServiceImpl();
private final ExecutorService pool = ThreadPoolConfig.createThreadPoolInstance();
@PrintParamMark @PrintParamMark
@RequiredMark("配置表唯一标识") @RequiredMark("配置表唯一标识")
@ActionDefaultTestValue(value = "****")
private String uniqueCode; private String uniqueCode;
@PrintParamMark @PrintParamMark
@RequiredMark("日志表模块id") @RequiredMark("日志表模块id")
@ActionDefaultTestValue(value = "11")
private String modelId; private String modelId;
@PrintParamMark
@RequiredMark("成功失败/标识字段")
@ActionDefaultTestValue(value = "soap-env:Envelope.soap-env:Body.n0:ZFI_OA_DOC_POSTINGResponse.ES_OA_OUTPUT.TYPE")
private String successField;
@PrintParamMark
@RequiredMark("成功时候的值")
@ActionDefaultTestValue(value = "T")
private String successVal;
@PrintParamMark
@RequiredMark("消息提示字段")
@ActionDefaultTestValue(value = "soap-env:Envelope.soap-env:Body.n0:ZFI_OA_DOC_POSTINGResponse.ES_OA_OUTPUT.MESSAGE")
private String messageField;
@Override @Override
public void doSubmit(String requestId, String billTable, int workflowId, User user, RequestInfo requestInfo) { public void doSubmit(String requestId, String billTable, int workflowId, User user, RequestInfo requestInfo) {
String xml = "";
String response = "";
String url = "";
String error = "";
boolean success = true;
try { try {
MainRequestConfig config = service.getRequestConfig(uniqueCode, billTable); MainRequestConfig config = service.getRequestConfig(uniqueCode, billTable);
String xml = service.convertXml(config, requestId, billTable); url = config.getRequestUrl();
String response = service.sendToSap(); xml = service.convertXml(config, requestId, billTable);
pool.execute(()->{ response = service.sendToSap(config.getRequestUrl(), xml);
try { service.parseResponse(response, successField, successVal, messageField);
service.logToOA(modelId, config.getRequestUrl(), requestId, xml, response);
}catch (Exception e){
log.error("日志数据写入建模失败! " + e.getMessage());
}
});
}catch (Exception e){ }catch (Exception e){
log.error("流程数据推送SAP error : " + e.getMessage()); log.error("流程数据推送SAP error : " + e.getMessage());
error = e.getMessage();
success = false;
}
try {
service.logToOA(modelId, url, requestId, xml, response, error);
}catch (Exception e){
log.error("日志数据写入建模失败! " + e.getMessage());
}
if(!success){
throw new CustomerException("WorkflowToSap Action execute error : " + error);
} }
} }
} }

View File

@ -11,6 +11,9 @@ import lombok.Data;
*/ */
@Data @Data
public class DetailRequestConfig { public class DetailRequestConfig {
@SqlDbFieldAnn("nodeType")
@SqlOracleDbFieldAnn("NODETYPE")
private String nodeType;
@SqlDbFieldAnn("paramName") @SqlDbFieldAnn("paramName")
@SqlOracleDbFieldAnn("PARAMNAME") @SqlOracleDbFieldAnn("PARAMNAME")
private String paramName; private String paramName;

View File

@ -11,6 +11,7 @@ import weaver.xuanran.wang.eighty_five_degreec.sap.entity.eneity.MainRequestConf
public interface WorkflowToSapService { public interface WorkflowToSapService {
MainRequestConfig getRequestConfig(String uniqueCode, String tableName); MainRequestConfig getRequestConfig(String uniqueCode, String tableName);
String convertXml(MainRequestConfig config, String requestId, String tableName); String convertXml(MainRequestConfig config, String requestId, String tableName);
String sendToSap(); String sendToSap(String url, String xml);
void logToOA(String modelId, String url, String requestId, String requestXml, String response); String parseResponse(String response, String responseField, String successField, String messageField);
void logToOA(String modelId, String url, String requestId, String requestXml, String response, String error);
} }

View File

@ -1,6 +1,11 @@
package weaver.xuanran.wang.eighty_five_degreec.sap.service.impl; package weaver.xuanran.wang.eighty_five_degreec.sap.service.impl;
import aiyh.utils.Util; import aiyh.utils.Util;
import aiyh.utils.excention.CustomerException;
import org.apache.log4j.Logger;
import org.json.JSONObject;
import org.json.XML;
import weaver.xuanran.wang.common.util.CusData2OA;
import weaver.xuanran.wang.common.util.CusInfoToOAUtil; import weaver.xuanran.wang.common.util.CusInfoToOAUtil;
import weaver.xuanran.wang.eighty_five_degreec.sap.entity.eneity.MainRequestConfig; import weaver.xuanran.wang.eighty_five_degreec.sap.entity.eneity.MainRequestConfig;
import weaver.xuanran.wang.eighty_five_degreec.sap.service.WorkflowToSapService; import weaver.xuanran.wang.eighty_five_degreec.sap.service.WorkflowToSapService;
@ -8,6 +13,7 @@ import weaver.xuanran.wang.eighty_five_degreec.sap.util.ReadConfigUtil;
import java.util.Collections; import java.util.Collections;
import java.util.HashMap; import java.util.HashMap;
import java.util.Map;
/** /**
@ -18,7 +24,7 @@ import java.util.HashMap;
*/ */
public class WorkflowToSapServiceImpl implements WorkflowToSapService { public class WorkflowToSapServiceImpl implements WorkflowToSapService {
private final ReadConfigUtil configUtil = new ReadConfigUtil(); private final ReadConfigUtil configUtil = new ReadConfigUtil();
private final Logger log = Util.getLogger();
@Override @Override
public MainRequestConfig getRequestConfig(String uniqueCode, String tableName) { public MainRequestConfig getRequestConfig(String uniqueCode, String tableName) {
return configUtil.getConfigByUniqueCode(uniqueCode, tableName); return configUtil.getConfigByUniqueCode(uniqueCode, tableName);
@ -30,20 +36,40 @@ public class WorkflowToSapServiceImpl implements WorkflowToSapService {
} }
@Override @Override
public String sendToSap() { public String sendToSap(String url, String xml) {
// TODO sap接口调用方式暂时搞不了 return configUtil.callSap(url, xml);
return ""; }
@Override
public String parseResponse(String response, String successField, String successVal, String messageField) {
String responseVal;
JSONObject xmlResponseObj;
try {
xmlResponseObj = XML.toJSONObject(response);
}catch (Exception e){
throw new CustomerException("xml to jsonObj error : " + e.getMessage());
}
Map<String, Object> responseMap = com.alibaba.fastjson.JSONObject.parseObject(xmlResponseObj.toString(), Map.class);
responseVal = configUtil.parseMap(responseMap, successField);
if(!successVal.equals(responseVal)){
throw new CustomerException("successVal not equals responseVal! current responseVal is : "
+ responseVal + ", the successVal is " + successVal + ", responseMsg is " + configUtil.parseMap(responseMap, messageField));
}
return responseVal;
} }
@Override @Override
public void logToOA(String modelId, String url, String requestId, public void logToOA(String modelId, String url, String requestId,
String requestXml, String response) { String requestXml, String response, String error) {
HashMap<String, Object> params = new HashMap<>(); HashMap<String, Object> params = new HashMap<>();
params.put("requestUrlAndFunName", url); params.put("requestUrl", url);
params.put("reqId", requestId); params.put("reqId", requestId);
params.put("requestXml", requestXml); params.put("requestXml", requestXml);
params.put("responseCode",""); params.put("responseCode","");
params.put("erpResponse", response); params.put("sapResponse", response);
CusInfoToOAUtil.getDataId(Util.getIntValue(modelId, -1), params, "select id from #{tableName} where reqId = ?", Collections.singletonList(requestId)); params.put("error", error);
log.info("写入日志参数 : " + com.alibaba.fastjson.JSONObject.toJSONString(params));
CusData2OA.writeToModel(modelId, "select id from #{tableName} where reqId = " + requestId, params);
} }
} }

View File

@ -1,5 +1,6 @@
package weaver.xuanran.wang.eighty_five_degreec.sap.util; package weaver.xuanran.wang.eighty_five_degreec.sap.util;
import aiyh.utils.excention.CustomerException;
import com.google.common.base.Strings; import com.google.common.base.Strings;
import org.apache.commons.collections.CollectionUtils; import org.apache.commons.collections.CollectionUtils;
import org.apache.commons.lang3.StringUtils; import org.apache.commons.lang3.StringUtils;
@ -12,11 +13,10 @@ import weaver.xuanran.wang.eighty_five_degreec.sap.entity.eneity.DetailRequestCo
import weaver.xuanran.wang.eighty_five_degreec.sap.entity.eneity.MainRequestConfig; import weaver.xuanran.wang.eighty_five_degreec.sap.entity.eneity.MainRequestConfig;
import weaver.zwl.common.ToolUtil; import weaver.zwl.common.ToolUtil;
import java.io.BufferedReader; import java.io.*;
import java.io.File;
import java.io.FileInputStream;
import java.io.InputStreamReader;
import java.lang.reflect.Field; import java.lang.reflect.Field;
import java.net.HttpURLConnection;
import java.net.URL;
import java.nio.charset.StandardCharsets; import java.nio.charset.StandardCharsets;
import java.security.SecureRandom; import java.security.SecureRandom;
import java.text.ParseException; import java.text.ParseException;
@ -55,7 +55,7 @@ public class ReadConfigUtil extends ToolUtil {
} }
int mainId = Util.getIntValue(res.getId()); int mainId = Util.getIntValue(res.getId());
// 配置明细表 // 配置明细表
sql = "select paramName,paramType,parentName,getValueType,workflowField,valueContext,fv.tableName," + sql = "select nodeType,paramName,paramType,parentName,getValueType,workflowField,valueContext,fv.tableName," +
" fv.id fieldId,fv.fieldname,fv.indexdesc " + " fv.id fieldId,fv.fieldname,fv.indexdesc " +
" from uf_memsic_createXml_dt1 config " + " from uf_memsic_createXml_dt1 config " +
" left join workflow_field_table_view fv on config.workflowField = fv.id " + " left join workflow_field_table_view fv on config.workflowField = fv.id " +
@ -88,7 +88,7 @@ public class ReadConfigUtil extends ToolUtil {
* @return * @return
**/ **/
public static <T> T getInstance(RecordSet queryRs, Class<T> clazz) { public static <T> T getInstance(RecordSet queryRs, Class<T> clazz) {
T res = null; T res;
try { try {
res = clazz.newInstance(); res = clazz.newInstance();
Field[] fields = clazz.getDeclaredFields(); Field[] fields = clazz.getDeclaredFields();
@ -443,15 +443,35 @@ public class ReadConfigUtil extends ToolUtil {
// 明细 // 明细
String[] detailIdArr = detailIndex.split(","); String[] detailIdArr = detailIndex.split(",");
StringBuilder detailSb = new StringBuilder(); StringBuilder detailSb = new StringBuilder();
for (String detailId : detailIdArr) { for (String detailId : detailIdArr) {
String nodeName;
List<DetailRequestConfig> nodeList = requestConfigList.stream()
.filter(item -> "0".equals(item.getNodeType())).collect(Collectors.toList());
if(CollectionUtils.isNotEmpty(nodeList)){
nodeName = nodeList.get(0).getParamName();
} else {
nodeName = "";
}
List<DetailRequestConfig> detailCollect = requestConfigList.stream() List<DetailRequestConfig> detailCollect = requestConfigList.stream()
.filter(item -> "detailRecord".equals(item.getParentName()) .filter(item -> {
).collect(Collectors.toList()); if(StringUtils.isNotBlank(nodeName)){
return nodeName.equals(item.getParentName());
}else {
return "detailRecord".equals(item.getParentName());
}
}).collect(Collectors.toList());
String detailSql = "select * from " + tableName + "_dt" + detailId + " where mainid = ?"; String detailSql = "select * from " + tableName + "_dt" + detailId + " where mainid = ?";
if (detailRs.executeQuery(detailSql, mainId)) { if (detailRs.executeQuery(detailSql, mainId)) {
int count = 1; int count = 1;
while (detailRs.next()) { while (detailRs.next()) {
if(StringUtils.isNotBlank(nodeName)){
detailSb.append("<").append(nodeName).append(">\n");
}
appendXml(detailSb, detailCollect, mainRs, detailRs, count++); appendXml(detailSb, detailCollect, mainRs, detailRs, count++);
if(StringUtils.isNotBlank(nodeName)){
detailSb.append("</").append(nodeName).append(">\n");
}
} }
} }
} }
@ -474,7 +494,7 @@ public class ReadConfigUtil extends ToolUtil {
.append(paramName) .append(paramName)
.append(">") .append(">")
.append(getParamValue(requestConfig, mainRs, detailRs,count)) .append(getParamValue(requestConfig, mainRs, detailRs,count))
.append("<") .append("</")
.append(paramName) .append(paramName)
.append(">") .append(">")
.append("\n"); .append("\n");
@ -544,22 +564,80 @@ public class ReadConfigUtil extends ToolUtil {
* @return * @return
*/ */
public String parseMap(Map<String, Object> responseMap, String responseField){ public String parseMap(Map<String, Object> responseMap, String responseField){
String[] strArr = responseField.split("\\."); try {
int i = 0; String[] strArr = responseField.split("\\.");
while (i < strArr.length - 1){ int i = 0;
Object o = responseMap.get(strArr[i]); while (i < strArr.length - 1){
if(o instanceof Map){ Object o = responseMap.get(strArr[i]);
responseMap = (Map<String, Object>) o; if(o instanceof Map){
}else if(o instanceof List){ responseMap = (Map<String, Object>) o;
List<Map<String, Object>> list = (List<Map<String, Object>>) o; }else if(o instanceof List){
if(CollectionUtils.isEmpty(list)){ List<Map<String, Object>> list = (List<Map<String, Object>>) o;
return ""; if(CollectionUtils.isEmpty(list)){
} return "";
responseMap = list.get(0); }
} responseMap = list.get(0);
i++; }
} i++;
return Util.null2String(responseMap.get(strArr[strArr.length - 1])); }
return Util.null2String(responseMap.get(strArr[strArr.length - 1]));
}catch (Exception e){
throw new CustomerException("parseMap error : " + e.getMessage());
}
} }
/**
* <h1>sap</h1>
* @author xuanran.wang
* @dateTime 2023/5/15 14:05
* @param url
* @param xml xml
* @return
**/
public String callSap(String url, String xml){
OutputStreamWriter writer = null;
BufferedReader reader = null;
try {
String userName = aiyh.utils.Util.null2DefaultStr(getSystemParamValue("sapUserName"),"");
String password = aiyh.utils.Util.null2DefaultStr(getSystemParamValue("sapPassword"),"");
log.info("callSap userName : [ " + userName + " ], password : [ " + password + " ]");
String authString = userName + ":" + password;
byte[] authEncBytes = Base64.getEncoder().encode(authString.getBytes());
String authStringEnc = new String(authEncBytes);
URL serviceUrl = new URL(url);
HttpURLConnection connection = (HttpURLConnection) serviceUrl.openConnection();
connection.setRequestMethod("POST");
connection.setRequestProperty("Content-Type", "text/xml; charset=utf-8");
connection.setRequestProperty("Authorization", "Basic " + authStringEnc);
connection.setDoOutput(true);
writer = new OutputStreamWriter(connection.getOutputStream(), StandardCharsets.UTF_8);
writer.write(xml);
writer.close();
reader = new BufferedReader(new InputStreamReader(connection.getInputStream(), StandardCharsets.UTF_8));
String line;
StringBuilder responseBuilder = new StringBuilder();
while ((line = reader.readLine()) != null) {
responseBuilder.append(line);
}
reader.close();
String response = responseBuilder.toString();
if(StringUtils.isBlank(response)){
throw new CustomerException("sap response is empty!");
}
return response;
}catch (Exception e){
throw new CustomerException("callSap error : " + e.getMessage());
}finally {
try {
if(writer != null){
writer.close();
}
if(reader != null){
reader.close();
}
}catch (Exception e){
log.error("关流异常 : " + e.getMessage());
}
}
}
} }

View File

@ -35,6 +35,8 @@ public class ShBigDataUtil {
WHILTE_LIST.add("loginErrorSendRedirectUrl"); WHILTE_LIST.add("loginErrorSendRedirectUrl");
WHILTE_LIST.add("getUserIdDebug"); WHILTE_LIST.add("getUserIdDebug");
WHILTE_LIST.add("getUserIdDebugOutKey"); WHILTE_LIST.add("getUserIdDebugOutKey");
WHILTE_LIST.add("ssoInterfaceCompareField");
WHILTE_LIST.add("ssoOaCompareField");
} }
/** /**

View File

@ -0,0 +1,21 @@
package xuanran.wang;
import aiyh.utils.GenerateFileUtil;
import basetest.BaseTest;
import org.junit.Test;
import weaver.xuanran.wang.eighty_five_degreec.sap.action.WorkflowToSap;
/**
* <h1></h1>
*
* @author xuanran.wang
* @date 2023/5/19 16:48
*/
public class NormalTest extends BaseTest {
@Test
public void testWord(){
GenerateFileUtil.createActionDocument(WorkflowToSap.class);
}
}

View File

@ -3,6 +3,7 @@ package xuanran.wang.big_data;
import aiyh.utils.Util; import aiyh.utils.Util;
import basetest.BaseTest; import basetest.BaseTest;
import com.alibaba.fastjson.JSONObject; import com.alibaba.fastjson.JSONObject;
import com.api.xuanran.wang.sh_bigdata.sso.mapper.OtherSystemToOAMapper;
import com.icbc.api.internal.apache.http.impl.cookie.S; import com.icbc.api.internal.apache.http.impl.cookie.S;
import com.weaver.esb.server.cache.ResourceComInfo; import com.weaver.esb.server.cache.ResourceComInfo;
import emo.macro.ob.OB; import emo.macro.ob.OB;
@ -13,6 +14,7 @@ import weaver.email.EmailWorkRunnable;
import weaver.general.TimeUtil; import weaver.general.TimeUtil;
import weaver.xuanran.wang.common.util.CusInfoToOAUtil; import weaver.xuanran.wang.common.util.CusInfoToOAUtil;
import weaver.xuanran.wang.sh_bigdata.common.entity.CusSuccess; import weaver.xuanran.wang.sh_bigdata.common.entity.CusSuccess;
import weaver.xuanran.wang.sh_bigdata.common.util.ShBigDataUtil;
import weaver.xuanran.wang.sh_bigdata.org_hrm_async.OrganizationHrmSyncFromOtherSys; import weaver.xuanran.wang.sh_bigdata.org_hrm_async.OrganizationHrmSyncFromOtherSys;
import weaver.xuanran.wang.sh_bigdata.org_hrm_async.entity.OrgHrmAsyncConfigMain; import weaver.xuanran.wang.sh_bigdata.org_hrm_async.entity.OrgHrmAsyncConfigMain;
import weaver.xuanran.wang.sh_bigdata.org_hrm_async.entity.OtherSysDepartment; import weaver.xuanran.wang.sh_bigdata.org_hrm_async.entity.OtherSysDepartment;
@ -32,369 +34,366 @@ import java.util.stream.Collectors;
* @date 2023/4/10 10:49 * @date 2023/4/10 10:49
*/ */
public class BigDataTest extends BaseTest { public class BigDataTest extends BaseTest {
private final OrgHrmAsyncServiceImpl orgHrmAsyncService = new OrgHrmAsyncServiceImpl(); // private final OrgHrmAsyncServiceImpl orgHrmAsyncService = new OrgHrmAsyncServiceImpl();
private final OrgHrmAsyncApiService orgHrmAsyncApiService = new OrgHrmAsyncApiServiceImpl(); // private final OrgHrmAsyncApiService orgHrmAsyncApiService = new OrgHrmAsyncApiServiceImpl();
private final List<String> departmentWhiteList; // private final List<String> departmentWhiteList;
private final List<String> subCompanyWhiteList; // private final List<String> subCompanyWhiteList;
private final OrgHrmAsyncMapper orgHrmAsyncMapper = Util.getMapper(OrgHrmAsyncMapper.class); // private final OrgHrmAsyncMapper orgHrmAsyncMapper = Util.getMapper(OrgHrmAsyncMapper.class);
//
{ // {
departmentWhiteList = orgHrmAsyncMapper.selectCusDepart(); // departmentWhiteList = orgHrmAsyncMapper.selectCusDepart();
subCompanyWhiteList = orgHrmAsyncMapper.selectCusSubCompany(); // subCompanyWhiteList = orgHrmAsyncMapper.selectCusSubCompany();
} // }
//
@Test // @Test
public void testA() throws IOException { // public void testA() throws IOException {
// List<OtherSysDepartment> rootDepList = departmentInfo //// List<OtherSysDepartment> rootDepList = departmentInfo
// .stream() //// .stream()
// .filter(item -> 1 == item.getHasChild()) //// .filter(item -> 1 == item.getHasChild())
// .sorted(Comparator.comparing(OtherSysDepartment::getId)) //// .sorted(Comparator.comparing(OtherSysDepartment::getId))
// .collect(Collectors.toList()); //// .collect(Collectors.toList());
// for (OtherSysDepartment department : rootDepList) { //// for (OtherSysDepartment department : rootDepList) {
// setChildList(department, departmentInfo); //// setChildList(department, departmentInfo);
//// }
//// List<OtherSysDepartment> departmentInfo = orgHrmAsyncApiService.getDepartmentInfo();
//// List<OtherSysDepartment> convert = Util.listToTree(departmentInfo,
//// OtherSysDepartment::getId, OtherSysDepartment::getParentid,
//// OtherSysDepartment::getChildList, OtherSysDepartment::setChildList,
//// parentid -> parentid == -1);
//// System.out.println("convert => " + JSONObject.toJSONString(convert, SerializerFeature.DisableCircularReferenceDetect));
//// List<OtherSysDepartment> hrmSubCompany = new ArrayList<>();
//// List<OtherSysDepartment> hrmDepartment = new ArrayList<>();
//// int maxLevel = Util.getIntValue(ShBigDataUtil.getPropertiesValByKey("maxLevel"), 3);
//// System.out.println(countNodes(convert.get(0)));
//// parseSubCompanyAndDepartment(convert, 0,maxLevel, hrmSubCompany, hrmDepartment);
//// parseSubCompanyAndDepartment(convert, hrmSubCompany);
//// System.out.println("hrmSubCompany => " + hrmSubCompany.size());
//// System.out.println("convertLevel => " + JSONObject.toJSONString(convert, SerializerFeature.DisableCircularReferenceDetect));
//// System.out.println("hrmSubCompany => " + JSONObject.toJSONString(hrmSubCompany));
//// System.out.println("hrmDepartment => " + JSONObject.toJSONString(hrmDepartment));
//// orgHrmAsyncService.asyncDepartment();
// Map res = JSONObject.parseObject("{\n" +
// "\t\t\"code\":0,\n" +
// "\t\t\"msg\":\"ok\",\n" +
// "\t\t\"data\":{\n" +
// "\t\t\t\"UserId\":\"13800000000\",\n" +
// "\t\t\t\"errcode\":0,\n" +
// "\t\t\t\"errmsg\":\"ok\",\n" +
// "\t\t\t\"id\":109,\n" +
// "\t\t\t\"userid\":\"13800000000\",\n" +
// "\t\t\t\"name\":\"祝芳\",\n" +
// "\t\t\t\"mobile\":\"13800000000\",\n" +
// "\t\t\t\"gender\":1,\n" +
// "\t\t\t\"department\":[\n" +
// "\t\t\t\t539\n" +
// "\t\t\t],\n" +
// "\t\t\t\"order\":[\n" +
// "\t\t\t\t6\n" +
// "\t\t\t]\n" +
// "\t\t}\n" +
// "\t}", Map.class);
// System.out.println(getRes(res));
// }
//
// public String getRes(Map res){
// return (String) parseRes(res, cusSuccess);
// }
//
// private final CusSuccess cusSuccess = CusSuccess.builder()
// .successField("code")
// .successValue(0)
// .errorMsg("msg")
// .dataKey("data.id")
// .build();
//
// public <T> T parseRes(Map<String, Object> response, CusSuccess cusSuccess){
// String[] split = Util.null2DefaultStr(cusSuccess.getDataKey(),"").split("\\.");
// int len = split.length;
// if(len == 0 || StringUtils.isBlank(cusSuccess.getDataKey())){
// return (T)response;
// } // }
// List<OtherSysDepartment> departmentInfo = orgHrmAsyncApiService.getDepartmentInfo(); // for (int i = 0; i < len - 1; i++) {
// List<OtherSysDepartment> convert = Util.listToTree(departmentInfo, // response = (Map) response.get(split[i]);
// OtherSysDepartment::getId, OtherSysDepartment::getParentid, // }
// OtherSysDepartment::getChildList, OtherSysDepartment::setChildList, // return (T) response.get(split[len - 1]);
// parentid -> parentid == -1); // }
// System.out.println("convert => " + JSONObject.toJSONString(convert, SerializerFeature.DisableCircularReferenceDetect)); //
// List<OtherSysDepartment> hrmSubCompany = new ArrayList<>(); // @Test
// List<OtherSysDepartment> hrmDepartment = new ArrayList<>(); // public void testMap(){
// int maxLevel = Util.getIntValue(ShBigDataUtil.getPropertiesValByKey("maxLevel"), 3); // List<Map<String, Object>> list = orgHrmAsyncApiService.getDepartmentInfoMap();
// System.out.println(countNodes(convert.get(0))); // // 将列表转换为以id为键的Map
// parseSubCompanyAndDepartment(convert, 0,maxLevel, hrmSubCompany, hrmDepartment); // List<Map<String, Object>> tree = convertListToTree(list);
// parseSubCompanyAndDepartment(convert, hrmSubCompany); // List<Map<String, Object>> department = new ArrayList<>();
// System.out.println("hrmSubCompany => " + hrmSubCompany.size()); // List<Map<String, Object>> subCompany = new ArrayList<>();
// System.out.println("convertLevel => " + JSONObject.toJSONString(convert, SerializerFeature.DisableCircularReferenceDetect)); // orgHrmAsyncService.parseSubCompanyAndDepartmentMap(tree, 0, 3, department, subCompany);
// System.out.println("hrmSubCompany => " + JSONObject.toJSONString(hrmSubCompany)); // System.out.println(JSONObject.toJSONString(department));
// System.out.println("hrmDepartment => " + JSONObject.toJSONString(hrmDepartment)); // System.out.println(JSONObject.toJSONString(subCompany));
// orgHrmAsyncService.asyncDepartment(); // }
Map res = JSONObject.parseObject("{\n" + //
"\t\t\"code\":0,\n" + // @Test
"\t\t\"msg\":\"ok\",\n" + // public void testMapper(){
"\t\t\"data\":{\n" + //// System.setProperty("_isDebug", "false");
"\t\t\t\"UserId\":\"13800000000\",\n" + //// System.out.println("分部执行结果 => " + JSONObject.toJSONString(orgHrmAsyncService.asyncOrgDep(0)));
"\t\t\t\"errcode\":0,\n" + //// System.out.println("部门执行结果 => " + JSONObject.toJSONString(orgHrmAsyncService.asyncOrgDep(1)));
"\t\t\t\"errmsg\":\"ok\",\n" + //// List<OrgHrmAsyncConfigMain> orgHrmAsyncConfigMains = orgHrmAsyncMapper.selectSubCompanyAsyncConfig(2);
"\t\t\t\"id\":109,\n" + //// System.out.println(JSONObject.toJSONString(orgHrmAsyncConfigMains));
"\t\t\t\"userid\":\"13800000000\",\n" + // ArrayList<String> ids = new ArrayList<>();
"\t\t\t\"name\":\"祝芳\",\n" + // for (int i = 0; i < 100; i++) {
"\t\t\t\"mobile\":\"13800000000\",\n" + // ids.add("'" + UUID.randomUUID().toString().replace("-","") + "'");
"\t\t\t\"gender\":1,\n" + // }
"\t\t\t\"department\":[\n" + // String updateDelStatus = "update cus_fielddata set field0 = 1 where " +
"\t\t\t\t539\n" + // weaver.general.Util.getSubINClause(StringUtils.join(ids,","),"field2","not in");
"\t\t\t],\n" + // System.out.println(updateDelStatus);
"\t\t\t\"order\":[\n" + // }
"\t\t\t\t6\n" + //
"\t\t\t]\n" + // @Test
"\t\t}\n" + // public void testAsync(){
"\t}", Map.class); // System.out.println(TimeUtil.getCurrentTimeString());
System.out.println(getRes(res)); // OrganizationHrmSyncFromOtherSys async = new OrganizationHrmSyncFromOtherSys();
} // async.SynTimingToOASubCompany();
// async.SynTimingToOADepartment();
public String getRes(Map res){ // HashMap synResult = async.getSynResult();
return (String) parseRes(res, cusSuccess); // System.out.println("res => \n" + JSONObject.toJSONString(synResult));
} // System.out.println(TimeUtil.getCurrentTimeString());
// }
private final CusSuccess cusSuccess = CusSuccess.builder() //
.successField("code") // @Test
.successValue(0) // public void testExtra(){
.errorMsg("msg") // orgHrmAsyncService.asyncHrm();
.dataKey("data.id") // }
.build(); //
// public List<Map<String, Object>> convertListToTree(List<Map<String, Object>> list){
public <T> T parseRes(Map<String, Object> response, CusSuccess cusSuccess){ // Map<Integer, Map<String, Object>> map = new HashMap<>();
String[] split = Util.null2DefaultStr(cusSuccess.getDataKey(),"").split("\\."); // for (Map<String, Object> item : list) {
int len = split.length; // map.put((Integer) item.get("id"), item);
if(len == 0 || StringUtils.isBlank(cusSuccess.getDataKey())){ // }
return (T)response; //
} // // 构建树形结构
for (int i = 0; i < len - 1; i++) { // List<Map<String, Object>> tree = new ArrayList<>();
response = (Map) response.get(split[i]); // for (Map<String, Object> item : list) {
} // int parentId = (Integer) item.get("parentid");
return (T) response.get(split[len - 1]); // if (parentId == -1) {
} // // 添加根节点
// tree.add(item);
@Test // } else {
public void testMap(){ // // 添加子节点
List<Map<String, Object>> list = orgHrmAsyncApiService.getDepartmentInfoMap(); // Map<String, Object> parent = map.get(parentId);
// 将列表转换为以id为键的Map // if (parent != null) {
List<Map<String, Object>> tree = convertListToTree(list); // List<Map<String, Object>> childList = (List<Map<String, Object>>) parent.get("childList");
List<Map<String, Object>> department = new ArrayList<>(); // if (childList == null) {
List<Map<String, Object>> subCompany = new ArrayList<>(); // childList = new ArrayList<>();
orgHrmAsyncService.parseSubCompanyAndDepartmentMap(tree, 0, 3, department, subCompany); // parent.put("childList", childList);
System.out.println(JSONObject.toJSONString(department)); // }
System.out.println(JSONObject.toJSONString(subCompany)); // childList.add(item);
} // }
// }
@Test // }
public void testMapper(){ // return tree;
// System.setProperty("_isDebug", "false"); // }
// System.out.println("分部执行结果 => " + JSONObject.toJSONString(orgHrmAsyncService.asyncOrgDep(0))); // public int countNodes(OtherSysDepartment node) {
// System.out.println("部门执行结果 => " + JSONObject.toJSONString(orgHrmAsyncService.asyncOrgDep(1))); // int count = 1; // 当前节点也算一条数据
// List<OrgHrmAsyncConfigMain> orgHrmAsyncConfigMains = orgHrmAsyncMapper.selectSubCompanyAsyncConfig(2); // List<OtherSysDepartment> childList = node.getChildList();
// System.out.println(JSONObject.toJSONString(orgHrmAsyncConfigMains)); // if (CollectionUtils.isNotEmpty(childList)) {
ArrayList<String> ids = new ArrayList<>(); // for (OtherSysDepartment otherSysDepartment : childList) {
for (int i = 0; i < 100; i++) { // count += countNodes(otherSysDepartment);
ids.add("'" + UUID.randomUUID().toString().replace("-","") + "'"); // }
} // }
String updateDelStatus = "update cus_fielddata set field0 = 1 where " + // return count;
weaver.general.Util.getSubINClause(StringUtils.join(ids,","),"field2","not in"); // }
System.out.println(updateDelStatus); //
} // public int countNodes(Map<String, Object> node) {
// int count = 1; // 当前节点也算一条数据
@Test // List<Map<String, Object>> childList = (List<Map<String, Object>>) node.get("childList");
public void testAsync(){ // if (CollectionUtils.isNotEmpty(childList)) {
System.out.println(TimeUtil.getCurrentTimeString()); // for (Map<String, Object> map : childList) {
OrganizationHrmSyncFromOtherSys async = new OrganizationHrmSyncFromOtherSys(); // count += countNodes(map);
async.SynTimingToOASubCompany(); // }
async.SynTimingToOADepartment(); // }
HashMap synResult = async.getSynResult(); // return count;
System.out.println("res => \n" + JSONObject.toJSONString(synResult)); // }
System.out.println(TimeUtil.getCurrentTimeString()); //
} //
// /**
@Test // * <h1>解析部门or分部</h1>
public void testExtra(){ // * @author xuanran.wang
orgHrmAsyncService.asyncHrm(); // * @dateTime 2023/4/10 12:13
} // * @param list 树形集合
// * @param hrmDepartment 部门
public List<Map<String, Object>> convertListToTree(List<Map<String, Object>> list){ // **/
Map<Integer, Map<String, Object>> map = new HashMap<>(); // public void parseSubCompanyAndDepartment(List<OtherSysDepartment> list, List<OtherSysDepartment> hrmDepartment){
for (Map<String, Object> item : list) { // for (OtherSysDepartment department : list) {
map.put((Integer) item.get("id"), item); // List<OtherSysDepartment> childList = department.getChildList();
} // if(CollectionUtils.isNotEmpty(childList)){
// parseSubCompanyAndDepartment(childList,hrmDepartment);
// 构建树形结构 // department.setChildList(null);
List<Map<String, Object>> tree = new ArrayList<>(); // }
for (Map<String, Object> item : list) { // hrmDepartment.add(department);
int parentId = (Integer) item.get("parentid"); // }
if (parentId == -1) { // }
// 添加根节点 //
tree.add(item); //
} else { // /**
// 添加子节点 // * <h1>解析部门or分部</h1>
Map<String, Object> parent = map.get(parentId); // * @author xuanran.wang
if (parent != null) { // * @dateTime 2023/4/10 12:13
List<Map<String, Object>> childList = (List<Map<String, Object>>) parent.get("childList"); // * @param list 树形集合
if (childList == null) { // * @param n 层级
childList = new ArrayList<>(); // * @param hrmSubCompany 分部
parent.put("childList", childList); // * @param hrmDepartment 部门
} // **/
childList.add(item); // public void parseSubCompanyAndDepartment(List<OtherSysDepartment> list, int n, int maxLevel,List<OtherSysDepartment> hrmSubCompany, List<OtherSysDepartment> hrmDepartment){
} // n++;
} // for (OtherSysDepartment department : list) {
} // department.setLevel(n);
return tree; // List<OtherSysDepartment> childList = department.getChildList();
} // String departmentId = department.getId() + "";
public int countNodes(OtherSysDepartment node) { // if(CollectionUtils.isNotEmpty(childList)){
int count = 1; // 当前节点也算一条数据 // List<String> collect = department.getChildList().stream().map(item -> Util.null2DefaultStr(item.getId(), "")).collect(Collectors.toList());
List<OtherSysDepartment> childList = node.getChildList(); // if(departmentWhiteList.contains(departmentId)){
if (CollectionUtils.isNotEmpty(childList)) { // departmentWhiteList.addAll(collect);
for (OtherSysDepartment otherSysDepartment : childList) { // }else if(subCompanyWhiteList.contains(departmentId)){
count += countNodes(otherSysDepartment); // subCompanyWhiteList.addAll(collect);
} // }
} // parseSubCompanyAndDepartment(childList, n, maxLevel, hrmSubCompany, hrmDepartment);
return count; // department.setChildList(null);
} // }
// if(n > maxLevel || departmentWhiteList.contains(departmentId)){
public int countNodes(Map<String, Object> node) { // hrmDepartment.add(department);
int count = 1; // 当前节点也算一条数据 // }else {
List<Map<String, Object>> childList = (List<Map<String, Object>>) node.get("childList"); // hrmSubCompany.add(department);
if (CollectionUtils.isNotEmpty(childList)) { // }
for (Map<String, Object> map : childList) { //
count += countNodes(map); // }
} // }
} //
return count; // @Test
} // public void testParseObj(){
// String json = "{\n" +
// " \"code\":0,\n" +
/** // " \"msg\":\"ok\",\n" +
* <h1>or</h1> // " \"data\":\n" +
* @author xuanran.wang // " {\n" +
* @dateTime 2023/4/10 12:13 // " \"errcode\": 0,\n" +
* @param list // " \"errmsg\": \"ok\",\n" +
* @param hrmDepartment // " \"id\": \"1\",\n" +
**/ // " \"userid\": \"superAdmin\",\n" +
public void parseSubCompanyAndDepartment(List<OtherSysDepartment> list, List<OtherSysDepartment> hrmDepartment){ // " \"name\": \"超级管理员\",\n" +
for (OtherSysDepartment department : list) { // " \"mobile\":\"12345678911\",\n" +
List<OtherSysDepartment> childList = department.getChildList(); // " \"email\":\"123@321.com\",\n" +
if(CollectionUtils.isNotEmpty(childList)){ // " \"gender\":0,\n" +
parseSubCompanyAndDepartment(childList,hrmDepartment); // " \"position\":\"position\",\n" +
department.setChildList(null); // " \"avatarImg\":\"avatarImg\",\n" +
} // " \"workPhone\":\"workPhone\",\n" +
hrmDepartment.add(department); // " \"fixedTelephone\":\"fixedTelephone\",\n" +
} // " \"extName\":\"extName\",\n" +
} // " \"userType\":0,\n" +
// " \"department\": [\n" +
// " 1\n" +
/** // " ],\n" +
* <h1>or</h1> // " \"order\": [\n" +
* @author xuanran.wang // " 0\n" +
* @dateTime 2023/4/10 12:13 // " ],\n" +
* @param list // " \"rank\":\"rank\"\n" +
* @param n // " }\n" +
* @param hrmSubCompany // "}";
* @param hrmDepartment // Map response = JSONObject.parseObject(json, Map.class);
**/ // String obj = Util.null2DefaultStr(getObj("data.id", response),"");
public void parseSubCompanyAndDepartment(List<OtherSysDepartment> list, int n, int maxLevel,List<OtherSysDepartment> hrmSubCompany, List<OtherSysDepartment> hrmDepartment){ // System.out.println("obj => " + obj);
n++; // }
for (OtherSysDepartment department : list) { //
department.setLevel(n); // public <T> T getObj(String dataKey, Map<String, Object> response){
List<OtherSysDepartment> childList = department.getChildList(); // String[] split = Util.null2DefaultStr(dataKey,"").split("\\.");
String departmentId = department.getId() + ""; // int len = split.length;
if(CollectionUtils.isNotEmpty(childList)){ // if(len == 0 || StringUtils.isBlank(dataKey)){
List<String> collect = department.getChildList().stream().map(item -> Util.null2DefaultStr(item.getId(), "")).collect(Collectors.toList()); // return (T)response;
if(departmentWhiteList.contains(departmentId)){ // }
departmentWhiteList.addAll(collect); // for (int i = 0; i < len - 1; i++) {
}else if(subCompanyWhiteList.contains(departmentId)){ // response = (Map) response.get(split[i]);
subCompanyWhiteList.addAll(collect); // }
} // return (T) response.get(split[len - 1]);
parseSubCompanyAndDepartment(childList, n, maxLevel, hrmSubCompany, hrmDepartment); // }
department.setChildList(null); //
} // @Test
if(n > maxLevel || departmentWhiteList.contains(departmentId)){ // public void testMsg(){
hrmDepartment.add(department); // String html = "<!DOCTYPE html>\n" +
}else { // "<html>\n" +
hrmSubCompany.add(department); // "<head>\n" +
} // "\t<title>Investment Calculator</title>\n" +
// "\t<style>\n" +
} // "\t\ttable {\n" +
} // "\t\t\tborder-collapse: collapse;\n" +
// "\t\t\twidth: 80%;\n" +
@Test // "\t\t\tmargin: 0 auto;\n" +
public void testParseObj(){ // "\t\t\tmargin-top: 50px;\n" +
String json = "{\n" + // "\t\t\tmargin-bottom: 50px;\n" +
" \"code\":0,\n" + // "\t\t}\n" +
" \"msg\":\"ok\",\n" + // "\t\tth, td {\n" +
" \"data\":\n" + // "\t\t\tborder: 1px solid black;\n" +
" {\n" + // "\t\t\tpadding: 10px;\n" +
" \"errcode\": 0,\n" + // "\t\t\ttext-align: center;\n" +
" \"errmsg\": \"ok\",\n" + // "\t\t}\n" +
" \"id\": \"1\",\n" + // "\t\tth {\n" +
" \"userid\": \"superAdmin\",\n" + // "\t\t\tbackground-color: #f2f2f2;\n" +
" \"name\": \"超级管理员\",\n" + // "\t\t}\n" +
" \"mobile\":\"12345678911\",\n" + // "\t\t.first-row {\n" +
" \"email\":\"123@321.com\",\n" + // "\t\t\ttext-align: center;\n" +
" \"gender\":0,\n" + // "\t\t\tfont-size: 24px;\n" +
" \"position\":\"position\",\n" + // "\t\t\tfont-weight: bold;\n" +
" \"avatarImg\":\"avatarImg\",\n" + // "\t\t\theight: 50px;\n" +
" \"workPhone\":\"workPhone\",\n" + // "\t\t\tline-height: 50px;\n" +
" \"fixedTelephone\":\"fixedTelephone\",\n" + // "\t\t}\n" +
" \"extName\":\"extName\",\n" + // "\t</style>\n" +
" \"userType\":0,\n" + // "</head>\n" +
" \"department\": [\n" + // "<body>\n" +
" 1\n" + // "\t<table>\n" +
" ],\n" + // "\t\t<tr class=\"first-row\">\n" +
" \"order\": [\n" + // "\t\t\t<td colspan=\"26\">投资试算(场外基金)</td>\n" +
" 0\n" + // "\t\t</tr>\n" +
" ],\n" + // "\t\t<tr>\n" +
" \"rank\":\"rank\"\n" + // "\t\t\t<td>A</td>\n" +
" }\n" + // "\t\t\t<td>B</td>\n" +
"}"; // "\t\t\t<td>C</td>\n" +
Map response = JSONObject.parseObject(json, Map.class); // "\t\t\t<td>D</td>\n" +
String obj = Util.null2DefaultStr(getObj("data.id", response),""); // "\t\t\t<td>E</td>\n" +
System.out.println("obj => " + obj); // "\t\t\t<td>F</td>\n" +
} // "\t\t\t<td>G</td>\n" +
// "\t\t\t<td>H</td>\n" +
public <T> T getObj(String dataKey, Map<String, Object> response){ // "\t\t\t<td>I</td>\n" +
String[] split = Util.null2DefaultStr(dataKey,"").split("\\."); // "\t\t\t<td>J</td>\n" +
int len = split.length; // "\t\t\t<td>K</td>\n" +
if(len == 0 || StringUtils.isBlank(dataKey)){ // "\t\t\t<td>L</td>\n" +
return (T)response; // "\t\t\t<td>M</td>\n" +
} // "\t\t\t\n" +
for (int i = 0; i < len - 1; i++) { // "\t\t</tr>\n" +
response = (Map) response.get(split[i]); // "\t\t<tr>\n" +
} // "\t\t\t<td>Cell A1</td>\n" +
return (T) response.get(split[len - 1]); // "\t\t\t<td>Cell B1</td>\n" +
} // "\t\t\t<td>Cell C1</td>\n" +
// "\t\t\t<td>Cell D1</td>\n" +
@Test // "\t\t\t<td>Cell E1</td>\n" +
public void testMsg(){ // "\t\t\t<td>Cell F1</td>\n" +
String html = "<!DOCTYPE html>\n" + // "\t\t\t<td>Cell G1</td>\n" +
"<html>\n" + // "\t\t\t<td>Cell H1</td>\n" +
"<head>\n" + // "\t\t\t<td>Cell I1</td>\n" +
"\t<title>Investment Calculator</title>\n" + // "\t\t\t<td>Cell J1</td>\n" +
"\t<style>\n" + // "\t\t\t<td>Cell K1</td>\n" +
"\t\ttable {\n" + // "\t\t\t<td>Cell L1</td>\n" +
"\t\t\tborder-collapse: collapse;\n" + // "\t\t\t<td>Cell M1</td>\n" +
"\t\t\twidth: 80%;\n" + // "\t\t\n" +
"\t\t\tmargin: 0 auto;\n" + // "\t\t</tr>\n" +
"\t\t\tmargin-top: 50px;\n" + // " \t</table>\n" +
"\t\t\tmargin-bottom: 50px;\n" + // " </body>\n" +
"\t\t}\n" + // "\n";
"\t\tth, td {\n" + // EmailWorkRunnable.threadModeReminder("3055088966@qq.com,xuanran.wang@weaver.com.cn", "test11", html);
"\t\t\tborder: 1px solid black;\n" + //
"\t\t\tpadding: 10px;\n" + // }
"\t\t\ttext-align: center;\n" + private final OtherSystemToOAMapper otherSystemToOAMapper = Util.getMapper(OtherSystemToOAMapper.class);
"\t\t}\n" +
"\t\tth {\n" +
"\t\t\tbackground-color: #f2f2f2;\n" +
"\t\t}\n" +
"\t\t.first-row {\n" +
"\t\t\ttext-align: center;\n" +
"\t\t\tfont-size: 24px;\n" +
"\t\t\tfont-weight: bold;\n" +
"\t\t\theight: 50px;\n" +
"\t\t\tline-height: 50px;\n" +
"\t\t}\n" +
"\t</style>\n" +
"</head>\n" +
"<body>\n" +
"\t<table>\n" +
"\t\t<tr class=\"first-row\">\n" +
"\t\t\t<td colspan=\"26\">投资试算(场外基金)</td>\n" +
"\t\t</tr>\n" +
"\t\t<tr>\n" +
"\t\t\t<td>A</td>\n" +
"\t\t\t<td>B</td>\n" +
"\t\t\t<td>C</td>\n" +
"\t\t\t<td>D</td>\n" +
"\t\t\t<td>E</td>\n" +
"\t\t\t<td>F</td>\n" +
"\t\t\t<td>G</td>\n" +
"\t\t\t<td>H</td>\n" +
"\t\t\t<td>I</td>\n" +
"\t\t\t<td>J</td>\n" +
"\t\t\t<td>K</td>\n" +
"\t\t\t<td>L</td>\n" +
"\t\t\t<td>M</td>\n" +
"\t\t\t\n" +
"\t\t</tr>\n" +
"\t\t<tr>\n" +
"\t\t\t<td>Cell A1</td>\n" +
"\t\t\t<td>Cell B1</td>\n" +
"\t\t\t<td>Cell C1</td>\n" +
"\t\t\t<td>Cell D1</td>\n" +
"\t\t\t<td>Cell E1</td>\n" +
"\t\t\t<td>Cell F1</td>\n" +
"\t\t\t<td>Cell G1</td>\n" +
"\t\t\t<td>Cell H1</td>\n" +
"\t\t\t<td>Cell I1</td>\n" +
"\t\t\t<td>Cell J1</td>\n" +
"\t\t\t<td>Cell K1</td>\n" +
"\t\t\t<td>Cell L1</td>\n" +
"\t\t\t<td>Cell M1</td>\n" +
"\t\t\n" +
"\t\t</tr>\n" +
" \t</table>\n" +
" </body>\n" +
"\n";
EmailWorkRunnable.threadModeReminder("3055088966@qq.com,xuanran.wang@weaver.com.cn", "test11", html);
}
@Test @Test
public void testG(){ public void testG(){
// String sql =" select case '$t{test1}' when '03' then '场外基金' when '04' then '基金赎回' else '测试下' end"; String oaOutKey = "111";
// HashMap<String, Object> param = new HashMap<>(); String sql = "select id from hrmresource where " + Util.null2DefaultStr(ShBigDataUtil.getPropertiesValByKey("ssoOaCompareField"),"outkey") + " = #{outKey}";
// param.put("test1","04"); int id = otherSystemToOAMapper.selectUserIdByOutKey(sql, oaOutKey);
// String s = orgHrmAsyncMapper.selectCustomerSql(sql, param); log.info("id => " + id);
// System.out.println("s => " + s);
HashMap<String, Object> map = new HashMap<>();
map.put("tiem", new Date());
System.out.println("map => " + JSONObject.toJSONString(map));
} }
} }

View File

@ -1,6 +1,7 @@
package xuanran.wang.cssc; package xuanran.wang.cssc;
import aiyh.utils.excention.CustomerException; import aiyh.utils.excention.CustomerException;
import aiyh.utils.httpUtil.util.HttpUtils;
import basetest.BaseTest; import basetest.BaseTest;
import com.alibaba.fastjson.JSONObject; import com.alibaba.fastjson.JSONObject;
import org.apache.commons.codec.digest.DigestUtils; import org.apache.commons.codec.digest.DigestUtils;
@ -201,4 +202,9 @@ public class FileTest extends BaseTest {
} }
} }
@Test
public void testB(){
HttpUtils httpUtils = new HttpUtils();
}
} }

View File

@ -1,12 +1,24 @@
package xuanran.wang.eighty_five_degreec; package xuanran.wang.eighty_five_degreec;
import aiyh.utils.annotation.PrintParamMark;
import aiyh.utils.annotation.RequiredMark;
import aiyh.utils.excention.CustomerException;
import aiyh.utils.tool.cn.hutool.core.lang.UUID; import aiyh.utils.tool.cn.hutool.core.lang.UUID;
import basetest.BaseTest; import basetest.BaseTest;
import com.alibaba.excel.util.CollectionUtils;
import org.json.JSONException;
import org.json.JSONObject;
import org.json.XML;
import org.junit.Test; import org.junit.Test;
import weaver.general.GCONST;
import weaver.general.Util;
import weaver.xuanran.wang.common.util.CusData2OA; import weaver.xuanran.wang.common.util.CusData2OA;
import weaver.xuanran.wang.eighty_five_degreec.sap.entity.eneity.MainRequestConfig; import weaver.xuanran.wang.eighty_five_degreec.sap.entity.eneity.MainRequestConfig;
import weaver.xuanran.wang.eighty_five_degreec.sap.service.WorkflowToSapService;
import weaver.xuanran.wang.eighty_five_degreec.sap.service.impl.WorkflowToSapServiceImpl;
import weaver.xuanran.wang.eighty_five_degreec.sap.util.ReadConfigUtil; import weaver.xuanran.wang.eighty_five_degreec.sap.util.ReadConfigUtil;
import java.io.File;
import java.util.ArrayList; import java.util.ArrayList;
import java.util.HashMap; import java.util.HashMap;
import java.util.List; import java.util.List;
@ -20,15 +32,116 @@ import java.util.Map;
*/ */
public class SAPTest extends BaseTest { public class SAPTest extends BaseTest {
private final WorkflowToSapService service = new WorkflowToSapServiceImpl();
@Test @Test
public void testXml(){ public void testXml(){
ReadConfigUtil configUtil = new ReadConfigUtil();
String uniqueCode = "test1"; String uniqueCode = "test1";
String tableName = "formtable_main_161"; String billTable = "formtable_main_161";
String requestId = "419420"; String requestId = "419420";
MainRequestConfig config = configUtil.getConfigByUniqueCode(uniqueCode, tableName);
String xml = configUtil.getXml(config, requestId, tableName); String response = "";
System.out.println("xml => \n " + xml); String url = "";
String error = "";
String xml = "";
boolean success = true;
String modelId = "119";
String successField = "soap-env:Envelope.soap-env:Body.n0:ZFI_OA_DOC_POSTINGResponse.ES_OA_OUTPUT.TYPE";
String successVal = "N";
String messageField = "soap-env:Envelope.soap-env:Body.n0:ZFI_OA_DOC_POSTINGResponse.ES_OA_OUTPUT.MESSAGE";
try {
MainRequestConfig config = service.getRequestConfig(uniqueCode, billTable);
url = config.getRequestUrl();
xml = service.convertXml(config, requestId, billTable);
// response = service.sendToSap(config.getRequestUrl(), xml);
response = "<soap-env:Envelope\n" +
" xmlns:soap-env=\"http://schemas.xmlsoap.org/soap/envelope/\">\n" +
" <soap-env:Header/>\n" +
" <soap-env:Body>\n" +
" <n0:ZFI_OA_DOC_POSTINGResponse\n" +
" xmlns:n0=\"urn:sap-com:document:sap:rfc:functions\">\n" +
" <ES_OA_OUTPUT>\n" +
" <ZOAPZ>clbx000003</ZOAPZ>\n" +
" <BELNR/>\n" +
" <BUKRS>1200</BUKRS>\n" +
" <BUDAT>2023-05-01</BUDAT>\n" +
" <BKTXT>t?·???????é??è????¨</BKTXT>\n" +
" <TYPE>E</TYPE>\n" +
" <MESSAGE> 1000 上不存在成本中心 1200180001/2023/05/01 。</MESSAGE>\n" +
" <ERDAT>2023-05-15</ERDAT>\n" +
" <ERZET>13:46:11</ERZET>\n" +
" </ES_OA_OUTPUT>\n" +
" <IT_OA_ITEMS>\n" +
" <item>\n" +
" <ZOAPZ>clbx000002</ZOAPZ>\n" +
" <ZOAXM>1</ZOAXM>\n" +
" <SGTXT>item1</SGTXT>\n" +
" <LIFNR>CN07010001</LIFNR>\n" +
" <HKONT/>\n" +
" <KOSTL/>\n" +
" <PSWBT>123.23</PSWBT>\n" +
" <PSWSL>CNY</PSWSL>\n" +
" <SHKZG>H</SHKZG>\n" +
" <BOAPZ>string..............</BOAPZ>\n" +
" <RESE_FIELD_1>string..............</RESE_FIELD_1>\n" +
" <RESE_FIELD_2>string..............</RESE_FIELD_2>\n" +
" <RESE_FIELD_3>string..............</RESE_FIELD_3>\n" +
" <RESE_FIELD_4>string..............</RESE_FIELD_4>\n" +
" <RESE_FIELD_5>string..............</RESE_FIELD_5>\n" +
" </item>\n" +
" <item>\n" +
" <ZOAPZ>clbx000003</ZOAPZ>\n" +
" <ZOAXM>2</ZOAXM>\n" +
" <SGTXT>item2</SGTXT>\n" +
" <LIFNR/>\n" +
" <HKONT>90010601</HKONT>\n" +
" <KOSTL>1200180001</KOSTL>\n" +
" <PSWBT>100.23</PSWBT>\n" +
" <PSWSL>CNY</PSWSL>\n" +
" <SHKZG>S</SHKZG>\n" +
" <BOAPZ>string..............</BOAPZ>\n" +
" <RESE_FIELD_1>string..............</RESE_FIELD_1>\n" +
" <RESE_FIELD_2>string..............</RESE_FIELD_2>\n" +
" <RESE_FIELD_3>string..............</RESE_FIELD_3>\n" +
" <RESE_FIELD_4>string..............</RESE_FIELD_4>\n" +
" <RESE_FIELD_5>string..............</RESE_FIELD_5>\n" +
" </item>\n" +
" <item>\n" +
" <ZOAPZ>clbx000003</ZOAPZ>\n" +
" <ZOAXM>3</ZOAXM>\n" +
" <SGTXT>item3</SGTXT>\n" +
" <LIFNR/>\n" +
" <HKONT>90010602</HKONT>\n" +
" <KOSTL>1200180001</KOSTL>\n" +
" <PSWBT>23.0</PSWBT>\n" +
" <PSWSL>CNY</PSWSL>\n" +
" <SHKZG>S</SHKZG>\n" +
" <BOAPZ>string..............</BOAPZ>\n" +
" <RESE_FIELD_1>string..............</RESE_FIELD_1>\n" +
" <RESE_FIELD_2>string..............</RESE_FIELD_2>\n" +
" <RESE_FIELD_3>string..............</RESE_FIELD_3>\n" +
" <RESE_FIELD_4>string..............</RESE_FIELD_4>\n" +
" <RESE_FIELD_5>string..............</RESE_FIELD_5>\n" +
" </item>\n" +
" </IT_OA_ITEMS>\n" +
" </n0:ZFI_OA_DOC_POSTINGResponse>\n" +
" </soap-env:Body>\n" +
"</soap-env:Envelope>";
response = service.parseResponse(response, successField, successVal, messageField);
}catch (Exception e){
log.error("流程数据推送SAP error : " + e.getMessage());
error = e.getMessage();
success = false;
}
try {
service.logToOA(modelId, url, requestId, xml, response, error);
}catch (Exception e){
log.error("日志数据写入建模失败! " + e.getMessage());
}
if(!success){
throw new CustomerException("WorkflowToSap Action execute error : " + error);
}
} }
@Test @Test
@ -49,4 +162,149 @@ public class SAPTest extends BaseTest {
List<String> strings = CusData2OA.batchWriteToModel(modelId, sql, list); List<String> strings = CusData2OA.batchWriteToModel(modelId, sql, list);
System.out.println("data => " + strings); System.out.println("data => " + strings);
} }
@Test
public void testResponse() throws JSONException {
String response = "<soap-env:Envelope\n" +
" xmlns:soap-env=\"http://schemas.xmlsoap.org/soap/envelope/\">\n" +
" <soap-env:Header/>\n" +
" <soap-env:Body>\n" +
" <n0:ZFI_OA_DOC_POSTINGResponse\n" +
" xmlns:n0=\"urn:sap-com:document:sap:rfc:functions\">\n" +
" <ES_OA_OUTPUT>\n" +
" <ZOAPZ>clbx000003</ZOAPZ>\n" +
" <BELNR/>\n" +
" <BUKRS>1200</BUKRS>\n" +
" <BUDAT>2023-05-01</BUDAT>\n" +
" <BKTXT>t?·???????é??è????¨</BKTXT>\n" +
" <TYPE>E</TYPE>\n" +
" <MESSAGE> 1000 上不存在成本中心 1200180001/2023/05/01 。</MESSAGE>\n" +
" <ERDAT>2023-05-15</ERDAT>\n" +
" <ERZET>13:46:11</ERZET>\n" +
" </ES_OA_OUTPUT>\n" +
" <IT_OA_ITEMS>\n" +
" <item>\n" +
" <ZOAPZ>clbx000002</ZOAPZ>\n" +
" <ZOAXM>1</ZOAXM>\n" +
" <SGTXT>item1</SGTXT>\n" +
" <LIFNR>CN07010001</LIFNR>\n" +
" <HKONT/>\n" +
" <KOSTL/>\n" +
" <PSWBT>123.23</PSWBT>\n" +
" <PSWSL>CNY</PSWSL>\n" +
" <SHKZG>H</SHKZG>\n" +
" <BOAPZ>string..............</BOAPZ>\n" +
" <RESE_FIELD_1>string..............</RESE_FIELD_1>\n" +
" <RESE_FIELD_2>string..............</RESE_FIELD_2>\n" +
" <RESE_FIELD_3>string..............</RESE_FIELD_3>\n" +
" <RESE_FIELD_4>string..............</RESE_FIELD_4>\n" +
" <RESE_FIELD_5>string..............</RESE_FIELD_5>\n" +
" </item>\n" +
" <item>\n" +
" <ZOAPZ>clbx000003</ZOAPZ>\n" +
" <ZOAXM>2</ZOAXM>\n" +
" <SGTXT>item2</SGTXT>\n" +
" <LIFNR/>\n" +
" <HKONT>90010601</HKONT>\n" +
" <KOSTL>1200180001</KOSTL>\n" +
" <PSWBT>100.23</PSWBT>\n" +
" <PSWSL>CNY</PSWSL>\n" +
" <SHKZG>S</SHKZG>\n" +
" <BOAPZ>string..............</BOAPZ>\n" +
" <RESE_FIELD_1>string..............</RESE_FIELD_1>\n" +
" <RESE_FIELD_2>string..............</RESE_FIELD_2>\n" +
" <RESE_FIELD_3>string..............</RESE_FIELD_3>\n" +
" <RESE_FIELD_4>string..............</RESE_FIELD_4>\n" +
" <RESE_FIELD_5>string..............</RESE_FIELD_5>\n" +
" </item>\n" +
" <item>\n" +
" <ZOAPZ>clbx000003</ZOAPZ>\n" +
" <ZOAXM>3</ZOAXM>\n" +
" <SGTXT>item3</SGTXT>\n" +
" <LIFNR/>\n" +
" <HKONT>90010602</HKONT>\n" +
" <KOSTL>1200180001</KOSTL>\n" +
" <PSWBT>23.0</PSWBT>\n" +
" <PSWSL>CNY</PSWSL>\n" +
" <SHKZG>S</SHKZG>\n" +
" <BOAPZ>string..............</BOAPZ>\n" +
" <RESE_FIELD_1>string..............</RESE_FIELD_1>\n" +
" <RESE_FIELD_2>string..............</RESE_FIELD_2>\n" +
" <RESE_FIELD_3>string..............</RESE_FIELD_3>\n" +
" <RESE_FIELD_4>string..............</RESE_FIELD_4>\n" +
" <RESE_FIELD_5>string..............</RESE_FIELD_5>\n" +
" </item>\n" +
" </IT_OA_ITEMS>\n" +
" </n0:ZFI_OA_DOC_POSTINGResponse>\n" +
" </soap-env:Body>\n" +
"</soap-env:Envelope>";
JSONObject xmlResponseObj = XML.toJSONObject(response);
log.info("接口响应 : \n" + xmlResponseObj);
Map<String, Object> responseMap = com.alibaba.fastjson.JSONObject.parseObject(xmlResponseObj.toString(), Map.class);
System.out.println("responseMap : " + com.alibaba.fastjson.JSONObject.toJSONString(responseMap));
// code = Util.null2String(parseMap(responseMap, RESPONSE_CODE));
// if(!successCode.equals(code)){
// throw new RuntimeException("推送erp接口失败! " + Util.null2String(readConfigUtil.parseMap(responseMap, RESPONSE_DESCRIPTION)));
// }
}
/**
* <h1></h1>
* @param responseMap map
* @param responseField map Response.Execution
* @return
*/
public String parseMap(Map<String, Object> responseMap, String responseField){
String[] strArr = responseField.split("\\.");
int i = 0;
while (i < strArr.length - 1){
Object o = responseMap.get(strArr[i]);
if(o instanceof Map){
responseMap = (Map<String, Object>) o;
}else if(o instanceof List){
List<Map<String, Object>> list = (List<Map<String, Object>>) o;
if(CollectionUtils.isEmpty(list)){
return "";
}
responseMap = list.get(0);
}
i++;
}
return Util.null2String(responseMap.get(strArr[strArr.length - 1]));
}
@Test
public void testB(){
String path = "sap.sap.xml";
System.out.println(parseConfigPath(path));
}
/**
* <h1>xml</h1>
* wxr.memsic.test.xml = /wxr/memsic/test.xml
* @param configFilePath
* @return
*/
public String parseConfigPath(String configFilePath){
StringBuilder filePath = new StringBuilder(GCONST.getSysFilePath());
int beginIndex = configFilePath.indexOf(".");
int endIndex = configFilePath.lastIndexOf(".");
if(beginIndex == endIndex){
filePath.append(configFilePath);
}else {
String[] pathArr = configFilePath.split("\\.");
for (int i = 0; i < pathArr.length - 2; i++) {
if(i != 0){
filePath.append(File.separator);
}
filePath.append(pathArr[i]);
}
filePath.append(File.separator)
.append(pathArr[pathArr.length - 2])
.append(".")
.append(pathArr[pathArr.length - 1]);
}
return filePath.toString();
}
} }

View File

@ -0,0 +1,19 @@
package xuanran.wang.http_test.annotations;
import java.lang.annotation.*;
/**
* <h1></h1>
*
* @author xuanran.wang
* @date 2023/5/25 14:42
*/
@Retention(RetentionPolicy.RUNTIME)
@Target({ElementType.METHOD})
@Documented
public @interface CusJsonMappingConfig {
String configCode() default "";
String tableName() default "";
}

View File

@ -15,5 +15,5 @@ import java.lang.annotation.*;
@Target({ElementType.METHOD, ElementType.TYPE}) @Target({ElementType.METHOD, ElementType.TYPE})
@Documented @Documented
public @interface CusReqAfterHandleRegister { public @interface CusReqAfterHandleRegister {
Class<?> afterHandle(); Class<?>[] afterHandle();
} }

View File

@ -23,4 +23,6 @@ public @interface CusRequestPost {
@AliasFor(annotation = CusRequestType.class, attribute = "requestType") @AliasFor(annotation = CusRequestType.class, attribute = "requestType")
int requestType() default CusRequestClientConstant.POST; int requestType() default CusRequestClientConstant.POST;
String configCode() default "";
} }

View File

@ -7,7 +7,9 @@ import lombok.Setter;
import xuanran.wang.http_test.annotations.handle.CusResponseSuccessHandle; import xuanran.wang.http_test.annotations.handle.CusResponseSuccessHandle;
import xuanran.wang.http_test.handle.CusRequestAfterHandle; import xuanran.wang.http_test.handle.CusRequestAfterHandle;
import java.lang.reflect.Type;
import java.util.HashMap; import java.util.HashMap;
import java.util.List;
import java.util.Map; import java.util.Map;
import java.util.function.Consumer; import java.util.function.Consumer;
@ -31,8 +33,8 @@ public class CusRequestEntity{
private boolean async = false; private boolean async = false;
private String host = ""; private String host = "";
private int port; private int port;
private Class<?> returnType; private Type returnType;
private CusRequestAfterHandle cusRequestAfter; private List<CusRequestAfterHandle> cusRequestAfter;
private CusResponseSuccessHandle responseSuccessHandle; private CusResponseSuccessHandle responseSuccessHandle;
private Map<String, Object> responseMap; private Map<String, Object> responseMap;
} }

View File

@ -7,6 +7,7 @@ import aiyh.utils.tool.cn.hutool.core.annotation.AnnotationUtil;
import com.alibaba.fastjson.JSON; import com.alibaba.fastjson.JSON;
import com.alibaba.fastjson.JSONObject; import com.alibaba.fastjson.JSONObject;
import org.apache.commons.collections.CollectionUtils;
import org.apache.log4j.Logger; import org.apache.log4j.Logger;
import xuanran.wang.http_test.annotations.handle.CusReqAfterHandleRegister; import xuanran.wang.http_test.annotations.handle.CusReqAfterHandleRegister;
import xuanran.wang.http_test.annotations.handle.CusResponseSuccessHandle; import xuanran.wang.http_test.annotations.handle.CusResponseSuccessHandle;
@ -85,16 +86,17 @@ public class CusHandleCenter{
} }
public Object requestAfterHandle(Method method, CusRequestEntity cusRequest, ResponeVo responseVo){ public Object requestAfterHandle(Method method, CusRequestEntity cusRequest, ResponeVo responseVo){
if(cusRequest.getCusRequestAfter() == null){ CusReqAfterHandleRegister cusReqAfterHandleRegister = method.getDeclaredAnnotation(CusReqAfterHandleRegister.class);
CusReqAfterHandleRegister cusReqAfterHandleRegister = method.getDeclaredAnnotation(CusReqAfterHandleRegister.class); if(cusReqAfterHandleRegister != null){
if(cusReqAfterHandleRegister != null){ RequestUtil.setCusRequestAfter(cusReqAfterHandleRegister, cusRequest);
RequestUtil.setCusRequestAfter(cusReqAfterHandleRegister, cusRequest); }else {
} List<CusRequestAfterHandle> tempList = new ArrayList<>();
tempList.add(new CusDefaultRequestAfterHandle());
cusRequest.setCusRequestAfter(tempList);
} }
// Type genericReturnType = method.getGenericReturnType(); cusRequest.setReturnType(method.getGenericReturnType());
cusRequest.setReturnType(method.getReturnType());
CusResponseSuccessHandle cusResponseSuccessHandle = method.getDeclaredAnnotation(CusResponseSuccessHandle.class); CusResponseSuccessHandle cusResponseSuccessHandle = method.getDeclaredAnnotation(CusResponseSuccessHandle.class);
if(cusResponseSuccessHandle != null && cusRequest.getResponseSuccessHandle() == null){ if(cusResponseSuccessHandle != null && cusRequest.getResponseSuccessHandle() != null){
cusRequest.setResponseSuccessHandle(cusResponseSuccessHandle); cusRequest.setResponseSuccessHandle(cusResponseSuccessHandle);
} }
return requestAfterHandle(cusRequest, responseVo); return requestAfterHandle(cusRequest, responseVo);
@ -113,11 +115,19 @@ public class CusHandleCenter{
responseVo.getEntityString())); responseVo.getEntityString()));
throw new CustomerException(Util.logStr("can not fetch [{}]", url)); // throw new CustomerException(Util.logStr("can not fetch [{}]", url)); //
} }
CusRequestAfterHandle handle = cusRequest.getCusRequestAfter() == null ? new CusDefaultRequestAfterHandle() : cusRequest.getCusRequestAfter(); cusRequest.setResponseMap(responseVo.getResponseMap());
cusRequest.setCusRequestAfter(handle); List<CusRequestAfterHandle> cusRequestAfter = cusRequest.getCusRequestAfter();
Object res = null;
log.info(Util.logStr("cusRequest: {}", JSONObject.toJSONString(cusRequest))); log.info(Util.logStr("cusRequest: {}", JSONObject.toJSONString(cusRequest)));
Object res = handle.parseResponse(cusRequest, responseVo); for (CusRequestAfterHandle handle : cusRequestAfter) {
handle.service(cusRequest, responseVo); if(RequestUtil.isMethodOverridden(handle.getClass(), CusDefaultRequestAfterHandle.class, "parseResponse")){
res = handle.parseResponse(cusRequest, responseVo);
}else {
CusDefaultRequestAfterHandle defaultRequestAfterHandle = new CusDefaultRequestAfterHandle();
res = defaultRequestAfterHandle.parseResponse(cusRequest, responseVo);
}
handle.service(cusRequest, responseVo);
}
return res; return res;
} }

View File

@ -25,11 +25,10 @@ public abstract class CusRequestHandle {
realRequestUrl.append(url); realRequestUrl.append(url);
}else { }else {
realRequestUrl.append(host); realRequestUrl.append(host);
if(!host.endsWith(":")){ if(port > 0 && !host.endsWith(":")){
realRequestUrl.append(":"); realRequestUrl.append(":").append(port);
} }
realRequestUrl.append(port); if(!host.endsWith("/") && !url.startsWith("/")){
if(!url.endsWith("/")){
realRequestUrl.append("/"); realRequestUrl.append("/");
} }
realRequestUrl.append(url); realRequestUrl.append(url);

View File

@ -72,10 +72,14 @@ public class RequestHeaderHandle implements CusRequestBeforeHandle {
Parameter parameter = parameters[i]; Parameter parameter = parameters[i];
CusRequestHeader requestHeader = parameter.getAnnotation(CusRequestHeader.class); CusRequestHeader requestHeader = parameter.getAnnotation(CusRequestHeader.class);
if(requestHeader != null){ if(requestHeader != null){
String val = Util.null2DefaultStr(args[i], "").trim(); if(Map.class.isAssignableFrom(parameter.getType())){
String key = requestHeader.value().trim(); headers.putAll((Map<? extends String, ? extends String>) args[i]);
if(StringUtils.isNotBlank(key) && StringUtils.isNotBlank(val)){ }else {
headers.put(key, val); String val = Util.null2DefaultStr(args[i], "").trim();
String key = requestHeader.value().trim();
if(StringUtils.isNotBlank(key) && StringUtils.isNotBlank(val)){
headers.put(key, val);
}
} }
} }
} }

View File

@ -10,6 +10,7 @@ import xuanran.wang.http_test.constant.CusRequestClientConstant;
import xuanran.wang.http_test.entity.CusRequestEntity; import xuanran.wang.http_test.entity.CusRequestEntity;
import xuanran.wang.http_test.handle.CusRequestAfterHandle; import xuanran.wang.http_test.handle.CusRequestAfterHandle;
import java.lang.reflect.Type;
import java.util.Map; import java.util.Map;
/** /**
@ -22,12 +23,11 @@ public class CusDefaultRequestAfterHandle implements CusRequestAfterHandle {
@Override @Override
public Object parseResponse(CusRequestEntity cusRequest, ResponeVo responseVo) { public Object parseResponse(CusRequestEntity cusRequest, ResponeVo responseVo) {
Class<?> returnType = cusRequest.getReturnType(); Type returnType = cusRequest.getReturnType();
if(ResponeVo.class.isAssignableFrom(returnType)) { if(ResponeVo.class.isAssignableFrom(returnType.getClass())) {
return responseVo; return responseVo;
} }
String json = responseVo.getEntityString(); String json = responseVo.getEntityString();
cusRequest.setResponseMap(responseVo.getResponseMap());
CusResponseSuccessHandle responseSuccessHandle = cusRequest.getResponseSuccessHandle(); CusResponseSuccessHandle responseSuccessHandle = cusRequest.getResponseSuccessHandle();
if(responseSuccessHandle != null){ if(responseSuccessHandle != null){
String successCondition = responseSuccessHandle.successCondition(); String successCondition = responseSuccessHandle.successCondition();

View File

@ -8,6 +8,8 @@ import xuanran.wang.http_test.entity.CusRequestEntity;
import xuanran.wang.http_test.handle.CusRequestBeforeHandle; import xuanran.wang.http_test.handle.CusRequestBeforeHandle;
import java.lang.reflect.Method; import java.lang.reflect.Method;
import java.lang.reflect.ParameterizedType;
import java.lang.reflect.Type;
/** /**
* <h1></h1> * <h1></h1>
@ -23,7 +25,6 @@ public class CusUrlHandle implements CusRequestBeforeHandle {
throw new CustomerException("method not found CusRequestUrl!"); throw new CustomerException("method not found CusRequestUrl!");
} }
cusRequest.setUrl(requestUrl.url()); cusRequest.setUrl(requestUrl.url());
Class<?> returnType = method.getReturnType(); cusRequest.setReturnType(method.getGenericReturnType());
cusRequest.setReturnType(returnType);
} }
} }

View File

@ -17,6 +17,8 @@ import java.lang.annotation.Annotation;
import java.lang.reflect.InvocationHandler; import java.lang.reflect.InvocationHandler;
import java.lang.reflect.Method; import java.lang.reflect.Method;
import java.lang.reflect.Proxy; import java.lang.reflect.Proxy;
import java.util.ArrayList;
import java.util.List;
/** /**
@ -29,12 +31,13 @@ public class RequestUtil implements InvocationHandler {
private CusRequestAddress cusRequestAddress = null; private CusRequestAddress cusRequestAddress = null;
private final Logger log = Util.getLogger(); private final Logger log = Util.getLogger();
private final CusHandleCenter handleCenter = new CusHandleCenter(); private final CusHandleCenter handleCenter = new CusHandleCenter();
private final CusRequestEntity cusRequest = new CusRequestEntity(); private CusRequestEntity cusRequest;
public <T> T getRequestClient(Class<?> clazz){ public <T> T getRequestClient(Class<?> clazz){
Annotation annotation = clazz.getDeclaredAnnotation(CusRequestClient.class); Annotation annotation = clazz.getDeclaredAnnotation(CusRequestClient.class);
if(annotation == null){ if(annotation == null){
throw new CustomerException(Util.logStr(clazz.getName() + " not found CusRequestClient annotation!")); throw new CustomerException(Util.logStr(clazz.getName() + " not found CusRequestClient annotation!"));
} }
cusRequest = new CusRequestEntity();
// 请求后处理 // 请求后处理
CusReqAfterHandleRegister cusReqAfterHandleRegister = clazz.getDeclaredAnnotation(CusReqAfterHandleRegister.class); CusReqAfterHandleRegister cusReqAfterHandleRegister = clazz.getDeclaredAnnotation(CusReqAfterHandleRegister.class);
if(cusReqAfterHandleRegister != null){ if(cusReqAfterHandleRegister != null){
@ -62,7 +65,6 @@ public class RequestUtil implements InvocationHandler {
cusRequest.setPort(port); cusRequest.setPort(port);
} }
handleCenter.requestBeforeHandle(cusRequest, method, args); handleCenter.requestBeforeHandle(cusRequest, method, args);
log.info("requestHandle : \n" + JSONObject.toJSONString(cusRequest));
ResponeVo responeVo = handleCenter.requestHandle(cusRequest, method); ResponeVo responeVo = handleCenter.requestHandle(cusRequest, method);
return handleCenter.requestAfterHandle(method, cusRequest, responeVo); return handleCenter.requestAfterHandle(method, cusRequest, responeVo);
} }
@ -70,16 +72,33 @@ public class RequestUtil implements InvocationHandler {
public static void setCusRequestAfter(CusReqAfterHandleRegister cusReqAfterHandleRegister, public static void setCusRequestAfter(CusReqAfterHandleRegister cusReqAfterHandleRegister,
CusRequestEntity cusRequest){ CusRequestEntity cusRequest){
if(cusReqAfterHandleRegister != null){ if(cusReqAfterHandleRegister != null){
Class<?> clazz = cusReqAfterHandleRegister.afterHandle(); Class<?>[] clazz = cusReqAfterHandleRegister.afterHandle();
if (CusRequestAfterHandle.class.isAssignableFrom(clazz)) { List<CusRequestAfterHandle> requestAfter = cusRequest.getCusRequestAfter();
try { if(requestAfter == null){
Object cusRequestAfter = clazz.newInstance(); requestAfter = new ArrayList<>();
cusRequest.setCusRequestAfter((CusRequestAfterHandle) cusRequestAfter); }
}catch (Exception e){ cusRequest.setCusRequestAfter(requestAfter);
throw new CustomerException(Util.logStr("class : {}, newInstance error!", e.getMessage())); for (Class<?> aClass : clazz) {
if (CusRequestAfterHandle.class.isAssignableFrom(aClass)) {
try {
CusRequestAfterHandle cusRequestAfter = (CusRequestAfterHandle) aClass.newInstance();
requestAfter.add(cusRequestAfter);
}catch (Exception e){
throw new CustomerException(Util.logStr("class : {}, newInstance error!", e.getMessage()));
}
} }
} }
} }
} }
public static boolean isMethodOverridden(Class<?> subclass, Class<?> superclass, String methodName) {
try {
Method method = subclass.getDeclaredMethod(methodName);
Method superMethod = superclass.getDeclaredMethod(methodName);
return !method.equals(superMethod);
} catch (NoSuchMethodException e) {
return false;
}
}
} }

View File

@ -0,0 +1,27 @@
package xuanran.wang.http_test.service;
import xuanran.wang.http_test.annotations.CusRequestClient;
import xuanran.wang.http_test.annotations.header.CusRequestHeader;
import xuanran.wang.http_test.annotations.request_type.CusRequestPost;
import javax.ws.rs.core.MediaType;
import java.util.Map;
/**
* <h1></h1>
*
* @author xuanran.wang
* @date 2023/5/24 14:53
*/
@CusRequestClient(host = "https://ecology.yeyaguitu.cn")
public interface EcTestService {
@CusRequestPost(url = "/api/ec/dev/auth/regist")
@CusRequestHeader(cusHeaders = {"appid:JYZ", "loginid:sysadmin","Content-type:"+ MediaType.APPLICATION_JSON})
Map<String, Object> register();
@CusRequestPost(url = "/api/ec/dev/auth/regist")
@CusRequestHeader(cusHeaders = {"Content-type:"+ MediaType.APPLICATION_JSON})
Map<String, Object> register(@CusRequestHeader("appid") String appId,
@CusRequestHeader Map<String, String> headers);
}

View File

@ -2,12 +2,15 @@ package xuanran.wang.http_test.service;
import xuanran.wang.http_test.annotations.*; import xuanran.wang.http_test.annotations.*;
import xuanran.wang.http_test.annotations.body.CusRequestBody; import xuanran.wang.http_test.annotations.body.CusRequestBody;
import xuanran.wang.http_test.annotations.handle.CusReqAfterHandleRegister;
import xuanran.wang.http_test.annotations.handle.CusResponseSuccessHandle; import xuanran.wang.http_test.annotations.handle.CusResponseSuccessHandle;
import xuanran.wang.http_test.annotations.header.CusRequestHeader; import xuanran.wang.http_test.annotations.header.CusRequestHeader;
import xuanran.wang.http_test.annotations.request_path.CusPathQuery; import xuanran.wang.http_test.annotations.request_path.CusPathQuery;
import xuanran.wang.http_test.annotations.request_type.CusRequestGet; import xuanran.wang.http_test.annotations.request_type.CusRequestGet;
import xuanran.wang.http_test.annotations.request_type.CusRequestPost; import xuanran.wang.http_test.annotations.request_type.CusRequestPost;
import xuanran.wang.http_test.constant.CusRequestClientConstant; import xuanran.wang.http_test.constant.CusRequestClientConstant;
import xuanran.wang.http_test.test.Student;
import xuanran.wang.http_test.test.TestRequestAfterHandle;
import java.util.List; import java.util.List;
import java.util.Map; import java.util.Map;
@ -19,7 +22,6 @@ import java.util.Map;
* @date 2023/3/10 12:39 * @date 2023/3/10 12:39
*/ */
@CusRequestClient(host = "http://114.115.168.220", port = 8191) @CusRequestClient(host = "http://114.115.168.220", port = 8191)
//@CusReqAfterHandleRegister(afterHandle = TestRequestAfterHandle.class)
public interface TestService { public interface TestService {
@CusRequestGet(url = "educate-plat/api/v1/class/getClassList") @CusRequestGet(url = "educate-plat/api/v1/class/getClassList")
@ -30,8 +32,9 @@ public interface TestService {
errorMsg = "msg", errorMsg = "msg",
data = "data" data = "data"
) )
Map<String, Object> getStu(Map<String, Object> path, @CusReqAfterHandleRegister(afterHandle = {TestRequestAfterHandle.class})
@CusRequestBody Map<String, Object> body, List<Student> getStu(Map<String, Object> path,
@CusRequestHeader("hsjhdsad") String test, @CusRequestBody Map<String, Object> body,
@CusPathQuery("test") String test1); @CusRequestHeader("hsjhdsad") String test,
@CusPathQuery("test") String test1);
} }

View File

@ -2,6 +2,7 @@ package xuanran.wang.http_test.test;
import basetest.BaseTest; import basetest.BaseTest;
import com.alibaba.fastjson.JSONObject; import com.alibaba.fastjson.JSONObject;
import com.alibaba.fastjson.TypeReference;
import com.api.doc.migrate.util.FtpUtil; import com.api.doc.migrate.util.FtpUtil;
import com.jcraft.jsch.ChannelSftp; import com.jcraft.jsch.ChannelSftp;
import org.junit.Test; import org.junit.Test;
@ -9,6 +10,7 @@ import weaver.backup.utils.ZipUtil;
import xuanran.wang.http_test.entity.CusHandleEntity; import xuanran.wang.http_test.entity.CusHandleEntity;
import xuanran.wang.http_test.handle.util.HandleUtil; import xuanran.wang.http_test.handle.util.HandleUtil;
import xuanran.wang.http_test.proxy.CusUtil; import xuanran.wang.http_test.proxy.CusUtil;
import xuanran.wang.http_test.service.EcTestService;
import xuanran.wang.http_test.service.TestService; import xuanran.wang.http_test.service.TestService;
import java.util.*; import java.util.*;
@ -23,6 +25,7 @@ import java.util.stream.Collectors;
public class RequestTest extends BaseTest { public class RequestTest extends BaseTest {
private TestService requestClient = CusUtil.getRequestClient(TestService.class); private TestService requestClient = CusUtil.getRequestClient(TestService.class);
private EcTestService ecTestService = CusUtil.getRequestClient(EcTestService.class);
@Test @Test
public void test(){ public void test(){
HashMap<String, Object> map = new HashMap<>(); HashMap<String, Object> map = new HashMap<>();
@ -36,9 +39,11 @@ public class RequestTest extends BaseTest {
path.put("e","5"); path.put("e","5");
path.put("f","6"); path.put("f","6");
Map<String, Object> stu = requestClient.getStu(map, body, "a", "test1111"); // List<Student> stu = requestClient.getStu(map, body, "a", "test1111");
log.info("stu : \n" + JSONObject.toJSONString(stu)); List<Student> stu = requestClient.getStu(map, body, "a", "test1111");
for (Student student : stu) {
System.out.println("stu => " + student);
}
// String json = "{\"xuanran.wang.http_test.requestBeforeHandle.path_handle\":[{\"handleClass\":\"xuanran.wang.http_test.requestBeforeHandle.path_handle.CusPathParseHandle\",\"order\":0,\"packageName\":\"xuanran.wang.http_test.requestBeforeHandle.path_handle\"},{\"handleClass\":\"xuanran.wang.http_test.requestBeforeHandle.path_handle.TestHandle\",\"order\":99,\"packageName\":\"xuanran.wang.http_test.requestBeforeHandle.path_handle\"}],\"xuanran.wang.http_test.requestBeforeHandle.header_handle\":[{\"handleClass\":\"xuanran.wang.http_test.requestBeforeHandle.header_handle.RequestHeaderHandle\",\"order\":0,\"packageName\":\"xuanran.wang.http_test.requestBeforeHandle.header_handle\"}]}"; // String json = "{\"xuanran.wang.http_test.requestBeforeHandle.path_handle\":[{\"handleClass\":\"xuanran.wang.http_test.requestBeforeHandle.path_handle.CusPathParseHandle\",\"order\":0,\"packageName\":\"xuanran.wang.http_test.requestBeforeHandle.path_handle\"},{\"handleClass\":\"xuanran.wang.http_test.requestBeforeHandle.path_handle.TestHandle\",\"order\":99,\"packageName\":\"xuanran.wang.http_test.requestBeforeHandle.path_handle\"}],\"xuanran.wang.http_test.requestBeforeHandle.header_handle\":[{\"handleClass\":\"xuanran.wang.http_test.requestBeforeHandle.header_handle.RequestHeaderHandle\",\"order\":0,\"packageName\":\"xuanran.wang.http_test.requestBeforeHandle.header_handle\"}]}";
// System.out.println(JSONObject.parseObject(JSONObject.toJSONString(json), Map.class)); // System.out.println(JSONObject.parseObject(JSONObject.toJSONString(json), Map.class));
// String stu1 = requestClient.getStu(body); // String stu1 = requestClient.getStu(body);
@ -61,4 +66,16 @@ public class RequestTest extends BaseTest {
} }
} }
@Test
public void testB(){
Map<String, Object> register = ecTestService.register();
System.out.printf("register : " + JSONObject.toJSONString(register));
HashMap<String, String> header = new HashMap<>();
header.put("loginid","123");
header.put("dadsada","sasas");
Map<String, Object> register1 = ecTestService.register("JYZ1", header);
System.out.printf("register1 : " + JSONObject.toJSONString(register1));
}
} }

View File

@ -0,0 +1,49 @@
package xuanran.wang.http_test.test;
/**
* <h1></h1>
*
* @author xuanran.wang
* @date 2023/5/23 11:40
*/
public class Student {
private String teacherId;
private int belongYear;
private String classNo;
private String className;
private String id;
public void setTeacherId(String teacherId) {
this.teacherId = teacherId;
}
public String getTeacherId() {
return teacherId;
}
public void setBelongYear(int belongYear) {
this.belongYear = belongYear;
}
public int getBelongYear() {
return belongYear;
}
public void setClassNo(String classNo) {
this.classNo = classNo;
}
public String getClassNo() {
return classNo;
}
public void setClassName(String className) {
this.className = className;
}
public String getClassName() {
return className;
}
public void setId(String id) {
this.id = id;
}
public String getId() {
return id;
}
}