Compare commits
14 Commits
Author | SHA1 | Date |
---|---|---|
wangxuanran | e83d55c455 | |
youHong.ai | e53858e7c6 | |
youHong.ai | af35223154 | |
wangxuanran | b1340f0b8e | |
wangxuanran | 31286babb2 | |
youHong.ai | 6f1e24a274 | |
youHong.ai | d5b0805ea5 | |
youHong.ai | ddf724f101 | |
youHong.ai | 60fba70611 | |
youHong.ai | decd040ce8 | |
wangxuanran | bc6b5eb9d5 | |
wangxuanran | 19e724b59d | |
youHong.ai | 2360774e9d | |
wangxuanran | 203a7cd4a9 |
|
@ -18,6 +18,7 @@ log
|
||||||
.idea/
|
.idea/
|
||||||
#.gitignore
|
#.gitignore
|
||||||
!.gitignore
|
!.gitignore
|
||||||
|
*.iml
|
||||||
# Project files, i.e. `.project`, `.actionScriptProperties` and `.flexProperties`
|
# Project files, i.e. `.project`, `.actionScriptProperties` and `.flexProperties`
|
||||||
# should NOT be excluded as they contain compiler settings and other important
|
# should NOT be excluded as they contain compiler settings and other important
|
||||||
# information for Eclipse / Flash Builder.
|
# information for Eclipse / Flash Builder.
|
||||||
|
@ -37,6 +38,9 @@ DirectoryV2.xml
|
||||||
/lib/classbeanLib/web-inf-class-lib.jar
|
/lib/classbeanLib/web-inf-class-lib.jar
|
||||||
/lib/weaverLib/
|
/lib/weaverLib/
|
||||||
*.groovy
|
*.groovy
|
||||||
|
*.log
|
||||||
|
src/main/resources/WEB-INF/sqllog/
|
||||||
|
java.io.tempdir/
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
|
@ -1,8 +0,0 @@
|
||||||
<?xml version="1.0" encoding="UTF-8"?>
|
|
||||||
<module version="4">
|
|
||||||
<component name="NewModuleRootManager">
|
|
||||||
<content url="file://$MODULE_DIR$">
|
|
||||||
<sourceFolder url="file://$MODULE_DIR$/src/test/resources" type="java-test-resource" />
|
|
||||||
</content>
|
|
||||||
</component>
|
|
||||||
</module>
|
|
|
@ -1,174 +1,174 @@
|
||||||
package aiyh.utils;
|
package aiyh.utils;
|
||||||
|
|
||||||
import aiyh.utils.entity.LabelHtmlIndex;
|
import aiyh.utils.entity.LabelHtmlIndex;
|
||||||
import aiyh.utils.service.UtilService;
|
import aiyh.utils.service.UtilService;
|
||||||
import aiyh.utils.zwl.common.ToolUtil;
|
import aiyh.utils.zwl.common.ToolUtil;
|
||||||
import weaver.systeminfo.SystemEnv;
|
import weaver.systeminfo.SystemEnv;
|
||||||
|
|
||||||
import java.util.Map;
|
import java.util.Map;
|
||||||
import java.util.regex.Matcher;
|
import java.util.regex.Matcher;
|
||||||
import java.util.regex.Pattern;
|
import java.util.regex.Pattern;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @author EBU7-dev1-ayh
|
* @author EBU7-dev1-ayh
|
||||||
* create 2021/12/13 0013 10:29
|
* create 2021/12/13 0013 10:29
|
||||||
* 多语言工具类
|
* 多语言工具类
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
|
||||||
public class LabelHtmlUtils {
|
public class LabelHtmlUtils {
|
||||||
|
|
||||||
private final UtilService utilService = new UtilService();
|
private final UtilService utilService = new UtilService();
|
||||||
private Map<String, Object> htmlLabel = null;
|
private Map<String, Object> htmlLabel = null;
|
||||||
private ToolUtil toolUtil = new ToolUtil();
|
private ToolUtil toolUtil = new ToolUtil();
|
||||||
|
|
||||||
public LabelHtmlUtils(String prefix) {
|
public LabelHtmlUtils(String prefix) {
|
||||||
if (!this.init(prefix)) {
|
if (!this.init(prefix)) {
|
||||||
toolUtil.writeErrorLog("配置文件异常,请检查配置文件结构是否符合要求!");
|
toolUtil.writeErrorLog("配置文件异常,请检查配置文件结构是否符合要求!");
|
||||||
throw new RuntimeException("配置文件异常,请检查配置文件结构是否符合要求!");
|
throw new RuntimeException("配置文件异常,请检查配置文件结构是否符合要求!");
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
public LabelHtmlUtils() {
|
public LabelHtmlUtils() {
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* 初始化配置信息
|
* 初始化配置信息
|
||||||
*
|
*
|
||||||
* @param prefix 前缀
|
* @param prefix 前缀
|
||||||
* @return 是否初始化成功
|
* @return 是否初始化成功
|
||||||
*/
|
*/
|
||||||
public synchronized boolean init(String prefix) {
|
public synchronized boolean init(String prefix) {
|
||||||
if (this.htmlLabel != null) {
|
if (this.htmlLabel != null) {
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
try {
|
try {
|
||||||
this.htmlLabel = Util.readProperties2Map("htmlLabelIndex", prefix);
|
this.htmlLabel = Util.readProperties2Map("htmlLabelIndex", prefix);
|
||||||
return this.htmlLabel != null;
|
return this.htmlLabel != null;
|
||||||
} catch (Exception e) {
|
} catch (Exception e) {
|
||||||
e.printStackTrace();
|
e.printStackTrace();
|
||||||
toolUtil.writeErrorLog(e.toString());
|
toolUtil.writeErrorLog(e.toString());
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* 获取指定语言id的自定义标签
|
* 获取指定语言id的自定义标签
|
||||||
*
|
*
|
||||||
* @param id 自定义标签id
|
* @param id 自定义标签id
|
||||||
* @param languageId 语言id
|
* @param languageId 语言id
|
||||||
* @param defaultStr 默认字符串
|
* @param defaultStr 默认字符串
|
||||||
* @return 自定义标签对应的语言字符串,或者默认字符串
|
* @return 自定义标签对应的语言字符串,或者默认字符串
|
||||||
*/
|
*/
|
||||||
public String getHtmlLabelName(int id, int languageId, String defaultStr) {
|
public String getHtmlLabelName(int id, int languageId, String defaultStr) {
|
||||||
String htmlLabelName = SystemEnv.getHtmlLabelName(id, languageId);
|
String htmlLabelName = SystemEnv.getHtmlLabelName(id, languageId);
|
||||||
return htmlLabelName == null ? defaultStr : htmlLabelName;
|
return htmlLabelName == null ? defaultStr : htmlLabelName;
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* 获取指定语言id的自定义标签
|
* 获取指定语言id的自定义标签
|
||||||
*
|
*
|
||||||
* @param id 标签id
|
* @param id 标签id
|
||||||
* @param languageId 语言id
|
* @param languageId 语言id
|
||||||
* @return 自定义标签的语言字符串
|
* @return 自定义标签的语言字符串
|
||||||
*/
|
*/
|
||||||
public String getHtmlLabelName(int id, int languageId) {
|
public String getHtmlLabelName(int id, int languageId) {
|
||||||
return SystemEnv.getHtmlLabelName(id, languageId);
|
return SystemEnv.getHtmlLabelName(id, languageId);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* 通过语言id截取多语言字符串
|
* 通过语言id截取多语言字符串
|
||||||
*
|
*
|
||||||
* @param languageId 语言id
|
* @param languageId 语言id
|
||||||
* @param languageStr 多语言字符串
|
* @param languageStr 多语言字符串
|
||||||
* @return 截取后的字符串
|
* @return 截取后的字符串
|
||||||
*/
|
*/
|
||||||
public String getHtmlLabelNameByStr(int languageId, String languageStr) {
|
public String getHtmlLabelNameByStr(int languageId, String languageStr) {
|
||||||
String pattern = "(`~`" + languageId + " )(?<label>(\\w*|\\W*|[\\u4e00-\\u9fa5]*))(`~`)";
|
String pattern = "(`~`" + languageId + " )(?<label>(\\w*|\\W*|[\\u4e00-\\u9fa5]*))(`~`)";
|
||||||
Pattern compile = Pattern.compile(pattern);
|
Pattern compile = Pattern.compile(pattern);
|
||||||
Matcher matcher = compile.matcher(languageStr);
|
Matcher matcher = compile.matcher(languageStr);
|
||||||
if (matcher.find()) {
|
if (matcher.find()) {
|
||||||
return matcher.group("label");
|
return matcher.group("label");
|
||||||
}
|
}
|
||||||
return languageStr;
|
return languageStr;
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* 获取配置多余元文件详细
|
* 获取配置多余元文件详细
|
||||||
*
|
*
|
||||||
* @param key 键
|
* @param key 键
|
||||||
*/
|
*/
|
||||||
public Map<String, Object> getHtmlLabelMap(String key) {
|
public Map<String, Object> getHtmlLabelMap(String key) {
|
||||||
if (this.htmlLabel == null) {
|
if (this.htmlLabel == null) {
|
||||||
throw new RuntimeException("请初始化以读取配置信息,调用方法init(String prefix)");
|
throw new RuntimeException("请初始化以读取配置信息,调用方法init(String prefix)");
|
||||||
}
|
}
|
||||||
Map<String, Object> map;
|
Map<String, Object> map;
|
||||||
try {
|
try {
|
||||||
map = (Map<String, Object>) this.htmlLabel.get(key);
|
map = (Map<String, Object>) this.htmlLabel.get(key);
|
||||||
} catch (Exception e) {
|
} catch (Exception e) {
|
||||||
throw new RuntimeException("配置文件异常,请检查配置文件结构是否符合要求!");
|
throw new RuntimeException("配置文件异常,请检查配置文件结构是否符合要求!");
|
||||||
}
|
}
|
||||||
return map;
|
return map;
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* 读取配置文件中的多语言配置
|
* 读取配置文件中的多语言配置
|
||||||
*
|
*
|
||||||
* @param key 多语言配置中的前缀
|
* @param key 多语言配置中的前缀
|
||||||
* @return 多语言配置Map
|
* @return 多语言配置Map
|
||||||
*/
|
*/
|
||||||
public Map<String, String> getHtmlLabel(String key) {
|
public Map<String, String> getHtmlLabel(String key) {
|
||||||
if (this.htmlLabel == null) {
|
if (this.htmlLabel == null) {
|
||||||
throw new RuntimeException("请初始化以读取配置信息,调用方法init(String prefix)");
|
throw new RuntimeException("请初始化以读取配置信息,调用方法init(String prefix)");
|
||||||
}
|
}
|
||||||
Map<String, String> map;
|
Map<String, String> map;
|
||||||
try {
|
try {
|
||||||
map = (Map<String, String>) this.htmlLabel.get(key);
|
map = (Map<String, String>) this.htmlLabel.get(key);
|
||||||
} catch (Exception e) {
|
} catch (Exception e) {
|
||||||
throw new RuntimeException("配置文件异常,请检查配置文件结构是否符合要求!");
|
throw new RuntimeException("配置文件异常,请检查配置文件结构是否符合要求!");
|
||||||
}
|
}
|
||||||
return map;
|
return map;
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* 读取配置文件中的多语言配置
|
* 读取配置文件中的多语言配置
|
||||||
*
|
*
|
||||||
* @param key 多语言配置中的前缀
|
* @param key 多语言配置中的前缀
|
||||||
* @return 多语言配置对象
|
* @return 多语言配置对象
|
||||||
*/
|
*/
|
||||||
public LabelHtmlIndex getLabelHtmlIndex(String key) {
|
public LabelHtmlIndex getLabelHtmlIndex(String key) {
|
||||||
if (this.htmlLabel == null) {
|
if (this.htmlLabel == null) {
|
||||||
throw new RuntimeException("请初始化以读取配置信息,调用方法init(String prefix)");
|
throw new RuntimeException("请初始化以读取配置信息,调用方法init(String prefix)");
|
||||||
}
|
}
|
||||||
Map<String, Object> map;
|
Map<String, Object> map;
|
||||||
LabelHtmlIndex labelHtmlIndex;
|
LabelHtmlIndex labelHtmlIndex;
|
||||||
try {
|
try {
|
||||||
map = (Map<String, Object>) this.htmlLabel.get(key);
|
map = (Map<String, Object>) this.htmlLabel.get(key);
|
||||||
labelHtmlIndex = Util.mapToObject(map, LabelHtmlIndex.class);
|
labelHtmlIndex = Util.mapToObject(map, LabelHtmlIndex.class);
|
||||||
} catch (Exception e) {
|
} catch (Exception e) {
|
||||||
throw new RuntimeException("配置文件异常,请检查配置文件结构是否符合要求!");
|
throw new RuntimeException("配置文件异常,请检查配置文件结构是否符合要求!");
|
||||||
}
|
}
|
||||||
return labelHtmlIndex;
|
return labelHtmlIndex;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* 读取配置文件中的多语言配置
|
* 读取配置文件中的多语言配置
|
||||||
*
|
*
|
||||||
* @param map 多语言配置中的对象
|
* @param map 多语言配置中的对象
|
||||||
* @return 多语言配置对象
|
* @return 多语言配置对象
|
||||||
*/
|
*/
|
||||||
public LabelHtmlIndex getLabelHtmlIndex(Map<String, Object> map, String key) {
|
public LabelHtmlIndex getLabelHtmlIndex(Map<String, Object> map, String key) {
|
||||||
LabelHtmlIndex labelHtmlIndex;
|
LabelHtmlIndex labelHtmlIndex;
|
||||||
Map<String, Object> resultMap;
|
Map<String, Object> resultMap;
|
||||||
try {
|
try {
|
||||||
resultMap = (Map<String, Object>) map.get(key);
|
resultMap = (Map<String, Object>) map.get(key);
|
||||||
labelHtmlIndex = Util.mapToObject(resultMap, LabelHtmlIndex.class);
|
labelHtmlIndex = Util.mapToObject(resultMap, LabelHtmlIndex.class);
|
||||||
} catch (Exception e) {
|
} catch (Exception e) {
|
||||||
e.printStackTrace();
|
e.printStackTrace();
|
||||||
throw new RuntimeException("map转换异常!");
|
throw new RuntimeException("map转换异常!");
|
||||||
}
|
}
|
||||||
return labelHtmlIndex;
|
return labelHtmlIndex;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -1,40 +1,40 @@
|
||||||
package aiyh.utils;
|
package aiyh.utils;
|
||||||
|
|
||||||
import org.apache.ibatis.io.Resources;
|
import org.apache.ibatis.io.Resources;
|
||||||
import org.apache.ibatis.session.SqlSessionManager;
|
import org.apache.ibatis.session.SqlSessionManager;
|
||||||
|
|
||||||
import java.io.File;
|
import java.io.File;
|
||||||
import java.io.Reader;
|
import java.io.Reader;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @author EBU7-dev1-ayh
|
* @author EBU7-dev1-ayh
|
||||||
* create 2021/12/14 0014 15:57
|
* create 2021/12/14 0014 15:57
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
|
||||||
public class MybatisUtil {
|
public class MybatisUtil {
|
||||||
private static SqlSessionManager sqlSessionManager = null;
|
private static SqlSessionManager sqlSessionManager = null;
|
||||||
|
|
||||||
private synchronized static void init(String config){
|
private synchronized static void init(String config){
|
||||||
try {
|
try {
|
||||||
Reader resourceAsReader = Resources.getResourceAsReader("WEB-INF" + File.separator +config);
|
Reader resourceAsReader = Resources.getResourceAsReader("WEB-INF" + File.separator +config);
|
||||||
sqlSessionManager = SqlSessionManager.newInstance(resourceAsReader);
|
sqlSessionManager = SqlSessionManager.newInstance(resourceAsReader);
|
||||||
} catch (Exception e) {
|
} catch (Exception e) {
|
||||||
e.printStackTrace();
|
e.printStackTrace();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
public static SqlSessionManager getSessionManager(String config){
|
public static SqlSessionManager getSessionManager(String config){
|
||||||
if(sqlSessionManager == null){
|
if(sqlSessionManager == null){
|
||||||
synchronized (MybatisUtil.class) {
|
synchronized (MybatisUtil.class) {
|
||||||
if (sqlSessionManager == null) {
|
if (sqlSessionManager == null) {
|
||||||
init(config);
|
init(config);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
return sqlSessionManager;
|
return sqlSessionManager;
|
||||||
}
|
}
|
||||||
|
|
||||||
public static <T> T getMapper(Class<T> tClass){
|
public static <T> T getMapper(Class<T> tClass){
|
||||||
return sqlSessionManager.getMapper(tClass);
|
return sqlSessionManager.getMapper(tClass);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -3287,7 +3287,7 @@ public class Util extends weaver.general.Util {
|
||||||
throw new CustomerException("计划任务执行异常!异常信息:\n" + Util.getErrString(e));
|
throw new CustomerException("计划任务执行异常!异常信息:\n" + Util.getErrString(e));
|
||||||
}
|
}
|
||||||
|
|
||||||
getLogger().info(Util.logStr("\n\t计划任务 [{}] execute success!\n", cronJobClass.getName()));
|
getLogger().info(Util.logStr("\n\t计划任务 [{}] getDataId success!\n", cronJobClass.getName()));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
@ -3358,7 +3358,7 @@ public class Util extends weaver.general.Util {
|
||||||
if (Action.FAILURE_AND_CONTINUE.equals(execute)) {
|
if (Action.FAILURE_AND_CONTINUE.equals(execute)) {
|
||||||
throw new CustomerException("action执行失败,失败原因:\n" + requestInfo.getRequestManager().getMessagecontent());
|
throw new CustomerException("action执行失败,失败原因:\n" + requestInfo.getRequestManager().getMessagecontent());
|
||||||
}
|
}
|
||||||
getLogger().info(Util.logStr("\n\n\tAction [{}] execute success!\n", actionClass.getName()));
|
getLogger().info(Util.logStr("\n\n\tAction [{}] getDataId success!\n", actionClass.getName()));
|
||||||
}
|
}
|
||||||
|
|
||||||
public static String getSetMethodName(String fieldName) {
|
public static String getSetMethodName(String fieldName) {
|
||||||
|
|
|
@ -30,7 +30,7 @@ public abstract class CusBaseAction implements Action {
|
||||||
/**
|
/**
|
||||||
* 全局requestInfo对象
|
* 全局requestInfo对象
|
||||||
*/
|
*/
|
||||||
protected RequestInfo requestInfo;
|
protected RequestInfo globalRequestInfo;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* <h2>初始化流程默认的处理方法</h2>
|
* <h2>初始化流程默认的处理方法</h2>
|
||||||
|
@ -49,7 +49,7 @@ public abstract class CusBaseAction implements Action {
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public final String execute(RequestInfo requestInfo) {
|
public final String execute(RequestInfo requestInfo) {
|
||||||
this.requestInfo = requestInfo;
|
this.globalRequestInfo = requestInfo;
|
||||||
RequestManager requestManager = requestInfo.getRequestManager();
|
RequestManager requestManager = requestInfo.getRequestManager();
|
||||||
String billTable = requestManager.getBillTableName();
|
String billTable = requestManager.getBillTableName();
|
||||||
String requestId = requestInfo.getRequestid();
|
String requestId = requestInfo.getRequestid();
|
||||||
|
@ -105,14 +105,12 @@ public abstract class CusBaseAction implements Action {
|
||||||
*/
|
*/
|
||||||
public boolean exceptionCallback(Exception e, RequestManager requestManager) {
|
public boolean exceptionCallback(Exception e, RequestManager requestManager) {
|
||||||
e.printStackTrace();
|
e.printStackTrace();
|
||||||
log.error(Util.logStr("execute action fail, exception message is [{}], error stack trace msg is: \n{}",
|
log.error(Util.logStr("getDataId action fail, exception message is [{}], error stack trace msg is: \n{}",
|
||||||
e.getMessage(), Util.getErrString(e)));
|
e.getMessage(), Util.getErrString(e)));
|
||||||
Util.actionFail(requestManager, e.getMessage());
|
Util.actionFail(requestManager, e.getMessage());
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
;
|
|
||||||
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* <h2>流程其他流转类型处理方法注册</h2>
|
* <h2>流程其他流转类型处理方法注册</h2>
|
||||||
|
@ -199,9 +197,26 @@ public abstract class CusBaseAction implements Action {
|
||||||
*
|
*
|
||||||
* @return 流程主表数据
|
* @return 流程主表数据
|
||||||
*/
|
*/
|
||||||
|
@Deprecated
|
||||||
protected Map<String, String> getMainTableValue() {
|
protected Map<String, String> getMainTableValue() {
|
||||||
|
// 获取主表数据
|
||||||
|
Property[] propertyArr = globalRequestInfo.getMainTableInfo().getProperty();
|
||||||
|
return getStringMap(propertyArr);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* <h2>获取流程主表数据</h2>
|
||||||
|
*
|
||||||
|
* @return 流程主表数据
|
||||||
|
*/
|
||||||
|
protected Map<String, String> getMainTableValue(RequestInfo requestInfo) {
|
||||||
// 获取主表数据
|
// 获取主表数据
|
||||||
Property[] propertyArr = requestInfo.getMainTableInfo().getProperty();
|
Property[] propertyArr = requestInfo.getMainTableInfo().getProperty();
|
||||||
|
return getStringMap(propertyArr);
|
||||||
|
}
|
||||||
|
|
||||||
|
@NotNull
|
||||||
|
private Map<String, String> getStringMap(Property[] propertyArr) {
|
||||||
if (null == propertyArr) {
|
if (null == propertyArr) {
|
||||||
return Collections.emptyMap();
|
return Collections.emptyMap();
|
||||||
}
|
}
|
||||||
|
@ -220,8 +235,25 @@ public abstract class CusBaseAction implements Action {
|
||||||
*
|
*
|
||||||
* @return 以明细表需要为键,以明细表数据为值的键值对明细数据信息
|
* @return 以明细表需要为键,以明细表数据为值的键值对明细数据信息
|
||||||
*/
|
*/
|
||||||
|
@Deprecated
|
||||||
protected Map<String, List<Map<String, String>>> getDetailTableValue() {
|
protected Map<String, List<Map<String, String>>> getDetailTableValue() {
|
||||||
|
DetailTable[] detailTableArr = globalRequestInfo.getDetailTableInfo().getDetailTable();
|
||||||
|
return getListMap(detailTableArr);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* <h2>获取所有明细数据</h2>
|
||||||
|
*
|
||||||
|
* @return 以明细表需要为键,以明细表数据为值的键值对明细数据信息
|
||||||
|
*/
|
||||||
|
protected Map<String, List<Map<String, String>>> getDetailTableValue(RequestInfo requestInfo) {
|
||||||
DetailTable[] detailTableArr = requestInfo.getDetailTableInfo().getDetailTable();
|
DetailTable[] detailTableArr = requestInfo.getDetailTableInfo().getDetailTable();
|
||||||
|
return getListMap(detailTableArr);
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
@NotNull
|
||||||
|
private Map<String, List<Map<String, String>>> getListMap(DetailTable[] detailTableArr) {
|
||||||
Map<String, List<Map<String, String>>> detailDataList = new HashMap<>((int) Math.ceil(detailTableArr.length * 1.4));
|
Map<String, List<Map<String, String>>> detailDataList = new HashMap<>((int) Math.ceil(detailTableArr.length * 1.4));
|
||||||
for (DetailTable detailTable : detailTableArr) {
|
for (DetailTable detailTable : detailTableArr) {
|
||||||
List<Map<String, String>> detailData = getDetailValue(detailTable);
|
List<Map<String, String>> detailData = getDetailValue(detailTable);
|
||||||
|
@ -237,10 +269,21 @@ public abstract class CusBaseAction implements Action {
|
||||||
* @param detailNo 明细表编号
|
* @param detailNo 明细表编号
|
||||||
* @return 明细数据
|
* @return 明细数据
|
||||||
*/
|
*/
|
||||||
|
@Deprecated
|
||||||
protected List<Map<String, String>> getDetailTableValueByDetailNo(int detailNo) {
|
protected List<Map<String, String>> getDetailTableValueByDetailNo(int detailNo) {
|
||||||
|
DetailTable detailTable = globalRequestInfo.getDetailTableInfo().getDetailTable(detailNo);
|
||||||
|
return getDetailValue(detailTable);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* <h2>获取指定明细表的表数据</h2>
|
||||||
|
*
|
||||||
|
* @param detailNo 明细表编号
|
||||||
|
* @return 明细数据
|
||||||
|
*/
|
||||||
|
protected List<Map<String, String>> getDetailTableValueByDetailNo(int detailNo, RequestInfo requestInfo) {
|
||||||
DetailTable detailTable = requestInfo.getDetailTableInfo().getDetailTable(detailNo);
|
DetailTable detailTable = requestInfo.getDetailTableInfo().getDetailTable(detailNo);
|
||||||
List<Map<String, String>> detailData = getDetailValue(detailTable);
|
return getDetailValue(detailTable);
|
||||||
return detailData;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
|
|
@ -1,15 +1,15 @@
|
||||||
package aiyh.utils.annotation.recordset;
|
package aiyh.utils.annotation.recordset;
|
||||||
|
|
||||||
import java.lang.annotation.*;
|
import java.lang.annotation.*;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @author @author EBU7-dev1-ay
|
* @author @author EBU7-dev1-ay
|
||||||
* create 2021/12/21 0021 15:25
|
* create 2021/12/21 0021 15:25
|
||||||
* 是否开启大小写转换默认开启
|
* 是否开启大小写转换默认开启
|
||||||
*/
|
*/
|
||||||
@Retention(RetentionPolicy.RUNTIME)
|
@Retention(RetentionPolicy.RUNTIME)
|
||||||
@Target(ElementType.METHOD)
|
@Target(ElementType.METHOD)
|
||||||
@Documented
|
@Documented
|
||||||
public @interface CaseConversion {
|
public @interface CaseConversion {
|
||||||
boolean value() default true;
|
boolean value() default true;
|
||||||
}
|
}
|
||||||
|
|
|
@ -1,17 +1,17 @@
|
||||||
package aiyh.utils.annotation.recordset;
|
package aiyh.utils.annotation.recordset;
|
||||||
|
|
||||||
import java.lang.annotation.*;
|
import java.lang.annotation.*;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @author @author EBU7-dev1-ay
|
* @author @author EBU7-dev1-ay
|
||||||
* create 2021/12/19 0019 15:08
|
* create 2021/12/19 0019 15:08
|
||||||
*/
|
*/
|
||||||
|
|
||||||
@Retention(RetentionPolicy.RUNTIME)
|
@Retention(RetentionPolicy.RUNTIME)
|
||||||
@Target(ElementType.METHOD)
|
@Target(ElementType.METHOD)
|
||||||
@Documented
|
@Documented
|
||||||
public @interface Delete {
|
public @interface Delete {
|
||||||
String value() default "";
|
String value() default "";
|
||||||
// sql是否是在参数中
|
// sql是否是在参数中
|
||||||
boolean custom() default false;
|
boolean custom() default false;
|
||||||
}
|
}
|
||||||
|
|
|
@ -1,17 +1,17 @@
|
||||||
package aiyh.utils.annotation.recordset;
|
package aiyh.utils.annotation.recordset;
|
||||||
|
|
||||||
import java.lang.annotation.*;
|
import java.lang.annotation.*;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @author @author EBU7-dev1-ay
|
* @author @author EBU7-dev1-ay
|
||||||
* create 2021/12/19 0019 15:08
|
* create 2021/12/19 0019 15:08
|
||||||
*/
|
*/
|
||||||
|
|
||||||
@Retention(RetentionPolicy.RUNTIME)
|
@Retention(RetentionPolicy.RUNTIME)
|
||||||
@Target(ElementType.METHOD)
|
@Target(ElementType.METHOD)
|
||||||
@Documented
|
@Documented
|
||||||
public @interface Insert {
|
public @interface Insert {
|
||||||
String value() default "";
|
String value() default "";
|
||||||
// sql是否是在参数中
|
// sql是否是在参数中
|
||||||
boolean custom() default false;
|
boolean custom() default false;
|
||||||
}
|
}
|
||||||
|
|
|
@ -1,15 +1,15 @@
|
||||||
package aiyh.utils.annotation.recordset;
|
package aiyh.utils.annotation.recordset;
|
||||||
|
|
||||||
import java.lang.annotation.*;
|
import java.lang.annotation.*;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @author @author EBU7-dev1-ay
|
* @author @author EBU7-dev1-ay
|
||||||
* create 2021/12/19 0019 15:20
|
* create 2021/12/19 0019 15:20
|
||||||
*/
|
*/
|
||||||
|
|
||||||
@Retention(RetentionPolicy.RUNTIME)
|
@Retention(RetentionPolicy.RUNTIME)
|
||||||
@Target(ElementType.PARAMETER)
|
@Target(ElementType.PARAMETER)
|
||||||
@Documented
|
@Documented
|
||||||
public @interface ParamMapper {
|
public @interface ParamMapper {
|
||||||
String value();
|
String value();
|
||||||
}
|
}
|
||||||
|
|
|
@ -1,17 +1,17 @@
|
||||||
package aiyh.utils.annotation.recordset;
|
package aiyh.utils.annotation.recordset;
|
||||||
|
|
||||||
import java.lang.annotation.*;
|
import java.lang.annotation.*;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @author @author EBU7-dev1-ay
|
* @author @author EBU7-dev1-ay
|
||||||
* create 2021/12/19 0019 15:08
|
* create 2021/12/19 0019 15:08
|
||||||
*/
|
*/
|
||||||
|
|
||||||
@Retention(RetentionPolicy.RUNTIME)
|
@Retention(RetentionPolicy.RUNTIME)
|
||||||
@Target(ElementType.METHOD)
|
@Target(ElementType.METHOD)
|
||||||
@Documented
|
@Documented
|
||||||
public @interface Select {
|
public @interface Select {
|
||||||
String value() default "";
|
String value() default "";
|
||||||
// sql是否是在参数中
|
// sql是否是在参数中
|
||||||
boolean custom() default false;
|
boolean custom() default false;
|
||||||
}
|
}
|
||||||
|
|
|
@ -1,15 +1,15 @@
|
||||||
package aiyh.utils.annotation.recordset;
|
package aiyh.utils.annotation.recordset;
|
||||||
|
|
||||||
import java.lang.annotation.*;
|
import java.lang.annotation.*;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @author @author EBU7-dev1-ay
|
* @author @author EBU7-dev1-ay
|
||||||
* create 2021/12/19 0019 15:01
|
* create 2021/12/19 0019 15:01
|
||||||
*/
|
*/
|
||||||
|
|
||||||
@Retention(RetentionPolicy.RUNTIME)
|
@Retention(RetentionPolicy.RUNTIME)
|
||||||
@Target(ElementType.TYPE)
|
@Target(ElementType.TYPE)
|
||||||
@Documented
|
@Documented
|
||||||
public @interface SqlMapper {
|
public @interface SqlMapper {
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -1,13 +1,13 @@
|
||||||
package aiyh.utils.annotation.recordset;
|
package aiyh.utils.annotation.recordset;
|
||||||
|
|
||||||
import java.lang.annotation.*;
|
import java.lang.annotation.*;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @author @author EBU7-dev1-ay
|
* @author @author EBU7-dev1-ay
|
||||||
* create 2021/12/19 0019 15:31
|
* create 2021/12/19 0019 15:31
|
||||||
*/
|
*/
|
||||||
@Retention(RetentionPolicy.RUNTIME)
|
@Retention(RetentionPolicy.RUNTIME)
|
||||||
@Target(ElementType.PARAMETER)
|
@Target(ElementType.PARAMETER)
|
||||||
@Documented
|
@Documented
|
||||||
public @interface SqlString {
|
public @interface SqlString {
|
||||||
}
|
}
|
||||||
|
|
|
@ -1,17 +1,17 @@
|
||||||
package aiyh.utils.annotation.recordset;
|
package aiyh.utils.annotation.recordset;
|
||||||
|
|
||||||
import java.lang.annotation.*;
|
import java.lang.annotation.*;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @author @author EBU7-dev1-ay
|
* @author @author EBU7-dev1-ay
|
||||||
* create 2021/12/19 0019 15:08
|
* create 2021/12/19 0019 15:08
|
||||||
*/
|
*/
|
||||||
|
|
||||||
@Retention(RetentionPolicy.RUNTIME)
|
@Retention(RetentionPolicy.RUNTIME)
|
||||||
@Target(ElementType.METHOD)
|
@Target(ElementType.METHOD)
|
||||||
@Documented
|
@Documented
|
||||||
public @interface Update {
|
public @interface Update {
|
||||||
String value() default "";
|
String value() default "";
|
||||||
// sql是否是在参数中
|
// sql是否是在参数中
|
||||||
boolean custom() default false;
|
boolean custom() default false;
|
||||||
}
|
}
|
||||||
|
|
|
@ -1,18 +1,18 @@
|
||||||
package aiyh.utils.apirequest.core.factory;
|
package aiyh.utils.apirequest.core.factory;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* <p>抽象工厂</p>
|
* <p>抽象工厂</p>
|
||||||
* <p>create 2022/1/26 0026 12:03</p>
|
* <p>create 2022/1/26 0026 12:03</p>
|
||||||
*
|
*
|
||||||
* @author EBU7-dev1-ayh
|
* @author EBU7-dev1-ayh
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
|
||||||
public interface AbstractFactory {
|
public interface AbstractFactory {
|
||||||
/**
|
/**
|
||||||
* 创建参数处理工厂
|
* 创建参数处理工厂
|
||||||
* @param type 工厂类型
|
* @param type 工厂类型
|
||||||
* @return 参数处理工厂
|
* @return 参数处理工厂
|
||||||
*/
|
*/
|
||||||
<T> T createParamHandlerFactory(Class<T> type);
|
<T> T createParamHandlerFactory(Class<T> type);
|
||||||
}
|
}
|
||||||
|
|
|
@ -1,21 +1,21 @@
|
||||||
package aiyh.utils.apirequest.core.factory;
|
package aiyh.utils.apirequest.core.factory;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* <p></p>
|
* <p></p>
|
||||||
* <p>create 2022/1/26 0026 12:55</p>
|
* <p>create 2022/1/26 0026 12:55</p>
|
||||||
*
|
*
|
||||||
* @author EBU7-dev1-ayh
|
* @author EBU7-dev1-ayh
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
|
||||||
public class AbstractFactoryImpl implements AbstractFactory {
|
public class AbstractFactoryImpl implements AbstractFactory {
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public <T> T createParamHandlerFactory(Class<T> type) {
|
public <T> T createParamHandlerFactory(Class<T> type) {
|
||||||
|
|
||||||
if(ApiAsyncFactory.class.equals(type)){
|
if(ApiAsyncFactory.class.equals(type)){
|
||||||
return (T) new ApiAsyncFactory();
|
return (T) new ApiAsyncFactory();
|
||||||
}
|
}
|
||||||
return null;
|
return null;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -1,19 +1,19 @@
|
||||||
package aiyh.utils.apirequest.core.factory;
|
package aiyh.utils.apirequest.core.factory;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* <p>参数处理工厂接口</p>
|
* <p>参数处理工厂接口</p>
|
||||||
* <p>create 2022/1/24 0024 10:59</p>
|
* <p>create 2022/1/24 0024 10:59</p>
|
||||||
*
|
*
|
||||||
* @author EBU7-dev1-ayh
|
* @author EBU7-dev1-ayh
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
|
||||||
public interface TypeHandlerFactory<R,V> {
|
public interface TypeHandlerFactory<R,V> {
|
||||||
/**
|
/**
|
||||||
* 创建参数处理对象工厂方法
|
* 创建参数处理对象工厂方法
|
||||||
* @param factoryEnum 工厂类型枚举
|
* @param factoryEnum 工厂类型枚举
|
||||||
* @return 产生的对象
|
* @return 产生的对象
|
||||||
*/
|
*/
|
||||||
|
|
||||||
public R createParamHandler(V factoryEnum);
|
public R createParamHandler(V factoryEnum);
|
||||||
}
|
}
|
||||||
|
|
|
@ -1,32 +1,32 @@
|
||||||
package aiyh.utils.apirequest.entity;
|
package aiyh.utils.apirequest.entity;
|
||||||
|
|
||||||
import lombok.Getter;
|
import lombok.Getter;
|
||||||
import lombok.Setter;
|
import lombok.Setter;
|
||||||
import lombok.ToString;
|
import lombok.ToString;
|
||||||
import weaver.hrm.User;
|
import weaver.hrm.User;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* <p>api请求参数所需的基本参数</p>
|
* <p>api请求参数所需的基本参数</p>
|
||||||
* <p>create 2022/1/28 0028 9:16</p>
|
* <p>create 2022/1/28 0028 9:16</p>
|
||||||
*
|
*
|
||||||
* @author EBU7-dev1-ayh
|
* @author EBU7-dev1-ayh
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
|
||||||
@Setter
|
@Setter
|
||||||
@Getter
|
@Getter
|
||||||
@ToString
|
@ToString
|
||||||
public class ApiBaseInfo {
|
public class ApiBaseInfo {
|
||||||
/**
|
/**
|
||||||
* 流程requestId
|
* 流程requestId
|
||||||
*/
|
*/
|
||||||
private String requestId;
|
private String requestId;
|
||||||
/**
|
/**
|
||||||
* 流程id
|
* 流程id
|
||||||
*/
|
*/
|
||||||
private String workflowId;
|
private String workflowId;
|
||||||
/**
|
/**
|
||||||
* 当前请求用户
|
* 当前请求用户
|
||||||
*/
|
*/
|
||||||
private User user;
|
private User user;
|
||||||
}
|
}
|
||||||
|
|
|
@ -1,85 +1,85 @@
|
||||||
package aiyh.utils.apirequest.entity;
|
package aiyh.utils.apirequest.entity;
|
||||||
|
|
||||||
import lombok.Getter;
|
import lombok.Getter;
|
||||||
import lombok.Setter;
|
import lombok.Setter;
|
||||||
import lombok.ToString;
|
import lombok.ToString;
|
||||||
|
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* <p>请求参数必要类</p>
|
* <p>请求参数必要类</p>
|
||||||
* <p>create 2022/1/27 0027 16:07</p>
|
* <p>create 2022/1/27 0027 16:07</p>
|
||||||
*
|
*
|
||||||
* @author EBU7-dev1-ayh
|
* @author EBU7-dev1-ayh
|
||||||
*/
|
*/
|
||||||
|
|
||||||
@Getter
|
@Getter
|
||||||
@Setter
|
@Setter
|
||||||
@ToString
|
@ToString
|
||||||
public class ApiRequestData {
|
public class ApiRequestData {
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* 主表id
|
* 主表id
|
||||||
*/
|
*/
|
||||||
private Integer id;
|
private Integer id;
|
||||||
/**
|
/**
|
||||||
* api地址
|
* api地址
|
||||||
*/
|
*/
|
||||||
private String apiUrl;
|
private String apiUrl;
|
||||||
/**
|
/**
|
||||||
* 测试环境api地址
|
* 测试环境api地址
|
||||||
*/
|
*/
|
||||||
private String testApiUrl;
|
private String testApiUrl;
|
||||||
/**
|
/**
|
||||||
* 请求方式
|
* 请求方式
|
||||||
*/
|
*/
|
||||||
private Integer requestType;
|
private Integer requestType;
|
||||||
/**
|
/**
|
||||||
* api启用类型
|
* api启用类型
|
||||||
*/
|
*/
|
||||||
private Integer apiType;
|
private Integer apiType;
|
||||||
/**
|
/**
|
||||||
* 数据来源
|
* 数据来源
|
||||||
*/
|
*/
|
||||||
private Integer dataSource;
|
private Integer dataSource;
|
||||||
/**
|
/**
|
||||||
* api接口描述
|
* api接口描述
|
||||||
*/
|
*/
|
||||||
private String apiDesc;
|
private String apiDesc;
|
||||||
/**
|
/**
|
||||||
* 流程类型
|
* 流程类型
|
||||||
*/
|
*/
|
||||||
private String workflowType;
|
private String workflowType;
|
||||||
/**
|
/**
|
||||||
* 建模表表名
|
* 建模表表名
|
||||||
*/
|
*/
|
||||||
private String modelTableName;
|
private String modelTableName;
|
||||||
/**
|
/**
|
||||||
* 参数请求方式
|
* 参数请求方式
|
||||||
*/
|
*/
|
||||||
private Integer paramRequestType;
|
private Integer paramRequestType;
|
||||||
/**
|
/**
|
||||||
* 请求参数的数据来源,适用于参数请求方式为明细表模式
|
* 请求参数的数据来源,适用于参数请求方式为明细表模式
|
||||||
*/
|
*/
|
||||||
private String requestDetailTableName;
|
private String requestDetailTableName;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* 唯一标识
|
* 唯一标识
|
||||||
*/
|
*/
|
||||||
private String onlyMark;
|
private String onlyMark;
|
||||||
/**
|
/**
|
||||||
* 请求参数信息
|
* 请求参数信息
|
||||||
*/
|
*/
|
||||||
private List<ApiRequestParamData> paramDetailList;
|
private List<ApiRequestParamData> paramDetailList;
|
||||||
/**
|
/**
|
||||||
* 请求头信息
|
* 请求头信息
|
||||||
*/
|
*/
|
||||||
private List<ApiRequestHeardData> heardDetailList;
|
private List<ApiRequestHeardData> heardDetailList;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* api请求基本信息
|
* api请求基本信息
|
||||||
*/
|
*/
|
||||||
private ApiBaseInfo apiBaseInfo;
|
private ApiBaseInfo apiBaseInfo;
|
||||||
|
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -1,14 +1,14 @@
|
||||||
package aiyh.utils.apirequest.entity;
|
package aiyh.utils.apirequest.entity;
|
||||||
|
|
||||||
import aiyh.utils.apirequest.pojo.ApiRequestHeardDetail;
|
import aiyh.utils.apirequest.pojo.ApiRequestHeardDetail;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* <p>api 请求头参数业务处理对象</p>
|
* <p>api 请求头参数业务处理对象</p>
|
||||||
* <p>create 2022/2/8 0008 11:15</p>
|
* <p>create 2022/2/8 0008 11:15</p>
|
||||||
*
|
*
|
||||||
* @author EBU7-dev1-ayh
|
* @author EBU7-dev1-ayh
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
|
||||||
public class ApiRequestHeardData extends ApiRequestHeardDetail {
|
public class ApiRequestHeardData extends ApiRequestHeardDetail {
|
||||||
}
|
}
|
||||||
|
|
|
@ -1,21 +1,21 @@
|
||||||
package aiyh.utils.apirequest.entity;
|
package aiyh.utils.apirequest.entity;
|
||||||
|
|
||||||
import aiyh.utils.apirequest.pojo.ApiRequestParamDetail;
|
import aiyh.utils.apirequest.pojo.ApiRequestParamDetail;
|
||||||
import lombok.Data;
|
import lombok.Data;
|
||||||
import lombok.EqualsAndHashCode;
|
import lombok.EqualsAndHashCode;
|
||||||
|
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* <p>Api 请求参数配置业务对象</p>
|
* <p>Api 请求参数配置业务对象</p>
|
||||||
* <p>create 2022/1/28 0028 12:09</p>
|
* <p>create 2022/1/28 0028 12:09</p>
|
||||||
*
|
*
|
||||||
* @author EBU7-dev1-ayh
|
* @author EBU7-dev1-ayh
|
||||||
*/
|
*/
|
||||||
|
|
||||||
@EqualsAndHashCode(callSuper = true)
|
@EqualsAndHashCode(callSuper = true)
|
||||||
@Data
|
@Data
|
||||||
public class ApiRequestParamData extends ApiRequestParamDetail {
|
public class ApiRequestParamData extends ApiRequestParamDetail {
|
||||||
private List<ApiRequestParamData> childList;
|
private List<ApiRequestParamData> childList;
|
||||||
private List<ParamInfo> paramInfoList;
|
private List<ParamInfo> paramInfoList;
|
||||||
}
|
}
|
||||||
|
|
|
@ -1,24 +1,24 @@
|
||||||
package aiyh.utils.apirequest.entity;
|
package aiyh.utils.apirequest.entity;
|
||||||
|
|
||||||
import lombok.Data;
|
import lombok.Data;
|
||||||
|
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* <p>请求头信息</p>
|
* <p>请求头信息</p>
|
||||||
* <p>create 2022/1/23 0023 21:09</p>
|
* <p>create 2022/1/23 0023 21:09</p>
|
||||||
*
|
*
|
||||||
* @author EBU7-dev1-ayh
|
* @author EBU7-dev1-ayh
|
||||||
*/
|
*/
|
||||||
|
|
||||||
@Data
|
@Data
|
||||||
public class HeardInfo {
|
public class HeardInfo {
|
||||||
/**
|
/**
|
||||||
* 参数名称
|
* 参数名称
|
||||||
*/
|
*/
|
||||||
private String heardName;
|
private String heardName;
|
||||||
/**
|
/**
|
||||||
* 参数值
|
* 参数值
|
||||||
*/
|
*/
|
||||||
private String heardValue;
|
private String heardValue;
|
||||||
}
|
}
|
||||||
|
|
|
@ -1,69 +1,69 @@
|
||||||
package aiyh.utils.apirequest.entity;
|
package aiyh.utils.apirequest.entity;
|
||||||
|
|
||||||
import lombok.Data;
|
import lombok.Data;
|
||||||
|
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* <p>配置信息</p>
|
* <p>配置信息</p>
|
||||||
* <p>create 2022/1/23 0023 21:08</p>
|
* <p>create 2022/1/23 0023 21:08</p>
|
||||||
*
|
*
|
||||||
* @author EBU7-dev1-ayh
|
* @author EBU7-dev1-ayh
|
||||||
*/
|
*/
|
||||||
|
|
||||||
@Data
|
@Data
|
||||||
public class ParamConfigInfo {
|
public class ParamConfigInfo {
|
||||||
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* 配置主表id
|
* 配置主表id
|
||||||
*/
|
*/
|
||||||
private Integer id;
|
private Integer id;
|
||||||
/**
|
/**
|
||||||
* api地址
|
* api地址
|
||||||
*/
|
*/
|
||||||
private String apiUrl;
|
private String apiUrl;
|
||||||
/**
|
/**
|
||||||
* 测试环境api地址
|
* 测试环境api地址
|
||||||
*/
|
*/
|
||||||
private String testApiUrl;
|
private String testApiUrl;
|
||||||
/**
|
/**
|
||||||
* 请求方式
|
* 请求方式
|
||||||
*/
|
*/
|
||||||
private Integer requestType;
|
private Integer requestType;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* 数据来源
|
* 数据来源
|
||||||
*/
|
*/
|
||||||
private Integer dataSource;
|
private Integer dataSource;
|
||||||
/**
|
/**
|
||||||
* api接口描述
|
* api接口描述
|
||||||
*/
|
*/
|
||||||
private String apiDesc;
|
private String apiDesc;
|
||||||
/**
|
/**
|
||||||
* 流程类型
|
* 流程类型
|
||||||
*/
|
*/
|
||||||
private String workflowType;
|
private String workflowType;
|
||||||
/**
|
/**
|
||||||
* 建模表表名
|
* 建模表表名
|
||||||
*/
|
*/
|
||||||
private String modelTableName;
|
private String modelTableName;
|
||||||
/**
|
/**
|
||||||
* 参数请求方式
|
* 参数请求方式
|
||||||
*/
|
*/
|
||||||
private Integer paramRequestType;
|
private Integer paramRequestType;
|
||||||
/**
|
/**
|
||||||
* 请求参数的数据来源,适用于参数请求方式为明细表模式
|
* 请求参数的数据来源,适用于参数请求方式为明细表模式
|
||||||
*/
|
*/
|
||||||
private String requestDetailTableName;
|
private String requestDetailTableName;
|
||||||
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* 参数信息
|
* 参数信息
|
||||||
*/
|
*/
|
||||||
private List<ParamInfo> paramInfoList;
|
private List<ParamInfo> paramInfoList;
|
||||||
/**
|
/**
|
||||||
* 请求头信息
|
* 请求头信息
|
||||||
*/
|
*/
|
||||||
private List<HeardInfo> heardInfoList;
|
private List<HeardInfo> heardInfoList;
|
||||||
}
|
}
|
||||||
|
|
|
@ -1,36 +1,36 @@
|
||||||
package aiyh.utils.apirequest.entity;
|
package aiyh.utils.apirequest.entity;
|
||||||
|
|
||||||
import lombok.Data;
|
import lombok.Data;
|
||||||
|
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* <p>参数信息</p>
|
* <p>参数信息</p>
|
||||||
* <p>create 2022/1/23 0023 21:04</p>
|
* <p>create 2022/1/23 0023 21:04</p>
|
||||||
*
|
*
|
||||||
* @author EBU7-dev1-ayh
|
* @author EBU7-dev1-ayh
|
||||||
*/
|
*/
|
||||||
|
|
||||||
@Data
|
@Data
|
||||||
public class ParamInfo {
|
public class ParamInfo {
|
||||||
/**
|
/**
|
||||||
* 行号
|
* 行号
|
||||||
*/
|
*/
|
||||||
private Integer lineNum;
|
private Integer lineNum;
|
||||||
/**
|
/**
|
||||||
* 参数名称
|
* 参数名称
|
||||||
*/
|
*/
|
||||||
private String paramName;
|
private String paramName;
|
||||||
/**
|
/**
|
||||||
* 参数值
|
* 参数值
|
||||||
*/
|
*/
|
||||||
private Object paramValue;
|
private Object paramValue;
|
||||||
/**
|
/**
|
||||||
* 所属 父级参数名
|
* 所属 父级参数名
|
||||||
*/
|
*/
|
||||||
private Integer parentLine;
|
private Integer parentLine;
|
||||||
/**
|
/**
|
||||||
* 子节点
|
* 子节点
|
||||||
*/
|
*/
|
||||||
private List<ParamInfo> childList;
|
private List<ParamInfo> childList;
|
||||||
}
|
}
|
||||||
|
|
|
@ -1,26 +1,26 @@
|
||||||
package aiyh.utils.apirequest.entity;
|
package aiyh.utils.apirequest.entity;
|
||||||
|
|
||||||
import java.util.Map;
|
import java.util.Map;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* <p>解析后的参数</p>
|
* <p>解析后的参数</p>
|
||||||
* <p>create 2022/1/23 0023 20:33</p>
|
* <p>create 2022/1/23 0023 20:33</p>
|
||||||
*
|
*
|
||||||
* @author EBU7-dev1-ayh
|
* @author EBU7-dev1-ayh
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
|
||||||
public class ParseAfterData {
|
public class ParseAfterData {
|
||||||
/**
|
/**
|
||||||
* 是否自动发送请求
|
* 是否自动发送请求
|
||||||
*/
|
*/
|
||||||
private boolean autoRequest;
|
private boolean autoRequest;
|
||||||
/**
|
/**
|
||||||
* 请求参数
|
* 请求参数
|
||||||
*/
|
*/
|
||||||
private Map<String,Object> requestData;
|
private Map<String,Object> requestData;
|
||||||
/**
|
/**
|
||||||
* 请求头信息
|
* 请求头信息
|
||||||
*/
|
*/
|
||||||
private Map<String,Object> requestHeard;
|
private Map<String,Object> requestHeard;
|
||||||
}
|
}
|
||||||
|
|
|
@ -1,48 +1,48 @@
|
||||||
package aiyh.utils.apirequest.enumtype;
|
package aiyh.utils.apirequest.enumtype;
|
||||||
|
|
||||||
import java.util.EnumSet;
|
import java.util.EnumSet;
|
||||||
import java.util.HashMap;
|
import java.util.HashMap;
|
||||||
import java.util.Map;
|
import java.util.Map;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* <p>参数处理类型枚举</p>
|
* <p>参数处理类型枚举</p>
|
||||||
* <p>create 2022/1/26 0026 10:43</p>
|
* <p>create 2022/1/26 0026 10:43</p>
|
||||||
*
|
*
|
||||||
* @author EBU7-dev1-ayh
|
* @author EBU7-dev1-ayh
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
|
||||||
public enum DataSourceRuleEnum {
|
public enum DataSourceRuleEnum {
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* 流程
|
* 流程
|
||||||
*/
|
*/
|
||||||
WORKFLOW_DATA(0),
|
WORKFLOW_DATA(0),
|
||||||
/**
|
/**
|
||||||
* 建模表
|
* 建模表
|
||||||
*/
|
*/
|
||||||
MODEL_DATA(1);
|
MODEL_DATA(1);
|
||||||
|
|
||||||
private static final Map<Integer, DataSourceRuleEnum> LOOKUP;
|
private static final Map<Integer, DataSourceRuleEnum> LOOKUP;
|
||||||
|
|
||||||
static {
|
static {
|
||||||
LOOKUP = new HashMap<>();
|
LOOKUP = new HashMap<>();
|
||||||
for (DataSourceRuleEnum enumType : EnumSet.allOf(DataSourceRuleEnum.class)) {
|
for (DataSourceRuleEnum enumType : EnumSet.allOf(DataSourceRuleEnum.class)) {
|
||||||
LOOKUP.put(enumType.getValue(), enumType);
|
LOOKUP.put(enumType.getValue(), enumType);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
private final int value;
|
private final int value;
|
||||||
|
|
||||||
DataSourceRuleEnum(int value) {
|
DataSourceRuleEnum(int value) {
|
||||||
this.value = value;
|
this.value = value;
|
||||||
}
|
}
|
||||||
|
|
||||||
public static DataSourceRuleEnum get(int value) {
|
public static DataSourceRuleEnum get(int value) {
|
||||||
return LOOKUP.get(value);
|
return LOOKUP.get(value);
|
||||||
}
|
}
|
||||||
|
|
||||||
public int getValue() {
|
public int getValue() {
|
||||||
return this.value;
|
return this.value;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -1,67 +1,67 @@
|
||||||
package aiyh.utils.apirequest.enumtype;
|
package aiyh.utils.apirequest.enumtype;
|
||||||
|
|
||||||
import java.util.EnumSet;
|
import java.util.EnumSet;
|
||||||
import java.util.HashMap;
|
import java.util.HashMap;
|
||||||
import java.util.Map;
|
import java.util.Map;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* <p>参数类型枚举</p>
|
* <p>参数类型枚举</p>
|
||||||
* <p>create 2022/1/25 0025 10:36</p>
|
* <p>create 2022/1/25 0025 10:36</p>
|
||||||
*
|
*
|
||||||
* @author EBU7-dev1-ayh
|
* @author EBU7-dev1-ayh
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
|
||||||
public enum ParamTypeEnum {
|
public enum ParamTypeEnum {
|
||||||
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* string 类型
|
* string 类型
|
||||||
*/
|
*/
|
||||||
STRING_TYPE(0),
|
STRING_TYPE(0),
|
||||||
/**
|
/**
|
||||||
* long 类型
|
* long 类型
|
||||||
*/
|
*/
|
||||||
LONG_TYPE(1),
|
LONG_TYPE(1),
|
||||||
/**
|
/**
|
||||||
* boolean类型
|
* boolean类型
|
||||||
*/
|
*/
|
||||||
BOOLEAN_TYPE(2),
|
BOOLEAN_TYPE(2),
|
||||||
/**
|
/**
|
||||||
* object 类型
|
* object 类型
|
||||||
*/
|
*/
|
||||||
OBJECT_TYPE(3),
|
OBJECT_TYPE(3),
|
||||||
/**
|
/**
|
||||||
* list类型
|
* list类型
|
||||||
*/
|
*/
|
||||||
LIST_TYPE(4),
|
LIST_TYPE(4),
|
||||||
/**
|
/**
|
||||||
* double 类型
|
* double 类型
|
||||||
*/
|
*/
|
||||||
DOUBLE_TYPE(5);
|
DOUBLE_TYPE(5);
|
||||||
|
|
||||||
|
|
||||||
private static final Map<Integer, ParamTypeEnum> LOOKUP;
|
private static final Map<Integer, ParamTypeEnum> LOOKUP;
|
||||||
|
|
||||||
static {
|
static {
|
||||||
LOOKUP = new HashMap<>();
|
LOOKUP = new HashMap<>();
|
||||||
for (ParamTypeEnum enumType : EnumSet.allOf(ParamTypeEnum.class)) {
|
for (ParamTypeEnum enumType : EnumSet.allOf(ParamTypeEnum.class)) {
|
||||||
LOOKUP.put(enumType.getValue(), enumType);
|
LOOKUP.put(enumType.getValue(), enumType);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
private final int value;
|
private final int value;
|
||||||
|
|
||||||
ParamTypeEnum(int value) {
|
ParamTypeEnum(int value) {
|
||||||
this.value = value;
|
this.value = value;
|
||||||
}
|
}
|
||||||
|
|
||||||
public static ParamTypeEnum get(int value) {
|
public static ParamTypeEnum get(int value) {
|
||||||
return LOOKUP.get(value);
|
return LOOKUP.get(value);
|
||||||
}
|
}
|
||||||
|
|
||||||
public int getValue() {
|
public int getValue() {
|
||||||
return this.value;
|
return this.value;
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -1,83 +1,83 @@
|
||||||
package aiyh.utils.apirequest.enumtype;
|
package aiyh.utils.apirequest.enumtype;
|
||||||
|
|
||||||
import java.util.EnumSet;
|
import java.util.EnumSet;
|
||||||
import java.util.HashMap;
|
import java.util.HashMap;
|
||||||
import java.util.Map;
|
import java.util.Map;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* <p>取值方式枚举</p>
|
* <p>取值方式枚举</p>
|
||||||
* <p>create 2022/1/25 0025 10:16</p>
|
* <p>create 2022/1/25 0025 10:16</p>
|
||||||
*
|
*
|
||||||
* @author EBU7-dev1-ayh
|
* @author EBU7-dev1-ayh
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
|
||||||
public enum ParamValueRuleEnum {
|
public enum ParamValueRuleEnum {
|
||||||
/**
|
/**
|
||||||
* 空值
|
* 空值
|
||||||
*/
|
*/
|
||||||
NULL_VALUE(0),
|
NULL_VALUE(0),
|
||||||
/**
|
/**
|
||||||
* 固定值
|
* 固定值
|
||||||
*/
|
*/
|
||||||
FIXED_VALUE(1),
|
FIXED_VALUE(1),
|
||||||
/**
|
/**
|
||||||
* 系统字段
|
* 系统字段
|
||||||
*/
|
*/
|
||||||
SYSTEM_FIELD(2),
|
SYSTEM_FIELD(2),
|
||||||
/**
|
/**
|
||||||
* 自定义SQL
|
* 自定义SQL
|
||||||
*/
|
*/
|
||||||
CUSTOMER_SQL(3),
|
CUSTOMER_SQL(3),
|
||||||
/**
|
/**
|
||||||
* 当前时间
|
* 当前时间
|
||||||
*/
|
*/
|
||||||
CURRENT_TIME(4),
|
CURRENT_TIME(4),
|
||||||
/**
|
/**
|
||||||
* 流程请求id
|
* 流程请求id
|
||||||
*/
|
*/
|
||||||
REQUEST_ID(5),
|
REQUEST_ID(5),
|
||||||
/**
|
/**
|
||||||
* 流程id
|
* 流程id
|
||||||
*/
|
*/
|
||||||
WORKFLOW_ID(6),
|
WORKFLOW_ID(6),
|
||||||
/**
|
/**
|
||||||
* 随机值
|
* 随机值
|
||||||
*/
|
*/
|
||||||
RANDOM_VALUE(7),
|
RANDOM_VALUE(7),
|
||||||
/**
|
/**
|
||||||
* 附件
|
* 附件
|
||||||
*/
|
*/
|
||||||
ATTACHMENT_FILE(8),
|
ATTACHMENT_FILE(8),
|
||||||
/**
|
/**
|
||||||
* 时间戳
|
* 时间戳
|
||||||
*/
|
*/
|
||||||
TIME_STAMP(9),
|
TIME_STAMP(9),
|
||||||
/**
|
/**
|
||||||
* SQL字段
|
* SQL字段
|
||||||
*/
|
*/
|
||||||
SQL_FIELD(10);
|
SQL_FIELD(10);
|
||||||
|
|
||||||
private static final Map<Integer, ParamValueRuleEnum> LOOKUP;
|
private static final Map<Integer, ParamValueRuleEnum> LOOKUP;
|
||||||
|
|
||||||
static {
|
static {
|
||||||
LOOKUP = new HashMap<>();
|
LOOKUP = new HashMap<>();
|
||||||
for (ParamValueRuleEnum enumType : EnumSet.allOf(ParamValueRuleEnum.class)) {
|
for (ParamValueRuleEnum enumType : EnumSet.allOf(ParamValueRuleEnum.class)) {
|
||||||
LOOKUP.put(enumType.getValue(), enumType);
|
LOOKUP.put(enumType.getValue(), enumType);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
private final int value;
|
private final int value;
|
||||||
|
|
||||||
ParamValueRuleEnum(int value) {
|
ParamValueRuleEnum(int value) {
|
||||||
this.value = value;
|
this.value = value;
|
||||||
}
|
}
|
||||||
|
|
||||||
public static ParamValueRuleEnum get(int value) {
|
public static ParamValueRuleEnum get(int value) {
|
||||||
return LOOKUP.get(value);
|
return LOOKUP.get(value);
|
||||||
}
|
}
|
||||||
|
|
||||||
public int getValue() {
|
public int getValue() {
|
||||||
return this.value;
|
return this.value;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -1,51 +1,51 @@
|
||||||
package aiyh.utils.apirequest.interceptor;
|
package aiyh.utils.apirequest.interceptor;
|
||||||
|
|
||||||
import aiyh.utils.apirequest.entity.ParamConfigInfo;
|
import aiyh.utils.apirequest.entity.ParamConfigInfo;
|
||||||
import aiyh.utils.apirequest.entity.ParseAfterData;
|
import aiyh.utils.apirequest.entity.ParseAfterData;
|
||||||
import aiyh.utils.apirequest.pojo.ApiRequestMain;
|
import aiyh.utils.apirequest.pojo.ApiRequestMain;
|
||||||
import aiyh.utils.httpUtil.ResponeVo;
|
import aiyh.utils.httpUtil.ResponeVo;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* <p>api 请求工具类拦截器</p>
|
* <p>api 请求工具类拦截器</p>
|
||||||
* <p>create 2022/1/22 0022 20:19</p>
|
* <p>create 2022/1/22 0022 20:19</p>
|
||||||
*
|
*
|
||||||
* @author EBU7-dev1-ayh
|
* @author EBU7-dev1-ayh
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
|
||||||
public interface ApiRequestInterceptor {
|
public interface ApiRequestInterceptor {
|
||||||
/**
|
/**
|
||||||
* 值解析前;拦截器'
|
* 值解析前;拦截器'
|
||||||
* @param apiRequestMain 数据库配置数据信息
|
* @param apiRequestMain 数据库配置数据信息
|
||||||
* @return 数据库配置数据
|
* @return 数据库配置数据
|
||||||
*/
|
*/
|
||||||
public ApiRequestMain parseBefore(ApiRequestMain apiRequestMain);
|
public ApiRequestMain parseBefore(ApiRequestMain apiRequestMain);
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* 解析值之后拦截器
|
* 解析值之后拦截器
|
||||||
* @param paramConfigInfo 解析后的值
|
* @param paramConfigInfo 解析后的值
|
||||||
* @return 值解析后的数据
|
* @return 值解析后的数据
|
||||||
*/
|
*/
|
||||||
public ParamConfigInfo parseAfter(ParamConfigInfo paramConfigInfo);
|
public ParamConfigInfo parseAfter(ParamConfigInfo paramConfigInfo);
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* 解析成树形结构之后拦截器
|
* 解析成树形结构之后拦截器
|
||||||
* @param paramConfigTreeInfo 树形结构的请求参数配置信息
|
* @param paramConfigTreeInfo 树形结构的请求参数配置信息
|
||||||
* @return 树形结构的请求参数配置信息
|
* @return 树形结构的请求参数配置信息
|
||||||
*/
|
*/
|
||||||
public ParamConfigInfo parseTreeAfter(ParamConfigInfo paramConfigTreeInfo);
|
public ParamConfigInfo parseTreeAfter(ParamConfigInfo paramConfigTreeInfo);
|
||||||
/**
|
/**
|
||||||
* 请求前拦截器
|
* 请求前拦截器
|
||||||
* @param parseAfterData 参数树形解析后参数
|
* @param parseAfterData 参数树形解析后参数
|
||||||
* @return 最终请求参数
|
* @return 最终请求参数
|
||||||
*/
|
*/
|
||||||
public ParseAfterData requestBefore(ParseAfterData parseAfterData);
|
public ParseAfterData requestBefore(ParseAfterData parseAfterData);
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* 请求完成后回调
|
* 请求完成后回调
|
||||||
* @param isSuccess 是否请求成功
|
* @param isSuccess 是否请求成功
|
||||||
* @param responeVo 响应结果信息
|
* @param responeVo 响应结果信息
|
||||||
*/
|
*/
|
||||||
public void requestAfter(ResponeVo responeVo,boolean isSuccess);
|
public void requestAfter(ResponeVo responeVo,boolean isSuccess);
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -1,53 +1,53 @@
|
||||||
package aiyh.utils.apirequest.mapper;
|
package aiyh.utils.apirequest.mapper;
|
||||||
|
|
||||||
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.apirequest.pojo.ApiRequestHeardDetail;
|
import aiyh.utils.apirequest.pojo.ApiRequestHeardDetail;
|
||||||
import aiyh.utils.apirequest.pojo.ApiRequestMain;
|
import aiyh.utils.apirequest.pojo.ApiRequestMain;
|
||||||
import aiyh.utils.apirequest.pojo.ApiRequestParamDetail;
|
import aiyh.utils.apirequest.pojo.ApiRequestParamDetail;
|
||||||
|
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* <p>查询数据库数据接口</p>
|
* <p>查询数据库数据接口</p>
|
||||||
* <p>create 2022/1/23 0023 17:52</p>
|
* <p>create 2022/1/23 0023 17:52</p>
|
||||||
*
|
*
|
||||||
* @author EBU7-dev1-ayh
|
* @author EBU7-dev1-ayh
|
||||||
*/
|
*/
|
||||||
|
|
||||||
@SqlMapper
|
@SqlMapper
|
||||||
public interface ApiRequestMapper {
|
public interface ApiRequestMapper {
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* 查询请求参数主表配置信息
|
* 查询请求参数主表配置信息
|
||||||
* @param onlyMark 唯一标识
|
* @param onlyMark 唯一标识
|
||||||
* @return 主表配置信息
|
* @return 主表配置信息
|
||||||
*/
|
*/
|
||||||
@Select("")
|
@Select("")
|
||||||
public ApiRequestMain selectApiConfigByOnlyMark(@ParamMapper("onlyMark") String onlyMark);
|
public ApiRequestMain selectApiConfigByOnlyMark(@ParamMapper("onlyMark") String onlyMark);
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* 查询请求参数主表配置信息
|
* 查询请求参数主表配置信息
|
||||||
* @param id id
|
* @param id id
|
||||||
* @return 主表配置信息
|
* @return 主表配置信息
|
||||||
*/
|
*/
|
||||||
@Select("")
|
@Select("")
|
||||||
public ApiRequestMain selectApiConfigById(@ParamMapper("id") int id);
|
public ApiRequestMain selectApiConfigById(@ParamMapper("id") int id);
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* 根据主表id查询请求参数配置信息
|
* 根据主表id查询请求参数配置信息
|
||||||
* @param mainId 主表id
|
* @param mainId 主表id
|
||||||
* @return 请求参数配置信息
|
* @return 请求参数配置信息
|
||||||
*/
|
*/
|
||||||
@Select("")
|
@Select("")
|
||||||
public List<ApiRequestParamDetail> selectApiParamListByMainId(@ParamMapper("mainId") int mainId);
|
public List<ApiRequestParamDetail> selectApiParamListByMainId(@ParamMapper("mainId") int mainId);
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* 个女警主表id查询请求头配置信息
|
* 个女警主表id查询请求头配置信息
|
||||||
* @param mainId 主表id
|
* @param mainId 主表id
|
||||||
* @return 请求头配置信息
|
* @return 请求头配置信息
|
||||||
*/
|
*/
|
||||||
@Select("")
|
@Select("")
|
||||||
public List<ApiRequestHeardDetail> selectApiHeardListByMainId(@ParamMapper("mainId") int mainId);
|
public List<ApiRequestHeardDetail> selectApiHeardListByMainId(@ParamMapper("mainId") int mainId);
|
||||||
}
|
}
|
||||||
|
|
|
@ -1,40 +1,40 @@
|
||||||
package aiyh.utils.apirequest.mapper;
|
package aiyh.utils.apirequest.mapper;
|
||||||
|
|
||||||
import aiyh.utils.annotation.recordset.CaseConversion;
|
import aiyh.utils.annotation.recordset.CaseConversion;
|
||||||
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 java.util.List;
|
import java.util.List;
|
||||||
import java.util.Map;
|
import java.util.Map;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* <p>数据来源逻辑处理查询数据库</p>
|
* <p>数据来源逻辑处理查询数据库</p>
|
||||||
* <p>create 2022/1/26 0026 14:10</p>
|
* <p>create 2022/1/26 0026 14:10</p>
|
||||||
*
|
*
|
||||||
* @author EBU7-dev1-ayh
|
* @author EBU7-dev1-ayh
|
||||||
*/
|
*/
|
||||||
|
|
||||||
@SqlMapper
|
@SqlMapper
|
||||||
public interface DataSourceMapper {
|
public interface DataSourceMapper {
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* 根据流程id查询流程表
|
* 根据流程id查询流程表
|
||||||
* @param versionIds 流程所有版本的id
|
* @param versionIds 流程所有版本的id
|
||||||
* @return 流程对应的表名
|
* @return 流程对应的表名
|
||||||
*/
|
*/
|
||||||
@Select("select distinct tablename from workflow_base wb " +
|
@Select("select distinct tablename from workflow_base wb " +
|
||||||
"left join workflow_bill wbi on wbi.id = wb.formid " +
|
"left join workflow_bill wbi on wbi.id = wb.formid " +
|
||||||
"where wb.id in (${versionIds})")
|
"where wb.id in (${versionIds})")
|
||||||
public String selectWorkflowTableById(@ParamMapper("versionIds") String[] versionIds);
|
public String selectWorkflowTableById(@ParamMapper("versionIds") String[] versionIds);
|
||||||
|
|
||||||
@Select("select * from $t{workflowTable} where requestid = #{requestid}")
|
@Select("select * from $t{workflowTable} where requestid = #{requestid}")
|
||||||
@CaseConversion(false)
|
@CaseConversion(false)
|
||||||
Map<String,Object> selectMainData(@ParamMapper("workflowTable") String workflowTable,
|
Map<String,Object> selectMainData(@ParamMapper("workflowTable") String workflowTable,
|
||||||
@ParamMapper("requestId") String requestId);
|
@ParamMapper("requestId") String requestId);
|
||||||
|
|
||||||
@Select("select * from $t{detailTable} where mainid = #{mainId}")
|
@Select("select * from $t{detailTable} where mainid = #{mainId}")
|
||||||
@CaseConversion(false)
|
@CaseConversion(false)
|
||||||
List<Map<String, Object>> selectDetailData(@ParamMapper("detailTable") String requestDetailTableName,
|
List<Map<String, Object>> selectDetailData(@ParamMapper("detailTable") String requestDetailTableName,
|
||||||
@ParamMapper("mainId") String mainId);
|
@ParamMapper("mainId") String mainId);
|
||||||
}
|
}
|
||||||
|
|
|
@ -1,77 +1,77 @@
|
||||||
package aiyh.utils.apirequest.mapper;
|
package aiyh.utils.apirequest.mapper;
|
||||||
|
|
||||||
import aiyh.utils.annotation.recordset.CaseConversion;
|
import aiyh.utils.annotation.recordset.CaseConversion;
|
||||||
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 aiyh.utils.annotation.recordset.SqlString;
|
||||||
|
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
import java.util.Map;
|
import java.util.Map;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* <p>参数值解析查询操作</p>
|
* <p>参数值解析查询操作</p>
|
||||||
* <p>create 2022/1/26 0026 16:32</p>
|
* <p>create 2022/1/26 0026 16:32</p>
|
||||||
*
|
*
|
||||||
* @author EBU7-dev1-ayh
|
* @author EBU7-dev1-ayh
|
||||||
*/
|
*/
|
||||||
|
|
||||||
@SqlMapper
|
@SqlMapper
|
||||||
public interface ParamValueParseMapper {
|
public interface ParamValueParseMapper {
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* 查询自定义SQL
|
* 查询自定义SQL
|
||||||
*
|
*
|
||||||
* @param sql 自定义SQL字符串
|
* @param sql 自定义SQL字符串
|
||||||
* @param map 参数
|
* @param map 参数
|
||||||
* @return 查询到的数据
|
* @return 查询到的数据
|
||||||
*/
|
*/
|
||||||
@Select(custom = true)
|
@Select(custom = true)
|
||||||
@CaseConversion(false)
|
@CaseConversion(false)
|
||||||
public String selectCustomerSql(@SqlString String sql, Map<String, Object> map);
|
public String selectCustomerSql(@SqlString String sql, Map<String, Object> map);
|
||||||
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* 自定义查询SQL对象
|
* 自定义查询SQL对象
|
||||||
*
|
*
|
||||||
* @param sqlStr 自定义SQL字符串
|
* @param sqlStr 自定义SQL字符串
|
||||||
* @param dataMap 参数
|
* @param dataMap 参数
|
||||||
* @return 查询到的数据
|
* @return 查询到的数据
|
||||||
*/
|
*/
|
||||||
@Select(custom = true)
|
@Select(custom = true)
|
||||||
@CaseConversion(false)
|
@CaseConversion(false)
|
||||||
public Map<String, Object> selectMapByCustomerSql(@SqlString String sqlStr, Map<String, Object> dataMap);
|
public Map<String, Object> selectMapByCustomerSql(@SqlString String sqlStr, Map<String, Object> dataMap);
|
||||||
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* 自定义查询SQL集合
|
* 自定义查询SQL集合
|
||||||
*
|
*
|
||||||
* @param sql 自定义SQL字符串
|
* @param sql 自定义SQL字符串
|
||||||
* @param dataMap 参数
|
* @param dataMap 参数
|
||||||
* @return 查询到的数据
|
* @return 查询到的数据
|
||||||
*/
|
*/
|
||||||
@Select(custom = true)
|
@Select(custom = true)
|
||||||
@CaseConversion(false)
|
@CaseConversion(false)
|
||||||
public List<Map<String, Object>> selectListByCustomerSql(@SqlString String sql, Map<String, Object> dataMap);
|
public List<Map<String, Object>> selectListByCustomerSql(@SqlString String sql, Map<String, Object> dataMap);
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* 查询普通数组的请求参数类型
|
* 查询普通数组的请求参数类型
|
||||||
*
|
*
|
||||||
* @param sql 自定义SQL字符串
|
* @param sql 自定义SQL字符串
|
||||||
* @param dataMap 参数
|
* @param dataMap 参数
|
||||||
* @return 查询到的数据
|
* @return 查询到的数据
|
||||||
*/
|
*/
|
||||||
@Select(custom = true)
|
@Select(custom = true)
|
||||||
@CaseConversion(false)
|
@CaseConversion(false)
|
||||||
public List<String> selectStringListByCustomerSql(@SqlString String sql, Map<String, Object> dataMap);
|
public List<String> selectStringListByCustomerSql(@SqlString String sql, Map<String, Object> dataMap);
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* 查询普通数组请求参数类型
|
* 查询普通数组请求参数类型
|
||||||
*
|
*
|
||||||
* @param sql 自定义SQL字符串
|
* @param sql 自定义SQL字符串
|
||||||
* @param dataMap 参数
|
* @param dataMap 参数
|
||||||
* @return 查询到的数据
|
* @return 查询到的数据
|
||||||
*/
|
*/
|
||||||
@Select(custom = true)
|
@Select(custom = true)
|
||||||
@CaseConversion(false)
|
@CaseConversion(false)
|
||||||
public List<Integer> selectIntegerListByCustomerSql(@SqlString String sql, Map<String, Object> dataMap);
|
public List<Integer> selectIntegerListByCustomerSql(@SqlString String sql, Map<String, Object> dataMap);
|
||||||
}
|
}
|
||||||
|
|
|
@ -1,31 +1,31 @@
|
||||||
package aiyh.utils.apirequest.pojo;
|
package aiyh.utils.apirequest.pojo;
|
||||||
|
|
||||||
import lombok.Data;
|
import lombok.Data;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* <p>api请求头信息</p>
|
* <p>api请求头信息</p>
|
||||||
* <p>create 2022/1/23 0023 18:10</p>
|
* <p>create 2022/1/23 0023 18:10</p>
|
||||||
*
|
*
|
||||||
* @author EBU7-dev1-ayh
|
* @author EBU7-dev1-ayh
|
||||||
*/
|
*/
|
||||||
|
|
||||||
@Data
|
@Data
|
||||||
public class ApiRequestHeardDetail {
|
public class ApiRequestHeardDetail {
|
||||||
private Integer mainId;
|
private Integer mainId;
|
||||||
/**
|
/**
|
||||||
* 请求头参数名称
|
* 请求头参数名称
|
||||||
*/
|
*/
|
||||||
private String heardName;
|
private String heardName;
|
||||||
/**
|
/**
|
||||||
* 取值规则
|
* 取值规则
|
||||||
*/
|
*/
|
||||||
private Integer valueRule;
|
private Integer valueRule;
|
||||||
/**
|
/**
|
||||||
* 自定义值
|
* 自定义值
|
||||||
*/
|
*/
|
||||||
private String customerValue;
|
private String customerValue;
|
||||||
/**
|
/**
|
||||||
* 是否启用参数
|
* 是否启用参数
|
||||||
*/
|
*/
|
||||||
private Integer enableParam;
|
private Integer enableParam;
|
||||||
}
|
}
|
||||||
|
|
|
@ -1,76 +1,76 @@
|
||||||
package aiyh.utils.apirequest.pojo;
|
package aiyh.utils.apirequest.pojo;
|
||||||
|
|
||||||
import lombok.Data;
|
import lombok.Data;
|
||||||
|
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* <p>主表</p>
|
* <p>主表</p>
|
||||||
* <p>create 2022/1/23 0023 17:55</p>
|
* <p>create 2022/1/23 0023 17:55</p>
|
||||||
*
|
*
|
||||||
* @author EBU7-dev1-ayh
|
* @author EBU7-dev1-ayh
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
|
||||||
@Data
|
@Data
|
||||||
public class ApiRequestMain {
|
public class ApiRequestMain {
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* 主表id
|
* 主表id
|
||||||
*/
|
*/
|
||||||
private Integer id;
|
private Integer id;
|
||||||
/**
|
/**
|
||||||
* api地址
|
* api地址
|
||||||
*/
|
*/
|
||||||
private String apiUrl;
|
private String apiUrl;
|
||||||
/**
|
/**
|
||||||
* 测试环境api地址
|
* 测试环境api地址
|
||||||
*/
|
*/
|
||||||
private String testApiUrl;
|
private String testApiUrl;
|
||||||
/**
|
/**
|
||||||
* 请求方式
|
* 请求方式
|
||||||
*/
|
*/
|
||||||
private Integer requestType;
|
private Integer requestType;
|
||||||
/**
|
/**
|
||||||
* api启用类型
|
* api启用类型
|
||||||
*/
|
*/
|
||||||
private Integer apiType;
|
private Integer apiType;
|
||||||
/**
|
/**
|
||||||
* 数据来源
|
* 数据来源
|
||||||
*/
|
*/
|
||||||
private Integer dataSource;
|
private Integer dataSource;
|
||||||
/**
|
/**
|
||||||
* api接口描述
|
* api接口描述
|
||||||
*/
|
*/
|
||||||
private String apiDesc;
|
private String apiDesc;
|
||||||
/**
|
/**
|
||||||
* 流程类型
|
* 流程类型
|
||||||
*/
|
*/
|
||||||
private String workflowType;
|
private String workflowType;
|
||||||
/**
|
/**
|
||||||
* 建模表表名
|
* 建模表表名
|
||||||
*/
|
*/
|
||||||
private String modelTableName;
|
private String modelTableName;
|
||||||
/**
|
/**
|
||||||
* 参数请求方式
|
* 参数请求方式
|
||||||
*/
|
*/
|
||||||
private Integer paramRequestType;
|
private Integer paramRequestType;
|
||||||
/**
|
/**
|
||||||
* 请求参数的数据来源,适用于参数请求方式为明细表模式
|
* 请求参数的数据来源,适用于参数请求方式为明细表模式
|
||||||
*/
|
*/
|
||||||
private String requestDetailTableName;
|
private String requestDetailTableName;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* 唯一标识
|
* 唯一标识
|
||||||
*/
|
*/
|
||||||
private String onlyMark;
|
private String onlyMark;
|
||||||
/**
|
/**
|
||||||
* 请求参数信息
|
* 请求参数信息
|
||||||
*/
|
*/
|
||||||
private List<ApiRequestParamDetail> paramDetailList;
|
private List<ApiRequestParamDetail> paramDetailList;
|
||||||
/**
|
/**
|
||||||
* 请求头信息
|
* 请求头信息
|
||||||
*/
|
*/
|
||||||
private List<ApiRequestHeardDetail> heardDetailList;
|
private List<ApiRequestHeardDetail> heardDetailList;
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -1,65 +1,65 @@
|
||||||
package aiyh.utils.apirequest.pojo;
|
package aiyh.utils.apirequest.pojo;
|
||||||
|
|
||||||
import lombok.Data;
|
import lombok.Data;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* <p></p>
|
* <p></p>
|
||||||
* <p>create 2022/1/23 0023 18:04</p>
|
* <p>create 2022/1/23 0023 18:04</p>
|
||||||
*
|
*
|
||||||
* @author EBU7-dev1-ayh
|
* @author EBU7-dev1-ayh
|
||||||
*/
|
*/
|
||||||
|
|
||||||
@Data
|
@Data
|
||||||
public class ApiRequestParamDetail {
|
public class ApiRequestParamDetail {
|
||||||
/**
|
/**
|
||||||
* 主表id
|
* 主表id
|
||||||
*/
|
*/
|
||||||
private Integer mainId;
|
private Integer mainId;
|
||||||
/**
|
/**
|
||||||
* 行号
|
* 行号
|
||||||
*/
|
*/
|
||||||
private Integer lineNum;
|
private Integer lineNum;
|
||||||
/**
|
/**
|
||||||
* 参数名称
|
* 参数名称
|
||||||
*/
|
*/
|
||||||
private String paramName;
|
private String paramName;
|
||||||
/**
|
/**
|
||||||
* 参数类型
|
* 参数类型
|
||||||
*/
|
*/
|
||||||
private Integer paramType;
|
private Integer paramType;
|
||||||
/**
|
/**
|
||||||
* 数据来源
|
* 数据来源
|
||||||
*/
|
*/
|
||||||
private Integer dataSource;
|
private Integer dataSource;
|
||||||
/**
|
/**
|
||||||
* 明细表表名
|
* 明细表表名
|
||||||
*/
|
*/
|
||||||
private String detailTableName;
|
private String detailTableName;
|
||||||
/**
|
/**
|
||||||
* 所属 父级行号
|
* 所属 父级行号
|
||||||
*/
|
*/
|
||||||
private Integer parentLine;
|
private Integer parentLine;
|
||||||
/**
|
/**
|
||||||
* 取值方式
|
* 取值方式
|
||||||
*/
|
*/
|
||||||
private Integer valueRule;
|
private Integer valueRule;
|
||||||
/**
|
/**
|
||||||
* 系统字段
|
* 系统字段
|
||||||
*/
|
*/
|
||||||
private String systemFieldName;
|
private String systemFieldName;
|
||||||
/**
|
/**
|
||||||
* 自定义值文本
|
* 自定义值文本
|
||||||
*/
|
*/
|
||||||
private String customerValue;
|
private String customerValue;
|
||||||
/**
|
/**
|
||||||
* 是否启用参数
|
* 是否启用参数
|
||||||
*/
|
*/
|
||||||
private Integer enableParam;
|
private Integer enableParam;
|
||||||
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* 字段所在表
|
* 字段所在表
|
||||||
*/
|
*/
|
||||||
private String fieldTableName;
|
private String fieldTableName;
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -1,39 +1,39 @@
|
||||||
package aiyh.utils.entity;
|
package aiyh.utils.entity;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @author EBU7-dev1-ayh
|
* @author EBU7-dev1-ayh
|
||||||
* create 2021/12/13 0013 11:19
|
* create 2021/12/13 0013 11:19
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
|
||||||
public class LabelHtmlIndex {
|
public class LabelHtmlIndex {
|
||||||
private Integer labelIndex;
|
private Integer labelIndex;
|
||||||
private String defaultStr;
|
private String defaultStr;
|
||||||
|
|
||||||
public LabelHtmlIndex() {
|
public LabelHtmlIndex() {
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
public LabelHtmlIndex(Integer labelIndex, String defaultStr) {
|
public LabelHtmlIndex(Integer labelIndex, String defaultStr) {
|
||||||
this.labelIndex = labelIndex;
|
this.labelIndex = labelIndex;
|
||||||
this.defaultStr = defaultStr;
|
this.defaultStr = defaultStr;
|
||||||
}
|
}
|
||||||
|
|
||||||
public Integer getLabelIndex() {
|
public Integer getLabelIndex() {
|
||||||
return labelIndex;
|
return labelIndex;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
public String getDefaultStr() {
|
public String getDefaultStr() {
|
||||||
return defaultStr;
|
return defaultStr;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public String toString() {
|
public String toString() {
|
||||||
return "LabelHtmlIndex{" +
|
return "LabelHtmlIndex{" +
|
||||||
"labelIndex='" + labelIndex + '\'' +
|
"labelIndex='" + labelIndex + '\'' +
|
||||||
", defaultStr='" + defaultStr + '\'' +
|
", defaultStr='" + defaultStr + '\'' +
|
||||||
'}';
|
'}';
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -1,13 +1,13 @@
|
||||||
package aiyh.utils.excention;
|
package aiyh.utils.excention;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @author EBU7-dev1-ayh
|
* @author EBU7-dev1-ayh
|
||||||
* create 2021/12/19 0019 14:51
|
* create 2021/12/19 0019 14:51
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
|
||||||
public class BindingException extends RuntimeException{
|
public class BindingException extends RuntimeException{
|
||||||
public BindingException(String msg){
|
public BindingException(String msg){
|
||||||
super(msg);
|
super(msg);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -1,13 +1,13 @@
|
||||||
package aiyh.utils.excention;
|
package aiyh.utils.excention;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @author EBU7-dev1-ayh
|
* @author EBU7-dev1-ayh
|
||||||
* create 2021/12/19 0019 19:33
|
* create 2021/12/19 0019 19:33
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
|
||||||
public class MethodNotFindException extends RuntimeException{
|
public class MethodNotFindException extends RuntimeException{
|
||||||
public MethodNotFindException(String msg){
|
public MethodNotFindException(String msg){
|
||||||
super(msg);
|
super(msg);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -1,13 +1,13 @@
|
||||||
package aiyh.utils.excention;
|
package aiyh.utils.excention;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @author EBU7-dev1-ayh
|
* @author EBU7-dev1-ayh
|
||||||
* create 2021/12/21 0021 10:33
|
* create 2021/12/21 0021 10:33
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
|
||||||
public class ParseSqlException extends RuntimeException{
|
public class ParseSqlException extends RuntimeException{
|
||||||
public ParseSqlException(String message) {
|
public ParseSqlException(String message) {
|
||||||
super(message);
|
super(message);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -1,13 +1,13 @@
|
||||||
package aiyh.utils.excention;
|
package aiyh.utils.excention;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @author EBU7-dev1-ayh
|
* @author EBU7-dev1-ayh
|
||||||
* create 2021/12/19 0019 19:24
|
* create 2021/12/19 0019 19:24
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
|
||||||
public class TypeNonsupportException extends RuntimeException{
|
public class TypeNonsupportException extends RuntimeException{
|
||||||
public TypeNonsupportException(String msg){
|
public TypeNonsupportException(String msg){
|
||||||
super(msg);
|
super(msg);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -70,7 +70,7 @@ public abstract class Try<T> {
|
||||||
* .recover((t) -> 1)
|
* .recover((t) -> 1)
|
||||||
* returns Integer(1)
|
* returns Integer(1)
|
||||||
*
|
*
|
||||||
* @param f function to execute on successful result.
|
* @param f function to getDataId on successful result.
|
||||||
* @return new composed Try
|
* @return new composed Try
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
|
|
@ -1,18 +1,18 @@
|
||||||
package aiyh.utils.function;
|
package aiyh.utils.function;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* <p>设置孩子节点function</p>
|
* <p>设置孩子节点function</p>
|
||||||
* <p>create 2022/1/22 0022 18:26</p>
|
* <p>create 2022/1/22 0022 18:26</p>
|
||||||
*
|
*
|
||||||
* @author EBU7-dev1-ayh
|
* @author EBU7-dev1-ayh
|
||||||
*/
|
*/
|
||||||
|
|
||||||
@FunctionalInterface
|
@FunctionalInterface
|
||||||
public interface ListToTreeSetChildFunction<T> {
|
public interface ListToTreeSetChildFunction<T> {
|
||||||
/**
|
/**
|
||||||
* 设置树形结构中的孩子节点
|
* 设置树形结构中的孩子节点
|
||||||
* @param parent 父节点
|
* @param parent 父节点
|
||||||
* @param child 孩子节点
|
* @param child 孩子节点
|
||||||
*/
|
*/
|
||||||
void setChildItem(T parent, T child);
|
void setChildItem(T parent, T child);
|
||||||
}
|
}
|
||||||
|
|
|
@ -1,39 +1,39 @@
|
||||||
package aiyh.utils.httpUtil;
|
package aiyh.utils.httpUtil;
|
||||||
|
|
||||||
import java.io.Closeable;
|
import java.io.Closeable;
|
||||||
import java.io.Flushable;
|
import java.io.Flushable;
|
||||||
import java.io.IOException;
|
import java.io.IOException;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* IO流拓展工具类,补充IOUtils新版本中废弃的closeQuietly
|
* IO流拓展工具类,补充IOUtils新版本中废弃的closeQuietly
|
||||||
*
|
*
|
||||||
* @author EBU7-dev1-ayh
|
* @author EBU7-dev1-ayh
|
||||||
* @since 2021/08/30 17:56
|
* @since 2021/08/30 17:56
|
||||||
*/
|
*/
|
||||||
public class ExtendedIOUtils {
|
public class ExtendedIOUtils {
|
||||||
|
|
||||||
public static void flush(Flushable... resources) throws IOException {
|
public static void flush(Flushable... resources) throws IOException {
|
||||||
int length = resources.length;
|
int length = resources.length;
|
||||||
for (int i = 0; i < length; ++i) {
|
for (int i = 0; i < length; ++i) {
|
||||||
Flushable resource = resources[i];
|
Flushable resource = resources[i];
|
||||||
if (resource != null) {
|
if (resource != null) {
|
||||||
resource.flush();
|
resource.flush();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
public static void closeQuietly(Closeable... resources) {
|
public static void closeQuietly(Closeable... resources) {
|
||||||
int length = resources.length;
|
int length = resources.length;
|
||||||
for (int i = 0; i < length; ++i) {
|
for (int i = 0; i < length; ++i) {
|
||||||
Closeable resource = resources[i];
|
Closeable resource = resources[i];
|
||||||
if (resource != null) {
|
if (resource != null) {
|
||||||
try {
|
try {
|
||||||
resource.close();
|
resource.close();
|
||||||
} catch (IOException e) {
|
} catch (IOException e) {
|
||||||
//ignore exception
|
//ignore exception
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -1,97 +1,97 @@
|
||||||
package aiyh.utils.httpUtil;
|
package aiyh.utils.httpUtil;
|
||||||
|
|
||||||
import org.apache.http.client.CredentialsProvider;
|
import org.apache.http.client.CredentialsProvider;
|
||||||
import org.apache.http.client.config.RequestConfig;
|
import org.apache.http.client.config.RequestConfig;
|
||||||
import org.apache.http.conn.ssl.NoopHostnameVerifier;
|
import org.apache.http.conn.ssl.NoopHostnameVerifier;
|
||||||
import org.apache.http.conn.ssl.SSLConnectionSocketFactory;
|
import org.apache.http.conn.ssl.SSLConnectionSocketFactory;
|
||||||
import org.apache.http.impl.client.CloseableHttpClient;
|
import org.apache.http.impl.client.CloseableHttpClient;
|
||||||
import org.apache.http.impl.client.HttpClientBuilder;
|
import org.apache.http.impl.client.HttpClientBuilder;
|
||||||
import org.apache.http.impl.client.HttpClients;
|
import org.apache.http.impl.client.HttpClients;
|
||||||
import org.apache.http.impl.conn.PoolingHttpClientConnectionManager;
|
import org.apache.http.impl.conn.PoolingHttpClientConnectionManager;
|
||||||
import org.apache.http.ssl.SSLContextBuilder;
|
import org.apache.http.ssl.SSLContextBuilder;
|
||||||
|
|
||||||
import javax.net.ssl.HostnameVerifier;
|
import javax.net.ssl.HostnameVerifier;
|
||||||
import javax.net.ssl.SSLContext;
|
import javax.net.ssl.SSLContext;
|
||||||
import java.security.KeyManagementException;
|
import java.security.KeyManagementException;
|
||||||
import java.security.KeyStoreException;
|
import java.security.KeyStoreException;
|
||||||
import java.security.NoSuchAlgorithmException;
|
import java.security.NoSuchAlgorithmException;
|
||||||
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @author EBU7-dev1-ayh
|
* @author EBU7-dev1-ayh
|
||||||
* @since 2021/08/30 17:56
|
* @since 2021/08/30 17:56
|
||||||
**/
|
**/
|
||||||
public class HttpManager {
|
public class HttpManager {
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* 创建连接池管理对象
|
* 创建连接池管理对象
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
|
||||||
private static final int CONNECT_TIMEOUT = 1000 * 60 * 3;
|
private static final int CONNECT_TIMEOUT = 1000 * 60 * 3;
|
||||||
private static final int CONNECTION_REQUEST_TIMEOUT = 1000 * 60 * 3;
|
private static final int CONNECTION_REQUEST_TIMEOUT = 1000 * 60 * 3;
|
||||||
private static final int SOCKET_TIMEOUT = 10000 * 60 * 3;
|
private static final int SOCKET_TIMEOUT = 10000 * 60 * 3;
|
||||||
private static final int MAX_TOTAL = 500;
|
private static final int MAX_TOTAL = 500;
|
||||||
private static final int MAX_PRE_ROUTE = 500;
|
private static final int MAX_PRE_ROUTE = 500;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* 设置请求配置
|
* 设置请求配置
|
||||||
*/
|
*/
|
||||||
static RequestConfig requestConfig = RequestConfig.custom()
|
static RequestConfig requestConfig = RequestConfig.custom()
|
||||||
//网络请求的超时时间
|
//网络请求的超时时间
|
||||||
.setConnectTimeout(CONNECT_TIMEOUT)
|
.setConnectTimeout(CONNECT_TIMEOUT)
|
||||||
//连接池去获取连接的超时时间
|
//连接池去获取连接的超时时间
|
||||||
.setConnectionRequestTimeout(CONNECTION_REQUEST_TIMEOUT)
|
.setConnectionRequestTimeout(CONNECTION_REQUEST_TIMEOUT)
|
||||||
//设置socket超时时间
|
//设置socket超时时间
|
||||||
.setSocketTimeout(SOCKET_TIMEOUT)
|
.setSocketTimeout(SOCKET_TIMEOUT)
|
||||||
.build();
|
.build();
|
||||||
static PoolingHttpClientConnectionManager manager = new PoolingHttpClientConnectionManager();
|
static PoolingHttpClientConnectionManager manager = new PoolingHttpClientConnectionManager();
|
||||||
static {
|
static {
|
||||||
// 配置最大的连接数
|
// 配置最大的连接数
|
||||||
manager.setMaxTotal(MAX_TOTAL);
|
manager.setMaxTotal(MAX_TOTAL);
|
||||||
// 每个路由最大连接数(路由是根据host来管理的,大小不好控制)
|
// 每个路由最大连接数(路由是根据host来管理的,大小不好控制)
|
||||||
manager.setDefaultMaxPerRoute(MAX_PRE_ROUTE);
|
manager.setDefaultMaxPerRoute(MAX_PRE_ROUTE);
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* 获取连接对象 从连接池里面去获取,根据url创建对应的对象,http / https
|
* 获取连接对象 从连接池里面去获取,根据url创建对应的对象,http / https
|
||||||
* @param url 请求地址
|
* @param url 请求地址
|
||||||
* @return 连接对象
|
* @return 连接对象
|
||||||
*/
|
*/
|
||||||
public static CloseableHttpClient getHttpConnection(String url, CredentialsProvider credentialsProvider){
|
public static CloseableHttpClient getHttpConnection(String url, CredentialsProvider credentialsProvider){
|
||||||
if(url.trim().toUpperCase().startsWith(HttpArgsType.HTTP_HTTPS.toUpperCase())){
|
if(url.trim().toUpperCase().startsWith(HttpArgsType.HTTP_HTTPS.toUpperCase())){
|
||||||
SSLContext sslContext;
|
SSLContext sslContext;
|
||||||
SSLConnectionSocketFactory sslsf = null;
|
SSLConnectionSocketFactory sslsf = null;
|
||||||
try {
|
try {
|
||||||
sslContext = new SSLContextBuilder().loadTrustMaterial(null, (x509Certificates, s) -> {
|
sslContext = new SSLContextBuilder().loadTrustMaterial(null, (x509Certificates, s) -> {
|
||||||
// 绕过所有验证
|
// 绕过所有验证
|
||||||
return true;
|
return true;
|
||||||
}).build();
|
}).build();
|
||||||
HostnameVerifier hostnameVerifier = NoopHostnameVerifier.INSTANCE;
|
HostnameVerifier hostnameVerifier = NoopHostnameVerifier.INSTANCE;
|
||||||
sslsf = new SSLConnectionSocketFactory(sslContext,hostnameVerifier);
|
sslsf = new SSLConnectionSocketFactory(sslContext,hostnameVerifier);
|
||||||
} catch (NoSuchAlgorithmException | KeyStoreException | KeyManagementException e) {
|
} catch (NoSuchAlgorithmException | KeyStoreException | KeyManagementException e) {
|
||||||
e.printStackTrace();
|
e.printStackTrace();
|
||||||
}
|
}
|
||||||
HttpClientBuilder httpClientBuilder = HttpClients.custom()
|
HttpClientBuilder httpClientBuilder = HttpClients.custom()
|
||||||
.setSSLSocketFactory(sslsf)
|
.setSSLSocketFactory(sslsf)
|
||||||
.setConnectionManager(manager)
|
.setConnectionManager(manager)
|
||||||
.setConnectionManagerShared(true)
|
.setConnectionManagerShared(true)
|
||||||
.setDefaultRequestConfig(requestConfig);
|
.setDefaultRequestConfig(requestConfig);
|
||||||
if(credentialsProvider != null){
|
if(credentialsProvider != null){
|
||||||
httpClientBuilder.setDefaultCredentialsProvider(credentialsProvider);
|
httpClientBuilder.setDefaultCredentialsProvider(credentialsProvider);
|
||||||
}
|
}
|
||||||
return httpClientBuilder
|
return httpClientBuilder
|
||||||
.build();
|
.build();
|
||||||
}else{
|
}else{
|
||||||
HttpClientBuilder httpClientBuilder = HttpClients.custom()
|
HttpClientBuilder httpClientBuilder = HttpClients.custom()
|
||||||
.setConnectionManager(manager)
|
.setConnectionManager(manager)
|
||||||
.setDefaultRequestConfig(requestConfig)
|
.setDefaultRequestConfig(requestConfig)
|
||||||
.setConnectionManagerShared(true);
|
.setConnectionManagerShared(true);
|
||||||
if(credentialsProvider != null){
|
if(credentialsProvider != null){
|
||||||
httpClientBuilder.setDefaultCredentialsProvider(credentialsProvider);
|
httpClientBuilder.setDefaultCredentialsProvider(credentialsProvider);
|
||||||
}
|
}
|
||||||
return httpClientBuilder
|
return httpClientBuilder
|
||||||
.build();
|
.build();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -1,152 +1,152 @@
|
||||||
package aiyh.utils.httpUtil;
|
package aiyh.utils.httpUtil;
|
||||||
|
|
||||||
|
|
||||||
import com.alibaba.fastjson.JSON;
|
import com.alibaba.fastjson.JSON;
|
||||||
import com.alibaba.fastjson.annotation.JSONField;
|
import com.alibaba.fastjson.annotation.JSONField;
|
||||||
import com.fasterxml.jackson.core.JsonProcessingException;
|
import com.fasterxml.jackson.core.JsonProcessingException;
|
||||||
import com.fasterxml.jackson.core.type.TypeReference;
|
import com.fasterxml.jackson.core.type.TypeReference;
|
||||||
import com.fasterxml.jackson.databind.ObjectMapper;
|
import com.fasterxml.jackson.databind.ObjectMapper;
|
||||||
import org.apache.http.Header;
|
import org.apache.http.Header;
|
||||||
|
|
||||||
import java.io.InputStream;
|
import java.io.InputStream;
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
import java.util.Locale;
|
import java.util.Locale;
|
||||||
import java.util.Map;
|
import java.util.Map;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @author EBU7-dev1-ayh
|
* @author EBU7-dev1-ayh
|
||||||
* @date 2021/8/31 0031 17:16
|
* @date 2021/8/31 0031 17:16
|
||||||
* http请求相应
|
* http请求相应
|
||||||
*/
|
*/
|
||||||
|
|
||||||
public class ResponeVo {
|
public class ResponeVo {
|
||||||
/**
|
/**
|
||||||
* 相应状态码
|
* 相应状态码
|
||||||
*/
|
*/
|
||||||
private int code;
|
private int code;
|
||||||
/**
|
/**
|
||||||
* 相应内容
|
* 相应内容
|
||||||
*/
|
*/
|
||||||
private String entityString;
|
private String entityString;
|
||||||
/**
|
/**
|
||||||
* 相应头信息
|
* 相应头信息
|
||||||
*/
|
*/
|
||||||
@JSONField(serialize = false)
|
@JSONField(serialize = false)
|
||||||
private Header[] allHeaders;
|
private Header[] allHeaders;
|
||||||
private Locale locale;
|
private Locale locale;
|
||||||
|
|
||||||
private InputStream content;
|
private InputStream content;
|
||||||
|
|
||||||
private byte[] contentByteArr;
|
private byte[] contentByteArr;
|
||||||
|
|
||||||
private Map<String,Object> requestData;
|
private Map<String,Object> requestData;
|
||||||
public int getCode() {
|
public int getCode() {
|
||||||
return code;
|
return code;
|
||||||
}
|
}
|
||||||
|
|
||||||
public Map<String, Object> getRequestData() {
|
public Map<String, Object> getRequestData() {
|
||||||
return requestData;
|
return requestData;
|
||||||
}
|
}
|
||||||
|
|
||||||
public void setRequestData(Map<String, Object> requestData) {
|
public void setRequestData(Map<String, Object> requestData) {
|
||||||
this.requestData = requestData;
|
this.requestData = requestData;
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* 根据相应结果转化为map集合
|
* 根据相应结果转化为map集合
|
||||||
* @return 资源皇后的map集合
|
* @return 资源皇后的map集合
|
||||||
* @throws JsonProcessingException JSON转换异常
|
* @throws JsonProcessingException JSON转换异常
|
||||||
*/
|
*/
|
||||||
public Map<String, Object> getEntityMap() throws JsonProcessingException {
|
public Map<String, Object> getEntityMap() throws JsonProcessingException {
|
||||||
ObjectMapper mapper = new ObjectMapper();
|
ObjectMapper mapper = new ObjectMapper();
|
||||||
return mapper.readValue(this.getEntityString(), Map.class);
|
return mapper.readValue(this.getEntityString(), Map.class);
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* 根据相应结果,转化为实体类
|
* 根据相应结果,转化为实体类
|
||||||
* @param clazz 需要映射的实体类
|
* @param clazz 需要映射的实体类
|
||||||
* @param <T> 需要转换实体类的泛型
|
* @param <T> 需要转换实体类的泛型
|
||||||
* @return 转换后的实体类
|
* @return 转换后的实体类
|
||||||
* @throws JsonProcessingException JSON转换异常
|
* @throws JsonProcessingException JSON转换异常
|
||||||
*/
|
*/
|
||||||
public <T> T getEntity(Class<T> clazz) throws JsonProcessingException {
|
public <T> T getEntity(Class<T> clazz) throws JsonProcessingException {
|
||||||
ObjectMapper mapper = new ObjectMapper();
|
ObjectMapper mapper = new ObjectMapper();
|
||||||
return mapper.readValue(this.getEntityString(), clazz);
|
return mapper.readValue(this.getEntityString(), clazz);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* 根据相应结果,转化为实体类
|
* 根据相应结果,转化为实体类
|
||||||
* @param <T> 需要转换实体类的泛型处理器
|
* @param <T> 需要转换实体类的泛型处理器
|
||||||
* @return 转换后的实体类
|
* @return 转换后的实体类
|
||||||
* @throws JsonProcessingException JSON转换异常
|
* @throws JsonProcessingException JSON转换异常
|
||||||
*/
|
*/
|
||||||
public <T> T getEntity(TypeReference<T> typeReference) throws JsonProcessingException {
|
public <T> T getEntity(TypeReference<T> typeReference) throws JsonProcessingException {
|
||||||
ObjectMapper mapper = new ObjectMapper();
|
ObjectMapper mapper = new ObjectMapper();
|
||||||
return mapper.readValue(this.getEntityString(), typeReference);
|
return mapper.readValue(this.getEntityString(), typeReference);
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* 根据相应结果转化为实体集合
|
* 根据相应结果转化为实体集合
|
||||||
* @param clazz 需要映射的实体类
|
* @param clazz 需要映射的实体类
|
||||||
* @param <T> 需要转换的实体类的泛型
|
* @param <T> 需要转换的实体类的泛型
|
||||||
* @return 转换后的实体类的集合
|
* @return 转换后的实体类的集合
|
||||||
*/
|
*/
|
||||||
public <T> List<T> getEntityArray(Class<T> clazz) {
|
public <T> List<T> getEntityArray(Class<T> clazz) {
|
||||||
return JSON.parseArray(this.getEntityString(), clazz);
|
return JSON.parseArray(this.getEntityString(), clazz);
|
||||||
}
|
}
|
||||||
|
|
||||||
public Locale getLocale() {
|
public Locale getLocale() {
|
||||||
return locale;
|
return locale;
|
||||||
}
|
}
|
||||||
|
|
||||||
public void setLocale(Locale locale) {
|
public void setLocale(Locale locale) {
|
||||||
this.locale = locale;
|
this.locale = locale;
|
||||||
}
|
}
|
||||||
|
|
||||||
public void setCode(int code) {
|
public void setCode(int code) {
|
||||||
this.code = code;
|
this.code = code;
|
||||||
}
|
}
|
||||||
|
|
||||||
public Header[] getAllHeaders() {
|
public Header[] getAllHeaders() {
|
||||||
return allHeaders;
|
return allHeaders;
|
||||||
}
|
}
|
||||||
|
|
||||||
public void setAllHeaders(Header[] allHeaders) {
|
public void setAllHeaders(Header[] allHeaders) {
|
||||||
this.allHeaders = allHeaders;
|
this.allHeaders = allHeaders;
|
||||||
}
|
}
|
||||||
|
|
||||||
public String getEntityString() {
|
public String getEntityString() {
|
||||||
return entityString;
|
return entityString;
|
||||||
}
|
}
|
||||||
|
|
||||||
public void setEntityString(String entityString) {
|
public void setEntityString(String entityString) {
|
||||||
this.entityString = entityString;
|
this.entityString = entityString;
|
||||||
}
|
}
|
||||||
|
|
||||||
public InputStream getContent() {
|
public InputStream getContent() {
|
||||||
return content;
|
return content;
|
||||||
}
|
}
|
||||||
|
|
||||||
public byte[] getContentByteArr() {
|
public byte[] getContentByteArr() {
|
||||||
return contentByteArr;
|
return contentByteArr;
|
||||||
}
|
}
|
||||||
|
|
||||||
public void setContentByteArr(byte[] contentByteArr) {
|
public void setContentByteArr(byte[] contentByteArr) {
|
||||||
this.contentByteArr = contentByteArr;
|
this.contentByteArr = contentByteArr;
|
||||||
}
|
}
|
||||||
|
|
||||||
public void setContent(InputStream content) {
|
public void setContent(InputStream content) {
|
||||||
this.content = content;
|
this.content = content;
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public String toString() {
|
public String toString() {
|
||||||
return "ResponeVo{" +
|
return "ResponeVo{" +
|
||||||
"code=" + code +
|
"code=" + code +
|
||||||
", entityString='" + entityString + '\'' +
|
", entityString='" + entityString + '\'' +
|
||||||
", otherParam=" + requestData +
|
", otherParam=" + requestData +
|
||||||
'}';
|
'}';
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -1,24 +1,24 @@
|
||||||
package aiyh.utils.httpUtil.staticUtil;
|
package aiyh.utils.httpUtil.staticUtil;
|
||||||
|
|
||||||
|
|
||||||
import java.util.HashMap;
|
import java.util.HashMap;
|
||||||
import java.util.Map;
|
import java.util.Map;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @author EBU7-dev1-ayh
|
* @author EBU7-dev1-ayh
|
||||||
* @since 2021/08/30 17:56
|
* @since 2021/08/30 17:56
|
||||||
*/
|
*/
|
||||||
public class GlobalStaticCache {
|
public class GlobalStaticCache {
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* 全局请求头
|
* 全局请求头
|
||||||
*/
|
*/
|
||||||
public static Map<String,String> header = new HashMap<>();
|
public static Map<String,String> header = new HashMap<>();
|
||||||
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* 依赖参数容器
|
* 依赖参数容器
|
||||||
*/
|
*/
|
||||||
public static Map<String,String> paramMap = new HashMap<>();
|
public static Map<String,String> paramMap = new HashMap<>();
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -1,42 +1,42 @@
|
||||||
package aiyh.utils.httpUtil.util;
|
package aiyh.utils.httpUtil.util;
|
||||||
|
|
||||||
|
|
||||||
import java.util.HashMap;
|
import java.util.HashMap;
|
||||||
import java.util.Map;
|
import java.util.Map;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @author EBU7-dev1-ayh
|
* @author EBU7-dev1-ayh
|
||||||
* @since 2021/08/30 17:56
|
* @since 2021/08/30 17:56
|
||||||
*/
|
*/
|
||||||
public class GlobalCache {
|
public class GlobalCache {
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* 全局请求头
|
* 全局请求头
|
||||||
*/
|
*/
|
||||||
public Map<String,String> header = new HashMap<>();
|
public Map<String,String> header = new HashMap<>();
|
||||||
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* 依赖参数容器
|
* 依赖参数容器
|
||||||
*/
|
*/
|
||||||
public Map<String,Object> paramMap = new HashMap<>();
|
public Map<String,Object> paramMap = new HashMap<>();
|
||||||
|
|
||||||
public Map<String,String> uptHeader(String key, String value){
|
public Map<String,String> uptHeader(String key, String value){
|
||||||
header.put(key,value);
|
header.put(key,value);
|
||||||
return header;
|
return header;
|
||||||
}
|
}
|
||||||
|
|
||||||
public Map<String,Object> uptParam(String key, Object value){
|
public Map<String,Object> uptParam(String key, Object value){
|
||||||
paramMap.put(key,value);
|
paramMap.put(key,value);
|
||||||
return paramMap;
|
return paramMap;
|
||||||
}
|
}
|
||||||
|
|
||||||
public void clearHeader(){
|
public void clearHeader(){
|
||||||
header.clear();
|
header.clear();
|
||||||
}
|
}
|
||||||
|
|
||||||
public void clearParam(){
|
public void clearParam(){
|
||||||
paramMap.clear();
|
paramMap.clear();
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -1,134 +1,134 @@
|
||||||
package aiyh.utils.mapper;
|
package aiyh.utils.mapper;
|
||||||
|
|
||||||
import aiyh.utils.annotation.recordset.*;
|
import aiyh.utils.annotation.recordset.*;
|
||||||
import aiyh.utils.entity.DocImageInfo;
|
import aiyh.utils.entity.DocImageInfo;
|
||||||
import aiyh.utils.entity.SelectValueEntity;
|
import aiyh.utils.entity.SelectValueEntity;
|
||||||
import aiyh.utils.entity.WorkflowNodeConfig;
|
import aiyh.utils.entity.WorkflowNodeConfig;
|
||||||
|
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
import java.util.Map;
|
import java.util.Map;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* <p>工具类查询SQL</p>
|
* <p>工具类查询SQL</p>
|
||||||
* <p>create 2022/1/27 0027 12:01</p>
|
* <p>create 2022/1/27 0027 12:01</p>
|
||||||
*
|
*
|
||||||
* @author EBU7-dev1-ayh
|
* @author EBU7-dev1-ayh
|
||||||
*/
|
*/
|
||||||
|
|
||||||
@SqlMapper
|
@SqlMapper
|
||||||
public interface UtilMapper {
|
public interface UtilMapper {
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* 查询日志级别是否开启Debug模式
|
* 查询日志级别是否开启Debug模式
|
||||||
*
|
*
|
||||||
* @return 是否开启Debug模式
|
* @return 是否开启Debug模式
|
||||||
*/
|
*/
|
||||||
@Select("select param_value from $t{configTableName} where only_mark = 'enableDebugLog'")
|
@Select("select param_value from $t{configTableName} where only_mark = 'enableDebugLog'")
|
||||||
public Boolean selectLogLevel(@ParamMapper("configTableName") String configTableName);
|
public Boolean selectLogLevel(@ParamMapper("configTableName") String configTableName);
|
||||||
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* 根据唯一标识查询参数值
|
* 根据唯一标识查询参数值
|
||||||
*
|
*
|
||||||
* @param onlyMark 唯一标识
|
* @param onlyMark 唯一标识
|
||||||
* @return 参数值
|
* @return 参数值
|
||||||
*/
|
*/
|
||||||
@Select("select param_value from $t{configTableName} where only_mark = #{onlyMark} and enable_param = 1")
|
@Select("select param_value from $t{configTableName} where only_mark = #{onlyMark} and enable_param = 1")
|
||||||
public String selectCusConfigParam(@ParamMapper("onlyMark") String onlyMark,
|
public String selectCusConfigParam(@ParamMapper("onlyMark") String onlyMark,
|
||||||
@ParamMapper("configTableName") String cusConfigTableName);
|
@ParamMapper("configTableName") String cusConfigTableName);
|
||||||
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* 查询文件名
|
* 查询文件名
|
||||||
*
|
*
|
||||||
* @param imageFileId 查询文件名
|
* @param imageFileId 查询文件名
|
||||||
* @return 文件名
|
* @return 文件名
|
||||||
*/
|
*/
|
||||||
@Select("select imagefilename from imagefile where imagefileid = #{imageFileId}")
|
@Select("select imagefilename from imagefile where imagefileid = #{imageFileId}")
|
||||||
String selectFileNameByImageFileId(@ParamMapper("imageFileId") int imageFileId);
|
String selectFileNameByImageFileId(@ParamMapper("imageFileId") int imageFileId);
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* 查询流程主表
|
* 查询流程主表
|
||||||
*
|
*
|
||||||
* @param workflowId 流程id
|
* @param workflowId 流程id
|
||||||
* @return 流程表名
|
* @return 流程表名
|
||||||
*/
|
*/
|
||||||
@Select("select bill.tablename from workflow_bill bill join workflow_base base on base.formid = bill.id where base.id = #{workflowId}")
|
@Select("select bill.tablename from workflow_bill bill join workflow_base base on base.formid = bill.id where base.id = #{workflowId}")
|
||||||
String selectWorkfowMainTable(@ParamMapper("workflowId") String workflowId);
|
String selectWorkfowMainTable(@ParamMapper("workflowId") String workflowId);
|
||||||
|
|
||||||
|
|
||||||
@Select("select id,docid doc_id,imagefileid image_file_id,imagefilename image_file_name from docimagefile where docid = #{docId}")
|
@Select("select id,docid doc_id,imagefileid image_file_id,imagefilename image_file_name from docimagefile where docid = #{docId}")
|
||||||
DocImageInfo selectDocImageInfo(@ParamMapper("docId") String docId);
|
DocImageInfo selectDocImageInfo(@ParamMapper("docId") String docId);
|
||||||
|
|
||||||
|
|
||||||
@Select("select id,workflow_type,mark_only,workflow_nodes,enable_nodes from uf_node_config where enable_nodes = 1 and workflow_type in ($t{allVersion}) and mark_only = #{markOnly}")
|
@Select("select id,workflow_type,mark_only,workflow_nodes,enable_nodes from uf_node_config where enable_nodes = 1 and workflow_type in ($t{allVersion}) and mark_only = #{markOnly}")
|
||||||
WorkflowNodeConfig selectNodeConfig(@ParamMapper("allVersion") String allVersion, @ParamMapper("markOnly") String markOnly);
|
WorkflowNodeConfig selectNodeConfig(@ParamMapper("allVersion") String allVersion, @ParamMapper("markOnly") String markOnly);
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* 查询下拉框值
|
* 查询下拉框值
|
||||||
*
|
*
|
||||||
* @param tableName 表明
|
* @param tableName 表明
|
||||||
* @param fileName 字段名
|
* @param fileName 字段名
|
||||||
* @return 下拉框
|
* @return 下拉框
|
||||||
*/
|
*/
|
||||||
@Select("select wbf.id,wbf.fieldname,wbf.fieldlabel,wb.tablename, ws.selectname,ws.selectvalue " +
|
@Select("select wbf.id,wbf.fieldname,wbf.fieldlabel,wb.tablename, ws.selectname,ws.selectvalue " +
|
||||||
"from workflow_billfield wbf left join workflow_bill wb on wbf.billid = wb.id " +
|
"from workflow_billfield wbf left join workflow_bill wb on wbf.billid = wb.id " +
|
||||||
"left join workflow_selectitem ws on ws.fieldid = wbf.id where wb.tablename = #{tableName} and fieldname = #{fileName}")
|
"left join workflow_selectitem ws on ws.fieldid = wbf.id where wb.tablename = #{tableName} and fieldname = #{fileName}")
|
||||||
List<SelectValueEntity> selectSelectFieldValue(@ParamMapper("tableName") String tableName, @ParamMapper("fileName") String fileName);
|
List<SelectValueEntity> selectSelectFieldValue(@ParamMapper("tableName") String tableName, @ParamMapper("fileName") String fileName);
|
||||||
|
|
||||||
@Select("select ws.selectname " +
|
@Select("select ws.selectname " +
|
||||||
"from workflow_billfield wbf left join workflow_bill wb on wbf.billid = wb.id " +
|
"from workflow_billfield wbf left join workflow_bill wb on wbf.billid = wb.id " +
|
||||||
"left join workflow_selectitem ws on ws.fieldid = wbf.id where wb.tablename = #{tableName} and fieldname = #{fileName} and selectvalue = #{value}")
|
"left join workflow_selectitem ws on ws.fieldid = wbf.id where wb.tablename = #{tableName} and fieldname = #{fileName} and selectvalue = #{value}")
|
||||||
String selectSelectFieldValueByValue(@ParamMapper("tableName") String tableName, @ParamMapper("fileName") String fileName,
|
String selectSelectFieldValueByValue(@ParamMapper("tableName") String tableName, @ParamMapper("fileName") String fileName,
|
||||||
@ParamMapper("value") String value);
|
@ParamMapper("value") String value);
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* 查询文件信息
|
* 查询文件信息
|
||||||
*
|
*
|
||||||
* @param imageFileId 查询文件名
|
* @param imageFileId 查询文件名
|
||||||
* @return 文件名
|
* @return 文件名
|
||||||
*/
|
*/
|
||||||
@Select("select * from imagefile where imagefileid = #{imageFileId}")
|
@Select("select * from imagefile where imagefileid = #{imageFileId}")
|
||||||
Map<String, Object> selectFileInfoByImageFileId(@ParamMapper("imageFileId") int imageFileId);
|
Map<String, Object> selectFileInfoByImageFileId(@ParamMapper("imageFileId") int imageFileId);
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* 删除文件信息
|
* 删除文件信息
|
||||||
*
|
*
|
||||||
* @param imageFileId 文件ID
|
* @param imageFileId 文件ID
|
||||||
* @return 是否删除成功
|
* @return 是否删除成功
|
||||||
*/
|
*/
|
||||||
@Delete("delete from imagefile where imagefileid = #{imageFileId}")
|
@Delete("delete from imagefile where imagefileid = #{imageFileId}")
|
||||||
boolean deleteImageFileInfo(@ParamMapper("imageFileId") Integer imageFileId);
|
boolean deleteImageFileInfo(@ParamMapper("imageFileId") Integer imageFileId);
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* <h2>插入自定义配置数据</h2>
|
* <h2>插入自定义配置数据</h2>
|
||||||
*
|
*
|
||||||
* @param onlyMark 唯一标识
|
* @param onlyMark 唯一标识
|
||||||
* @param value 参数值
|
* @param value 参数值
|
||||||
* @param desc 描述
|
* @param desc 描述
|
||||||
* @return 是否插入成功
|
* @return 是否插入成功
|
||||||
*/
|
*/
|
||||||
@Update("update $t{configTableName} set only_mark = #{onlyMark},param_value = #{paramValue}, \n" +
|
@Update("update $t{configTableName} set only_mark = #{onlyMark},param_value = #{paramValue}, \n" +
|
||||||
"param_desc = #{paramDesc} where id = #{id}")
|
"param_desc = #{paramDesc} where id = #{id}")
|
||||||
boolean updateConfigValueById(@ParamMapper("onlyMark") String onlyMark,
|
boolean updateConfigValueById(@ParamMapper("onlyMark") String onlyMark,
|
||||||
@ParamMapper("paramValue") String value,
|
@ParamMapper("paramValue") String value,
|
||||||
@ParamMapper("paramDesc") String desc,
|
@ParamMapper("paramDesc") String desc,
|
||||||
@ParamMapper("id") String id,
|
@ParamMapper("id") String id,
|
||||||
@ParamMapper("configTableName") String configTableName);
|
@ParamMapper("configTableName") String configTableName);
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* <h2>修改自定义配置数据</h2>
|
* <h2>修改自定义配置数据</h2>
|
||||||
*
|
*
|
||||||
* @param onlyMark 唯一标识
|
* @param onlyMark 唯一标识
|
||||||
* @param value 值
|
* @param value 值
|
||||||
* @param desc 描述
|
* @param desc 描述
|
||||||
* @return 是否更新成功
|
* @return 是否更新成功
|
||||||
*/
|
*/
|
||||||
@Update("update $t{configTableName} set param_value = #{paramValue}, \n" +
|
@Update("update $t{configTableName} set param_value = #{paramValue}, \n" +
|
||||||
"param_desc = #{paramDesc} where only_mark = #{onlyMark}")
|
"param_desc = #{paramDesc} where only_mark = #{onlyMark}")
|
||||||
boolean updateConfigValueByOnlyMark(@ParamMapper("onlyMark") String onlyMark,
|
boolean updateConfigValueByOnlyMark(@ParamMapper("onlyMark") String onlyMark,
|
||||||
@ParamMapper("paramValue") String value,
|
@ParamMapper("paramValue") String value,
|
||||||
@ParamMapper("paramDesc") String desc,
|
@ParamMapper("paramDesc") String desc,
|
||||||
@ParamMapper("configTableName") String configTableName);
|
@ParamMapper("configTableName") String configTableName);
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -1,68 +1,68 @@
|
||||||
package aiyh.utils.recordset;
|
package aiyh.utils.recordset;
|
||||||
|
|
||||||
import aiyh.utils.annotation.BooleanConverter;
|
import aiyh.utils.annotation.BooleanConverter;
|
||||||
import aiyh.utils.annotation.BooleanConverterEnum;
|
import aiyh.utils.annotation.BooleanConverterEnum;
|
||||||
import aiyh.utils.excention.CustomerException;
|
import aiyh.utils.excention.CustomerException;
|
||||||
import com.google.common.base.Strings;
|
import com.google.common.base.Strings;
|
||||||
import org.jetbrains.annotations.NotNull;
|
import org.jetbrains.annotations.NotNull;
|
||||||
import weaver.conn.RecordSet;
|
import weaver.conn.RecordSet;
|
||||||
|
|
||||||
import java.lang.reflect.Field;
|
import java.lang.reflect.Field;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @author EBU7-dev1-ayh
|
* @author EBU7-dev1-ayh
|
||||||
* create 2021/12/21 0021 13:34
|
* create 2021/12/21 0021 13:34
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
|
||||||
public class BooleanTypeHandler implements TypeHandler{
|
public class BooleanTypeHandler implements TypeHandler{
|
||||||
@Override
|
@Override
|
||||||
public Object getValue(RecordSet rs, String fieldName, Field declaredField) {
|
public Object getValue(RecordSet rs, String fieldName, Field declaredField) {
|
||||||
return getBoolean(declaredField, rs.getString(fieldName));
|
return getBoolean(declaredField, rs.getString(fieldName));
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public Object getValue(RecordSet rs, int index,Field declaredField) {
|
public Object getValue(RecordSet rs, int index,Field declaredField) {
|
||||||
return getBoolean(declaredField, rs.getString(index));
|
return getBoolean(declaredField, rs.getString(index));
|
||||||
}
|
}
|
||||||
|
|
||||||
@NotNull
|
@NotNull
|
||||||
private Object getBoolean(Field declaredField, String fieldValue) {
|
private Object getBoolean(Field declaredField, String fieldValue) {
|
||||||
try {
|
try {
|
||||||
BooleanConverter annotation = declaredField.getAnnotation(BooleanConverter.class);
|
BooleanConverter annotation = declaredField.getAnnotation(BooleanConverter.class);
|
||||||
BooleanConverterEnum value = annotation.value();
|
BooleanConverterEnum value = annotation.value();
|
||||||
String trueStr = annotation.trueStr();
|
String trueStr = annotation.trueStr();
|
||||||
String falseStr = annotation.falseStr();
|
String falseStr = annotation.falseStr();
|
||||||
String trueInteger = annotation.trueInteger();
|
String trueInteger = annotation.trueInteger();
|
||||||
String falseInteger = annotation.falseInteger();
|
String falseInteger = annotation.falseInteger();
|
||||||
boolean defaultValue = annotation.defaultValue();
|
boolean defaultValue = annotation.defaultValue();
|
||||||
String booleanVal = null;
|
String booleanVal = null;
|
||||||
try {
|
try {
|
||||||
booleanVal = fieldValue;
|
booleanVal = fieldValue;
|
||||||
} catch (Exception ignored) {
|
} catch (Exception ignored) {
|
||||||
}
|
}
|
||||||
boolean hasValueTrue = annotation.hasValueTrue();
|
boolean hasValueTrue = annotation.hasValueTrue();
|
||||||
if (value == BooleanConverterEnum.STRING) {
|
if (value == BooleanConverterEnum.STRING) {
|
||||||
if (booleanVal == null || booleanVal.equals(falseStr)) {
|
if (booleanVal == null || booleanVal.equals(falseStr)) {
|
||||||
return false;
|
return false;
|
||||||
} else if ((hasValueTrue && !Strings.isNullOrEmpty(booleanVal)) || booleanVal.equals(trueStr)) {
|
} else if ((hasValueTrue && !Strings.isNullOrEmpty(booleanVal)) || booleanVal.equals(trueStr)) {
|
||||||
return true;
|
return true;
|
||||||
} else {
|
} else {
|
||||||
return defaultValue;
|
return defaultValue;
|
||||||
}
|
}
|
||||||
} else if (value == BooleanConverterEnum.INTEGER) {
|
} else if (value == BooleanConverterEnum.INTEGER) {
|
||||||
if (booleanVal == null || booleanVal.equals(falseInteger)) {
|
if (booleanVal == null || booleanVal.equals(falseInteger)) {
|
||||||
return false;
|
return false;
|
||||||
} else if ((hasValueTrue && !Strings.isNullOrEmpty(booleanVal)) || booleanVal.equals(trueInteger)) {
|
} else if ((hasValueTrue && !Strings.isNullOrEmpty(booleanVal)) || booleanVal.equals(trueInteger)) {
|
||||||
return true;
|
return true;
|
||||||
} else {
|
} else {
|
||||||
return defaultValue;
|
return defaultValue;
|
||||||
}
|
}
|
||||||
}else {
|
}else {
|
||||||
return defaultValue;
|
return defaultValue;
|
||||||
}
|
}
|
||||||
} catch (Exception e) {
|
} catch (Exception e) {
|
||||||
throw new CustomerException("不支持的类型转换!");
|
throw new CustomerException("不支持的类型转换!");
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -1,56 +1,56 @@
|
||||||
package aiyh.utils.recordset;
|
package aiyh.utils.recordset;
|
||||||
|
|
||||||
import aiyh.utils.annotation.DateFormatAn;
|
import aiyh.utils.annotation.DateFormatAn;
|
||||||
import aiyh.utils.excention.TypeNonsupportException;
|
import aiyh.utils.excention.TypeNonsupportException;
|
||||||
import com.ibm.icu.text.SimpleDateFormat;
|
import com.ibm.icu.text.SimpleDateFormat;
|
||||||
import weaver.conn.RecordSet;
|
import weaver.conn.RecordSet;
|
||||||
|
|
||||||
import java.lang.reflect.Field;
|
import java.lang.reflect.Field;
|
||||||
import java.text.ParseException;
|
import java.text.ParseException;
|
||||||
import java.util.Date;
|
import java.util.Date;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @author EBU7-dev1-ayh
|
* @author EBU7-dev1-ayh
|
||||||
* create 2021/12/21 0021 13:35
|
* create 2021/12/21 0021 13:35
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
|
||||||
public class DataTypeHandler implements TypeHandler {
|
public class DataTypeHandler implements TypeHandler {
|
||||||
@Override
|
@Override
|
||||||
public Object getValue(RecordSet rs, String fieldName, Field declaredField) {
|
public Object getValue(RecordSet rs, String fieldName, Field declaredField) {
|
||||||
if (declaredField == null) {
|
if (declaredField == null) {
|
||||||
throw new TypeNonsupportException("An error occurred while trying to convert the query result field to type Date!");
|
throw new TypeNonsupportException("An error occurred while trying to convert the query result field to type Date!");
|
||||||
}
|
}
|
||||||
DateFormatAn annotation = declaredField.getAnnotation(DateFormatAn.class);
|
DateFormatAn annotation = declaredField.getAnnotation(DateFormatAn.class);
|
||||||
Date date = null;
|
Date date = null;
|
||||||
if (annotation != null) {
|
if (annotation != null) {
|
||||||
String value = annotation.value();
|
String value = annotation.value();
|
||||||
try {
|
try {
|
||||||
date = new SimpleDateFormat(value).parse(rs.getString(fieldName));
|
date = new SimpleDateFormat(value).parse(rs.getString(fieldName));
|
||||||
} catch (ParseException e) {
|
} catch (ParseException e) {
|
||||||
e.printStackTrace();
|
e.printStackTrace();
|
||||||
throw new TypeNonsupportException("Failed to convert [" + rs.getString(fieldName) + "] to a Date object as [" + value + "]!!");
|
throw new TypeNonsupportException("Failed to convert [" + rs.getString(fieldName) + "] to a Date object as [" + value + "]!!");
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
return date;
|
return date;
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public Object getValue(RecordSet rs, int index, Field declaredField) {
|
public Object getValue(RecordSet rs, int index, Field declaredField) {
|
||||||
if (declaredField == null) {
|
if (declaredField == null) {
|
||||||
throw new TypeNonsupportException("An error occurred while trying to convert the query result field to type Date!");
|
throw new TypeNonsupportException("An error occurred while trying to convert the query result field to type Date!");
|
||||||
}
|
}
|
||||||
DateFormatAn annotation = declaredField.getAnnotation(DateFormatAn.class);
|
DateFormatAn annotation = declaredField.getAnnotation(DateFormatAn.class);
|
||||||
Date date = null;
|
Date date = null;
|
||||||
if (annotation != null) {
|
if (annotation != null) {
|
||||||
String value = annotation.value();
|
String value = annotation.value();
|
||||||
try {
|
try {
|
||||||
date = new SimpleDateFormat(value).parse(rs.getString(index));
|
date = new SimpleDateFormat(value).parse(rs.getString(index));
|
||||||
} catch (ParseException e) {
|
} catch (ParseException e) {
|
||||||
e.printStackTrace();
|
e.printStackTrace();
|
||||||
throw new TypeNonsupportException("Failed to convert [" + rs.getString(index) + "] to a Date object as [" + value + "]!!");
|
throw new TypeNonsupportException("Failed to convert [" + rs.getString(index) + "] to a Date object as [" + value + "]!!");
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
return date;
|
return date;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -1,32 +1,32 @@
|
||||||
package aiyh.utils.recordset;
|
package aiyh.utils.recordset;
|
||||||
|
|
||||||
import aiyh.utils.Util;
|
import aiyh.utils.Util;
|
||||||
import weaver.conn.RecordSet;
|
import weaver.conn.RecordSet;
|
||||||
|
|
||||||
import java.lang.reflect.Field;
|
import java.lang.reflect.Field;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @author EBU7-dev1-ayh
|
* @author EBU7-dev1-ayh
|
||||||
* create 2021/12/21 0021 13:10
|
* create 2021/12/21 0021 13:10
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
|
||||||
public class IntegerTypeHandler implements TypeHandler{
|
public class IntegerTypeHandler implements TypeHandler{
|
||||||
@Override
|
@Override
|
||||||
public Object getValue(RecordSet rs, String fieldName, Field declaredField) {
|
public Object getValue(RecordSet rs, String fieldName, Field declaredField) {
|
||||||
String string = Util.null2DefaultStr(rs.getString(fieldName),"-1");
|
String string = Util.null2DefaultStr(rs.getString(fieldName),"-1");
|
||||||
if(string.contains(".")){
|
if(string.contains(".")){
|
||||||
string = string.substring(0,string.indexOf("."));
|
string = string.substring(0,string.indexOf("."));
|
||||||
}
|
}
|
||||||
return Integer.parseInt(string);
|
return Integer.parseInt(string);
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public Object getValue(RecordSet rs, int index,Field declaredField) {
|
public Object getValue(RecordSet rs, int index,Field declaredField) {
|
||||||
String string = Util.null2DefaultStr(rs.getString(index),"-1");
|
String string = Util.null2DefaultStr(rs.getString(index),"-1");
|
||||||
if(string.contains(".")){
|
if(string.contains(".")){
|
||||||
string = string.substring(0,string.indexOf("."));
|
string = string.substring(0,string.indexOf("."));
|
||||||
}
|
}
|
||||||
return Integer.parseInt(string);
|
return Integer.parseInt(string);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -1,211 +1,211 @@
|
||||||
package aiyh.utils.recordset;
|
package aiyh.utils.recordset;
|
||||||
|
|
||||||
import aiyh.utils.Util;
|
import aiyh.utils.Util;
|
||||||
import aiyh.utils.annotation.recordset.*;
|
import aiyh.utils.annotation.recordset.*;
|
||||||
import aiyh.utils.excention.BindingException;
|
import aiyh.utils.excention.BindingException;
|
||||||
import aiyh.utils.excention.CustomerException;
|
import aiyh.utils.excention.CustomerException;
|
||||||
import aiyh.utils.sqlUtil.sqlResult.impl.BatchSqlResultImpl;
|
import aiyh.utils.sqlUtil.sqlResult.impl.BatchSqlResultImpl;
|
||||||
import aiyh.utils.sqlUtil.sqlResult.impl.PrepSqlResultImpl;
|
import aiyh.utils.sqlUtil.sqlResult.impl.PrepSqlResultImpl;
|
||||||
import weaver.conn.RecordSet;
|
import weaver.conn.RecordSet;
|
||||||
|
|
||||||
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;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @author EBU7-dev1-ayh
|
* @author EBU7-dev1-ayh
|
||||||
* create 2021/12/19 0019 14:39
|
* create 2021/12/19 0019 14:39
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
|
||||||
public class RecordsetUtil implements InvocationHandler {
|
public class RecordsetUtil implements InvocationHandler {
|
||||||
|
|
||||||
private final RecordSet recordSet = new RecordSet();
|
private final RecordSet recordSet = new RecordSet();
|
||||||
|
|
||||||
public <T> T getMapper(Class<T> tClass) {
|
public <T> T getMapper(Class<T> tClass) {
|
||||||
if (tClass == null) {
|
if (tClass == null) {
|
||||||
throw new BindingException("class is null!");
|
throw new BindingException("class is null!");
|
||||||
}
|
}
|
||||||
if (tClass.getAnnotation(SqlMapper.class) == null) {
|
if (tClass.getAnnotation(SqlMapper.class) == null) {
|
||||||
throw new BindingException("can not find SqlMapper annotation!");
|
throw new BindingException("can not find SqlMapper annotation!");
|
||||||
}
|
}
|
||||||
return (T) Proxy.newProxyInstance(tClass.getClassLoader(), new Class[]{tClass}, this);
|
return (T) Proxy.newProxyInstance(tClass.getClassLoader(), new Class[]{tClass}, this);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public Object invoke(Object proxy, Method method, Object[] args) {
|
public Object invoke(Object proxy, Method method, Object[] args) {
|
||||||
|
|
||||||
SqlHandler sqlHandler = new SqlHandler();
|
SqlHandler sqlHandler = new SqlHandler();
|
||||||
ResultMapper resultMapper = new ResultMapper();
|
ResultMapper resultMapper = new ResultMapper();
|
||||||
Select select = method.getAnnotation(Select.class);
|
Select select = method.getAnnotation(Select.class);
|
||||||
if (select != null) {
|
if (select != null) {
|
||||||
// 查询
|
// 查询
|
||||||
RecordSet rs = new RecordSet();
|
RecordSet rs = new RecordSet();
|
||||||
String sql = select.value();
|
String sql = select.value();
|
||||||
boolean custom = select.custom();
|
boolean custom = select.custom();
|
||||||
PrepSqlResultImpl handler = sqlHandler.handler(sql, custom, method, args);
|
PrepSqlResultImpl handler = sqlHandler.handler(sql, custom, method, args);
|
||||||
if (!handler.getSqlStr().trim().toLowerCase().startsWith("select ")) {
|
if (!handler.getSqlStr().trim().toLowerCase().startsWith("select ")) {
|
||||||
throw new CustomerException("The sql statement does not match, the @Select annotation can only execute the select statement, please check whether the sql statement matches!");
|
throw new CustomerException("The sql statement does not match, the @Select annotation can only getDataId the select statement, please check whether the sql statement matches!");
|
||||||
}
|
}
|
||||||
Util.getLogger("sql_log").info("解析sql===>" + handler);
|
Util.getLogger("sql_log").info("解析sql===>" + handler);
|
||||||
if (handler.getArgs().isEmpty()) {
|
if (handler.getArgs().isEmpty()) {
|
||||||
rs.executeQuery(handler.getSqlStr());
|
rs.executeQuery(handler.getSqlStr());
|
||||||
} else {
|
} else {
|
||||||
rs.executeQuery(handler.getSqlStr(), handler.getArgs());
|
rs.executeQuery(handler.getSqlStr(), handler.getArgs());
|
||||||
}
|
}
|
||||||
return resultMapper.mapperResult(rs, method, method.getReturnType());
|
return resultMapper.mapperResult(rs, method, method.getReturnType());
|
||||||
}
|
}
|
||||||
Update update = method.getAnnotation(Update.class);
|
Update update = method.getAnnotation(Update.class);
|
||||||
|
|
||||||
if (update != null) {
|
if (update != null) {
|
||||||
// 查询
|
// 查询
|
||||||
String sql = update.value();
|
String sql = update.value();
|
||||||
boolean custom = update.custom();
|
boolean custom = update.custom();
|
||||||
PrepSqlResultImpl handler = sqlHandler.handler(sql, custom, method, args);
|
PrepSqlResultImpl handler = sqlHandler.handler(sql, custom, method, args);
|
||||||
if (!handler.getSqlStr().trim().toLowerCase().startsWith("update ")) {
|
if (!handler.getSqlStr().trim().toLowerCase().startsWith("update ")) {
|
||||||
throw new CustomerException("The sql statement does not match, the @Update annotation can only execute the update statement, please check whether the sql statement matches!");
|
throw new CustomerException("The sql statement does not match, the @Update annotation can only getDataId the update statement, please check whether the sql statement matches!");
|
||||||
}
|
}
|
||||||
Util.getLogger("sql_log").info(handler.toString());
|
Util.getLogger("sql_log").info(handler.toString());
|
||||||
Class<?> returnType = method.getReturnType();
|
Class<?> returnType = method.getReturnType();
|
||||||
boolean b;
|
boolean b;
|
||||||
if (handler.getArgs().isEmpty()) {
|
if (handler.getArgs().isEmpty()) {
|
||||||
b = recordSet.executeUpdate(handler.getSqlStr());
|
b = recordSet.executeUpdate(handler.getSqlStr());
|
||||||
} else {
|
} else {
|
||||||
b = recordSet.executeUpdate(handler.getSqlStr(), handler.getArgs());
|
b = recordSet.executeUpdate(handler.getSqlStr(), handler.getArgs());
|
||||||
}
|
}
|
||||||
if (returnType.equals(void.class)) {
|
if (returnType.equals(void.class)) {
|
||||||
return null;
|
return null;
|
||||||
}
|
}
|
||||||
if (returnType.equals(int.class) || returnType.equals(Integer.class)) {
|
if (returnType.equals(int.class) || returnType.equals(Integer.class)) {
|
||||||
if (b) {
|
if (b) {
|
||||||
return 1;
|
return 1;
|
||||||
} else {
|
} else {
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
if (returnType.equals(boolean.class) || returnType.equals(Boolean.class)) {
|
if (returnType.equals(boolean.class) || returnType.equals(Boolean.class)) {
|
||||||
return b;
|
return b;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
Insert insert = method.getAnnotation(Insert.class);
|
Insert insert = method.getAnnotation(Insert.class);
|
||||||
if (insert != null) {
|
if (insert != null) {
|
||||||
// 查询
|
// 查询
|
||||||
String sql = insert.value();
|
String sql = insert.value();
|
||||||
boolean custom = insert.custom();
|
boolean custom = insert.custom();
|
||||||
PrepSqlResultImpl handler = sqlHandler.handler(sql, custom, method, args);
|
PrepSqlResultImpl handler = sqlHandler.handler(sql, custom, method, args);
|
||||||
if (!handler.getSqlStr().trim().toLowerCase().startsWith("insert ")) {
|
if (!handler.getSqlStr().trim().toLowerCase().startsWith("insert ")) {
|
||||||
throw new CustomerException("The sql statement does not match, the @Insert annotation can only execute the insert statement, please check whether the sql statement matches!");
|
throw new CustomerException("The sql statement does not match, the @Insert annotation can only getDataId the insert statement, please check whether the sql statement matches!");
|
||||||
}
|
}
|
||||||
Util.getLogger("sql_log").info(handler.toString());
|
Util.getLogger("sql_log").info(handler.toString());
|
||||||
Class<?> returnType = method.getReturnType();
|
Class<?> returnType = method.getReturnType();
|
||||||
boolean b;
|
boolean b;
|
||||||
if (handler.getArgs().isEmpty()) {
|
if (handler.getArgs().isEmpty()) {
|
||||||
b = recordSet.executeUpdate(handler.getSqlStr());
|
b = recordSet.executeUpdate(handler.getSqlStr());
|
||||||
} else {
|
} else {
|
||||||
b = recordSet.executeUpdate(handler.getSqlStr(), handler.getArgs());
|
b = recordSet.executeUpdate(handler.getSqlStr(), handler.getArgs());
|
||||||
}
|
}
|
||||||
if (returnType.equals(void.class)) {
|
if (returnType.equals(void.class)) {
|
||||||
return null;
|
return null;
|
||||||
}
|
}
|
||||||
if (returnType.equals(boolean.class) || returnType.equals(Boolean.class)) {
|
if (returnType.equals(boolean.class) || returnType.equals(Boolean.class)) {
|
||||||
return b;
|
return b;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
Delete delete = method.getAnnotation(Delete.class);
|
Delete delete = method.getAnnotation(Delete.class);
|
||||||
if (delete != null) {
|
if (delete != null) {
|
||||||
// 查询
|
// 查询
|
||||||
String sql = delete.value();
|
String sql = delete.value();
|
||||||
boolean custom = delete.custom();
|
boolean custom = delete.custom();
|
||||||
PrepSqlResultImpl handler = sqlHandler.handler(sql, custom, method, args);
|
PrepSqlResultImpl handler = sqlHandler.handler(sql, custom, method, args);
|
||||||
if (!handler.getSqlStr().trim().toLowerCase().startsWith("delete ")) {
|
if (!handler.getSqlStr().trim().toLowerCase().startsWith("delete ")) {
|
||||||
throw new CustomerException("The sql statement does not match, the @Delete annotation can only execute the delete statement, please check whether the sql statement matches!");
|
throw new CustomerException("The sql statement does not match, the @Delete annotation can only getDataId the delete statement, please check whether the sql statement matches!");
|
||||||
}
|
}
|
||||||
Util.getLogger("sql_log").info(handler.toString());
|
Util.getLogger("sql_log").info(handler.toString());
|
||||||
Class<?> returnType = method.getReturnType();
|
Class<?> returnType = method.getReturnType();
|
||||||
boolean b;
|
boolean b;
|
||||||
if (handler.getArgs().isEmpty()) {
|
if (handler.getArgs().isEmpty()) {
|
||||||
b = recordSet.executeUpdate(handler.getSqlStr());
|
b = recordSet.executeUpdate(handler.getSqlStr());
|
||||||
} else {
|
} else {
|
||||||
b = recordSet.executeUpdate(handler.getSqlStr(), handler.getArgs());
|
b = recordSet.executeUpdate(handler.getSqlStr(), handler.getArgs());
|
||||||
}
|
}
|
||||||
if (returnType.equals(void.class)) {
|
if (returnType.equals(void.class)) {
|
||||||
return null;
|
return null;
|
||||||
}
|
}
|
||||||
if (returnType.equals(boolean.class) || returnType.equals(Boolean.class)) {
|
if (returnType.equals(boolean.class) || returnType.equals(Boolean.class)) {
|
||||||
return b;
|
return b;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
boolean hasBatchInsert = method.isAnnotationPresent(BatchInsert.class);
|
boolean hasBatchInsert = method.isAnnotationPresent(BatchInsert.class);
|
||||||
if (hasBatchInsert) {
|
if (hasBatchInsert) {
|
||||||
BatchInsert batchInsert = method.getAnnotation(BatchInsert.class);
|
BatchInsert batchInsert = method.getAnnotation(BatchInsert.class);
|
||||||
String sql = batchInsert.value();
|
String sql = batchInsert.value();
|
||||||
Class<?> returnType = method.getReturnType();
|
Class<?> returnType = method.getReturnType();
|
||||||
boolean custom = batchInsert.custom();
|
boolean custom = batchInsert.custom();
|
||||||
BatchSqlResultImpl batchSqlResult = sqlHandler.handlerBatch(sql, custom, method, args);
|
BatchSqlResultImpl batchSqlResult = sqlHandler.handlerBatch(sql, custom, method, args);
|
||||||
Util.getLogger("sql_log").info(batchSqlResult.toString());
|
Util.getLogger("sql_log").info(batchSqlResult.toString());
|
||||||
if (batchSqlResult.getBatchList().isEmpty()) {
|
if (batchSqlResult.getBatchList().isEmpty()) {
|
||||||
throw new CustomerException("execute batch sql error , batch sql args is empty!");
|
throw new CustomerException("getDataId batch sql error , batch sql args is empty!");
|
||||||
}
|
}
|
||||||
if (!batchSqlResult.getSqlStr().trim().toLowerCase().startsWith("insert ")) {
|
if (!batchSqlResult.getSqlStr().trim().toLowerCase().startsWith("insert ")) {
|
||||||
throw new CustomerException("The sql statement does not match, the @Insert annotation can only execute the insert statement, please check whether the sql statement matches!");
|
throw new CustomerException("The sql statement does not match, the @Insert annotation can only getDataId the insert statement, please check whether the sql statement matches!");
|
||||||
}
|
}
|
||||||
boolean b = recordSet.executeBatchSql(batchSqlResult.getSqlStr(), batchSqlResult.getBatchList());
|
boolean b = recordSet.executeBatchSql(batchSqlResult.getSqlStr(), batchSqlResult.getBatchList());
|
||||||
if (returnType.equals(void.class)) {
|
if (returnType.equals(void.class)) {
|
||||||
return null;
|
return null;
|
||||||
}
|
}
|
||||||
if (returnType.equals(boolean.class) || returnType.equals(Boolean.class)) {
|
if (returnType.equals(boolean.class) || returnType.equals(Boolean.class)) {
|
||||||
return b;
|
return b;
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
boolean hasBatchUpdate = method.isAnnotationPresent(BatchUpdate.class);
|
boolean hasBatchUpdate = method.isAnnotationPresent(BatchUpdate.class);
|
||||||
if (hasBatchUpdate) {
|
if (hasBatchUpdate) {
|
||||||
BatchUpdate batchUpdate = method.getAnnotation(BatchUpdate.class);
|
BatchUpdate batchUpdate = method.getAnnotation(BatchUpdate.class);
|
||||||
String sql = batchUpdate.value();
|
String sql = batchUpdate.value();
|
||||||
Class<?> returnType = method.getReturnType();
|
Class<?> returnType = method.getReturnType();
|
||||||
boolean custom = batchUpdate.custom();
|
boolean custom = batchUpdate.custom();
|
||||||
BatchSqlResultImpl batchSqlResult = sqlHandler.handlerBatch(sql, custom, method, args);
|
BatchSqlResultImpl batchSqlResult = sqlHandler.handlerBatch(sql, custom, method, args);
|
||||||
Util.getLogger("sql_log").info(batchSqlResult.toString());
|
Util.getLogger("sql_log").info(batchSqlResult.toString());
|
||||||
if (batchSqlResult.getBatchList().isEmpty()) {
|
if (batchSqlResult.getBatchList().isEmpty()) {
|
||||||
throw new CustomerException("execute batch sql error , batch sql args is empty!");
|
throw new CustomerException("getDataId batch sql error , batch sql args is empty!");
|
||||||
}
|
}
|
||||||
if (!batchSqlResult.getSqlStr().trim().toLowerCase().startsWith("update ")) {
|
if (!batchSqlResult.getSqlStr().trim().toLowerCase().startsWith("update ")) {
|
||||||
throw new CustomerException("The sql statement does not match, the @Update annotation can only execute the update statement, please check whether the sql statement matches!");
|
throw new CustomerException("The sql statement does not match, the @Update annotation can only getDataId the update statement, please check whether the sql statement matches!");
|
||||||
}
|
}
|
||||||
boolean b = recordSet.executeBatchSql(batchSqlResult.getSqlStr(), batchSqlResult.getBatchList());
|
boolean b = recordSet.executeBatchSql(batchSqlResult.getSqlStr(), batchSqlResult.getBatchList());
|
||||||
if (returnType.equals(void.class)) {
|
if (returnType.equals(void.class)) {
|
||||||
return null;
|
return null;
|
||||||
}
|
}
|
||||||
if (returnType.equals(boolean.class) || returnType.equals(Boolean.class)) {
|
if (returnType.equals(boolean.class) || returnType.equals(Boolean.class)) {
|
||||||
return b;
|
return b;
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
boolean hasBatchDelete = method.isAnnotationPresent(BatchDelete.class);
|
boolean hasBatchDelete = method.isAnnotationPresent(BatchDelete.class);
|
||||||
if (hasBatchDelete) {
|
if (hasBatchDelete) {
|
||||||
BatchDelete batchDelete = method.getAnnotation(BatchDelete.class);
|
BatchDelete batchDelete = method.getAnnotation(BatchDelete.class);
|
||||||
String sql = batchDelete.value();
|
String sql = batchDelete.value();
|
||||||
Class<?> returnType = method.getReturnType();
|
Class<?> returnType = method.getReturnType();
|
||||||
boolean custom = batchDelete.custom();
|
boolean custom = batchDelete.custom();
|
||||||
BatchSqlResultImpl batchSqlResult = sqlHandler.handlerBatch(sql, custom, method, args);
|
BatchSqlResultImpl batchSqlResult = sqlHandler.handlerBatch(sql, custom, method, args);
|
||||||
Util.getLogger("sql_log").info(batchSqlResult.toString());
|
Util.getLogger("sql_log").info(batchSqlResult.toString());
|
||||||
if (batchSqlResult.getBatchList().isEmpty()) {
|
if (batchSqlResult.getBatchList().isEmpty()) {
|
||||||
throw new CustomerException("execute batch sql error , batch sql args is empty!");
|
throw new CustomerException("getDataId batch sql error , batch sql args is empty!");
|
||||||
}
|
}
|
||||||
if (!batchSqlResult.getSqlStr().trim().toLowerCase().startsWith("delete ")) {
|
if (!batchSqlResult.getSqlStr().trim().toLowerCase().startsWith("delete ")) {
|
||||||
throw new CustomerException("The sql statement does not match, the @Delete annotation can only execute the delete statement, please check whether the sql statement matches!");
|
throw new CustomerException("The sql statement does not match, the @Delete annotation can only getDataId the delete statement, please check whether the sql statement matches!");
|
||||||
}
|
}
|
||||||
boolean b = recordSet.executeBatchSql(batchSqlResult.getSqlStr(), batchSqlResult.getBatchList());
|
boolean b = recordSet.executeBatchSql(batchSqlResult.getSqlStr(), batchSqlResult.getBatchList());
|
||||||
if (returnType.equals(void.class)) {
|
if (returnType.equals(void.class)) {
|
||||||
return null;
|
return null;
|
||||||
}
|
}
|
||||||
if (returnType.equals(boolean.class) || returnType.equals(Boolean.class)) {
|
if (returnType.equals(boolean.class) || returnType.equals(Boolean.class)) {
|
||||||
return b;
|
return b;
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
throw new CustomerException("该方法没有添加注解!请检查是否正确添加注解!@Select、@Update、@Insert、@Delete、@BatchUpdate、@BatchInsert、@BatchDelete");
|
throw new CustomerException("该方法没有添加注解!请检查是否正确添加注解!@Select、@Update、@Insert、@Delete、@BatchUpdate、@BatchInsert、@BatchDelete");
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -1,278 +1,278 @@
|
||||||
package aiyh.utils.recordset;
|
package aiyh.utils.recordset;
|
||||||
|
|
||||||
import aiyh.utils.Util;
|
import aiyh.utils.Util;
|
||||||
import aiyh.utils.annotation.recordset.CaseConversion;
|
import aiyh.utils.annotation.recordset.CaseConversion;
|
||||||
import aiyh.utils.excention.CustomerException;
|
import aiyh.utils.excention.CustomerException;
|
||||||
import aiyh.utils.excention.TypeNonsupportException;
|
import aiyh.utils.excention.TypeNonsupportException;
|
||||||
import com.google.common.base.Strings;
|
import com.google.common.base.Strings;
|
||||||
import weaver.conn.RecordSet;
|
import weaver.conn.RecordSet;
|
||||||
import weaver.conn.RecordSetTrans;
|
import weaver.conn.RecordSetTrans;
|
||||||
|
|
||||||
import java.beans.BeanInfo;
|
import java.beans.BeanInfo;
|
||||||
import java.beans.Introspector;
|
import java.beans.Introspector;
|
||||||
import java.beans.PropertyDescriptor;
|
import java.beans.PropertyDescriptor;
|
||||||
import java.lang.reflect.*;
|
import java.lang.reflect.*;
|
||||||
import java.util.*;
|
import java.util.*;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @author EBU7-dev1-ayh
|
* @author EBU7-dev1-ayh
|
||||||
* create 2021/12/21 0021 11:03
|
* create 2021/12/21 0021 11:03
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
|
||||||
public class ResultMapper {
|
public class ResultMapper {
|
||||||
|
|
||||||
private static Map<Class<?>, TypeHandler> typeHandler = new HashMap<>();
|
private static Map<Class<?>, TypeHandler> typeHandler = new HashMap<>();
|
||||||
|
|
||||||
static {
|
static {
|
||||||
IntegerTypeHandler integerTypeHandler = new IntegerTypeHandler();
|
IntegerTypeHandler integerTypeHandler = new IntegerTypeHandler();
|
||||||
typeHandler.put(String.class, new StringTypeHandler());
|
typeHandler.put(String.class, new StringTypeHandler());
|
||||||
typeHandler.put(Integer.class, integerTypeHandler);
|
typeHandler.put(Integer.class, integerTypeHandler);
|
||||||
typeHandler.put(int.class, integerTypeHandler);
|
typeHandler.put(int.class, integerTypeHandler);
|
||||||
typeHandler.put(byte.class, integerTypeHandler);
|
typeHandler.put(byte.class, integerTypeHandler);
|
||||||
typeHandler.put(short.class, integerTypeHandler);
|
typeHandler.put(short.class, integerTypeHandler);
|
||||||
typeHandler.put(long.class, integerTypeHandler);
|
typeHandler.put(long.class, integerTypeHandler);
|
||||||
typeHandler.put(Long.class, integerTypeHandler);
|
typeHandler.put(Long.class, integerTypeHandler);
|
||||||
typeHandler.put(Boolean.class, new BooleanTypeHandler());
|
typeHandler.put(Boolean.class, new BooleanTypeHandler());
|
||||||
typeHandler.put(boolean.class, new BooleanTypeHandler());
|
typeHandler.put(boolean.class, new BooleanTypeHandler());
|
||||||
typeHandler.put(Date.class, new DataTypeHandler());
|
typeHandler.put(Date.class, new DataTypeHandler());
|
||||||
typeHandler.put(Float.class, new FloatTypeHandler());
|
typeHandler.put(Float.class, new FloatTypeHandler());
|
||||||
typeHandler.put(float.class, new FloatTypeHandler());
|
typeHandler.put(float.class, new FloatTypeHandler());
|
||||||
}
|
}
|
||||||
|
|
||||||
public <T> T mapperResult(RecordSet rs, Method method, Class<T> tClass) {
|
public <T> T mapperResult(RecordSet rs, Method method, Class<T> tClass) {
|
||||||
if (tClass.equals(void.class)) {
|
if (tClass.equals(void.class)) {
|
||||||
return null;
|
return null;
|
||||||
}
|
}
|
||||||
if (tClass.equals(RecordSet.class) || tClass.equals(RecordSetTrans.class)) {
|
if (tClass.equals(RecordSet.class) || tClass.equals(RecordSetTrans.class)) {
|
||||||
return (T) rs;
|
return (T) rs;
|
||||||
}
|
}
|
||||||
try {
|
try {
|
||||||
if (tClass.equals(List.class)) {
|
if (tClass.equals(List.class)) {
|
||||||
tClass = (Class<T>) ArrayList.class;
|
tClass = (Class<T>) ArrayList.class;
|
||||||
}
|
}
|
||||||
if (tClass.equals(Map.class)) {
|
if (tClass.equals(Map.class)) {
|
||||||
tClass = (Class<T>) HashMap.class;
|
tClass = (Class<T>) HashMap.class;
|
||||||
}
|
}
|
||||||
if (ResultMapper.typeHandler.containsKey(tClass)) {
|
if (ResultMapper.typeHandler.containsKey(tClass)) {
|
||||||
rs.next();
|
rs.next();
|
||||||
return (T) ResultMapper.typeHandler.get(tClass).getValue(rs, 1, null);
|
return (T) ResultMapper.typeHandler.get(tClass).getValue(rs, 1, null);
|
||||||
}
|
}
|
||||||
T t = tClass.newInstance();
|
T t = tClass.newInstance();
|
||||||
if (t instanceof Collection) {
|
if (t instanceof Collection) {
|
||||||
// 集合求出泛型
|
// 集合求出泛型
|
||||||
//获取返回值的类型
|
//获取返回值的类型
|
||||||
Type genericReturnType = method.getGenericReturnType();
|
Type genericReturnType = method.getGenericReturnType();
|
||||||
Type actualTypeArgument = ((ParameterizedType) genericReturnType).getActualTypeArguments()[0];
|
Type actualTypeArgument = ((ParameterizedType) genericReturnType).getActualTypeArguments()[0];
|
||||||
Class<?> rawType = this.getRawType(actualTypeArgument);
|
Class<?> rawType = this.getRawType(actualTypeArgument);
|
||||||
if (rawType.equals(Map.class)) {
|
if (rawType.equals(Map.class)) {
|
||||||
rawType = HashMap.class;
|
rawType = HashMap.class;
|
||||||
}
|
}
|
||||||
while (rs.next()) {
|
while (rs.next()) {
|
||||||
Object o = null;
|
Object o = null;
|
||||||
try {
|
try {
|
||||||
Constructor<?> constructor = rawType.getConstructor();
|
Constructor<?> constructor = rawType.getConstructor();
|
||||||
o = constructor.newInstance();
|
o = constructor.newInstance();
|
||||||
} catch (NoSuchMethodException | InvocationTargetException ignored) {
|
} catch (NoSuchMethodException | InvocationTargetException ignored) {
|
||||||
if (Number.class.isAssignableFrom(rawType)) {
|
if (Number.class.isAssignableFrom(rawType)) {
|
||||||
Constructor<?> constructor;
|
Constructor<?> constructor;
|
||||||
try {
|
try {
|
||||||
constructor = rawType.getConstructor(String.class);
|
constructor = rawType.getConstructor(String.class);
|
||||||
o = constructor.newInstance("-1");
|
o = constructor.newInstance("-1");
|
||||||
} catch (NoSuchMethodException | InvocationTargetException e) {
|
} catch (NoSuchMethodException | InvocationTargetException e) {
|
||||||
throw new CustomerException("can not Initialization " + t.getClass() + " [" + rawType + "]", e);
|
throw new CustomerException("can not Initialization " + t.getClass() + " [" + rawType + "]", e);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
if (o == null) {
|
if (o == null) {
|
||||||
throw new CustomerException("can not Initialization " + t.getClass() + " [" + rawType + "]");
|
throw new CustomerException("can not Initialization " + t.getClass() + " [" + rawType + "]");
|
||||||
}
|
}
|
||||||
Object object = getObject(rs, o, method);
|
Object object = getObject(rs, o, method);
|
||||||
((Collection<? super Object>) t).add(object);
|
((Collection<? super Object>) t).add(object);
|
||||||
}
|
}
|
||||||
return t;
|
return t;
|
||||||
}
|
}
|
||||||
if (t instanceof Map) {
|
if (t instanceof Map) {
|
||||||
// map
|
// map
|
||||||
Type genericReturnType = method.getGenericReturnType();
|
Type genericReturnType = method.getGenericReturnType();
|
||||||
Type actualTypeArgument = ((ParameterizedType) genericReturnType).getActualTypeArguments()[0];
|
Type actualTypeArgument = ((ParameterizedType) genericReturnType).getActualTypeArguments()[0];
|
||||||
Class<?> rawType = this.getRawType(actualTypeArgument);
|
Class<?> rawType = this.getRawType(actualTypeArgument);
|
||||||
if (rawType.equals(List.class)) {
|
if (rawType.equals(List.class)) {
|
||||||
rawType = (Class<T>) ArrayList.class;
|
rawType = (Class<T>) ArrayList.class;
|
||||||
}
|
}
|
||||||
if (rawType.equals(Map.class)) {
|
if (rawType.equals(Map.class)) {
|
||||||
rawType = HashMap.class;
|
rawType = HashMap.class;
|
||||||
}
|
}
|
||||||
// Object o = rawType.newInstance();
|
// Object o = rawType.newInstance();
|
||||||
Object o = null;
|
Object o = null;
|
||||||
try {
|
try {
|
||||||
Constructor<?> constructor = rawType.getConstructor();
|
Constructor<?> constructor = rawType.getConstructor();
|
||||||
o = constructor.newInstance();
|
o = constructor.newInstance();
|
||||||
} catch (NoSuchMethodException | InvocationTargetException ignored) {
|
} catch (NoSuchMethodException | InvocationTargetException ignored) {
|
||||||
if (Number.class.isAssignableFrom(rawType)) {
|
if (Number.class.isAssignableFrom(rawType)) {
|
||||||
Constructor<?> constructor;
|
Constructor<?> constructor;
|
||||||
try {
|
try {
|
||||||
constructor = rawType.getConstructor(String.class);
|
constructor = rawType.getConstructor(String.class);
|
||||||
o = constructor.newInstance("-1");
|
o = constructor.newInstance("-1");
|
||||||
} catch (NoSuchMethodException | InvocationTargetException e) {
|
} catch (NoSuchMethodException | InvocationTargetException e) {
|
||||||
throw new CustomerException("can not Initialization " + t.getClass() + " [" + rawType + "]", e);
|
throw new CustomerException("can not Initialization " + t.getClass() + " [" + rawType + "]", e);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
if (o == null) {
|
if (o == null) {
|
||||||
throw new CustomerException("can not Initialization " + t.getClass() + " [" + rawType + "]");
|
throw new CustomerException("can not Initialization " + t.getClass() + " [" + rawType + "]");
|
||||||
}
|
}
|
||||||
if (o instanceof Map || o instanceof Collection) {
|
if (o instanceof Map || o instanceof Collection) {
|
||||||
throw new TypeNonsupportException("An unsupported return type!");
|
throw new TypeNonsupportException("An unsupported return type!");
|
||||||
}
|
}
|
||||||
if (rs.next()) {
|
if (rs.next()) {
|
||||||
return (T) getObject(rs, t, method);
|
return (T) getObject(rs, t, method);
|
||||||
}
|
}
|
||||||
return null;
|
return null;
|
||||||
}
|
}
|
||||||
if (t.getClass().isArray()) {
|
if (t.getClass().isArray()) {
|
||||||
throw new TypeNonsupportException("An unsupported return type!");
|
throw new TypeNonsupportException("An unsupported return type!");
|
||||||
}
|
}
|
||||||
if (rs.next()) {
|
if (rs.next()) {
|
||||||
return (T) getObject(rs, t, method);
|
return (T) getObject(rs, t, method);
|
||||||
}
|
}
|
||||||
return null;
|
return null;
|
||||||
} catch (InstantiationException | IllegalAccessException e) {
|
} catch (InstantiationException | IllegalAccessException e) {
|
||||||
e.printStackTrace();
|
e.printStackTrace();
|
||||||
}
|
}
|
||||||
return null;
|
return null;
|
||||||
}
|
}
|
||||||
|
|
||||||
public Object getObject(RecordSet rs, Object o, Method method) {
|
public Object getObject(RecordSet rs, Object o, Method method) {
|
||||||
CaseConversion annotation = method.getAnnotation(CaseConversion.class);
|
CaseConversion annotation = method.getAnnotation(CaseConversion.class);
|
||||||
boolean enable = annotation == null ? true : annotation.value();
|
boolean enable = annotation == null ? true : annotation.value();
|
||||||
String[] columnName = rs.getColumnName();
|
String[] columnName = rs.getColumnName();
|
||||||
String[] columnTypeName = rs.getColumnTypeName();
|
String[] columnTypeName = rs.getColumnTypeName();
|
||||||
int[] columnTypes = rs.getColumnType();
|
int[] columnTypes = rs.getColumnType();
|
||||||
if (columnTypeName == null) {
|
if (columnTypeName == null) {
|
||||||
columnTypeName = new String[columnTypes.length];
|
columnTypeName = new String[columnTypes.length];
|
||||||
for (int i = 0; i < columnTypes.length; i++) {
|
for (int i = 0; i < columnTypes.length; i++) {
|
||||||
int type = columnTypes[i];
|
int type = columnTypes[i];
|
||||||
switch (type) {
|
switch (type) {
|
||||||
case -1:
|
case -1:
|
||||||
columnTypeName[i] = "TEXT";
|
columnTypeName[i] = "TEXT";
|
||||||
break;
|
break;
|
||||||
case 4:
|
case 4:
|
||||||
columnTypeName[i] = "INT";
|
columnTypeName[i] = "INT";
|
||||||
break;
|
break;
|
||||||
case 12:
|
case 12:
|
||||||
columnTypeName[i] = "VARCHAR";
|
columnTypeName[i] = "VARCHAR";
|
||||||
break;
|
break;
|
||||||
default:
|
default:
|
||||||
columnTypeName[i] = "VARCHAR";
|
columnTypeName[i] = "VARCHAR";
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
try {
|
try {
|
||||||
if (o instanceof Map) {
|
if (o instanceof Map) {
|
||||||
for (int i = 0; i < columnName.length; i++) {
|
for (int i = 0; i < columnName.length; i++) {
|
||||||
String columnType = columnTypeName[i];
|
String columnType = columnTypeName[i];
|
||||||
if ("int".equalsIgnoreCase(columnType) || "long".equalsIgnoreCase(columnType) || "number".equalsIgnoreCase(columnType) || "MEDIUMINT".equalsIgnoreCase(columnType) || "TINYINT".equalsIgnoreCase(columnType) || "SMALLINT".equalsIgnoreCase(columnType) || "BIGINT".equalsIgnoreCase(columnType) || "INTEGER".equalsIgnoreCase(columnType)) {
|
if ("int".equalsIgnoreCase(columnType) || "long".equalsIgnoreCase(columnType) || "number".equalsIgnoreCase(columnType) || "MEDIUMINT".equalsIgnoreCase(columnType) || "TINYINT".equalsIgnoreCase(columnType) || "SMALLINT".equalsIgnoreCase(columnType) || "BIGINT".equalsIgnoreCase(columnType) || "INTEGER".equalsIgnoreCase(columnType)) {
|
||||||
if (enable) {
|
if (enable) {
|
||||||
((Map<? super Object, ? super Object>) o).put(Util.toCamelCase(columnName[i]), rs.getInt(i + 1));
|
((Map<? super Object, ? super Object>) o).put(Util.toCamelCase(columnName[i]), rs.getInt(i + 1));
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
((Map<? super Object, ? super Object>) o).put(columnName[i], rs.getInt(i + 1));
|
((Map<? super Object, ? super Object>) o).put(columnName[i], rs.getInt(i + 1));
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
if ("FLOAT".equalsIgnoreCase(columnType) || "DOUBLE".equalsIgnoreCase(columnType) || "DECIMAL".equalsIgnoreCase(columnType)) {
|
if ("FLOAT".equalsIgnoreCase(columnType) || "DOUBLE".equalsIgnoreCase(columnType) || "DECIMAL".equalsIgnoreCase(columnType)) {
|
||||||
if (enable) {
|
if (enable) {
|
||||||
((Map<? super Object, ? super Object>) o).put(Util.toCamelCase(columnName[i]), rs.getFloat(i + 1));
|
((Map<? super Object, ? super Object>) o).put(Util.toCamelCase(columnName[i]), rs.getFloat(i + 1));
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
((Map<? super Object, ? super Object>) o).put(columnName[i], rs.getFloat(i + 1));
|
((Map<? super Object, ? super Object>) o).put(columnName[i], rs.getFloat(i + 1));
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
if (enable) {
|
if (enable) {
|
||||||
((Map<? super Object, ? super Object>) o).put(Util.toCamelCase(columnName[i]), rs.getString(i + 1));
|
((Map<? super Object, ? super Object>) o).put(Util.toCamelCase(columnName[i]), rs.getString(i + 1));
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
((Map<? super Object, ? super Object>) o).put(columnName[i], rs.getString(i + 1));
|
((Map<? super Object, ? super Object>) o).put(columnName[i], rs.getString(i + 1));
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
return o;
|
return o;
|
||||||
}
|
}
|
||||||
if (o instanceof Collection) {
|
if (o instanceof Collection) {
|
||||||
throw new TypeNonsupportException("An unsupported return type!");
|
throw new TypeNonsupportException("An unsupported return type!");
|
||||||
}
|
}
|
||||||
if (o instanceof Number) {
|
if (o instanceof Number) {
|
||||||
for (int i = 0; i < columnName.length; i++) {
|
for (int i = 0; i < columnName.length; i++) {
|
||||||
String columnType = columnTypeName[i];
|
String columnType = columnTypeName[i];
|
||||||
if ("int".equalsIgnoreCase(columnType) || "long".equalsIgnoreCase(columnType) || "number".equalsIgnoreCase(columnType) || "MEDIUMINT".equalsIgnoreCase(columnType) || "TINYINT".equalsIgnoreCase(columnType) || "SMALLINT".equalsIgnoreCase(columnType) || "BIGINT".equalsIgnoreCase(columnType) || "INTEGER".equalsIgnoreCase(columnType)) {
|
if ("int".equalsIgnoreCase(columnType) || "long".equalsIgnoreCase(columnType) || "number".equalsIgnoreCase(columnType) || "MEDIUMINT".equalsIgnoreCase(columnType) || "TINYINT".equalsIgnoreCase(columnType) || "SMALLINT".equalsIgnoreCase(columnType) || "BIGINT".equalsIgnoreCase(columnType) || "INTEGER".equalsIgnoreCase(columnType)) {
|
||||||
return rs.getInt(i + 1);
|
return rs.getInt(i + 1);
|
||||||
}
|
}
|
||||||
if ("FLOAT".equalsIgnoreCase(columnType) || "DOUBLE".equalsIgnoreCase(columnType) || "DECIMAL".equalsIgnoreCase(columnType)) {
|
if ("FLOAT".equalsIgnoreCase(columnType) || "DOUBLE".equalsIgnoreCase(columnType) || "DECIMAL".equalsIgnoreCase(columnType)) {
|
||||||
return rs.getFloat(i + 1);
|
return rs.getFloat(i + 1);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
return o;
|
return o;
|
||||||
}
|
}
|
||||||
if (o instanceof String) {
|
if (o instanceof String) {
|
||||||
for (int i = 0; i < columnName.length; i++) {
|
for (int i = 0; i < columnName.length; i++) {
|
||||||
return rs.getString(i + 1);
|
return rs.getString(i + 1);
|
||||||
}
|
}
|
||||||
return o;
|
return o;
|
||||||
}
|
}
|
||||||
if (o instanceof Boolean) {
|
if (o instanceof Boolean) {
|
||||||
for (int i = 0; i < columnName.length; i++) {
|
for (int i = 0; i < columnName.length; i++) {
|
||||||
return rs.getBoolean(i + 1);
|
return rs.getBoolean(i + 1);
|
||||||
}
|
}
|
||||||
return o;
|
return o;
|
||||||
}
|
}
|
||||||
|
|
||||||
// Util.getLogger().info("获取对象:" + o.toString());
|
// Util.getLogger().info("获取对象:" + o.toString());
|
||||||
BeanInfo beanInfo = Introspector.getBeanInfo(o.getClass(), Object.class);
|
BeanInfo beanInfo = Introspector.getBeanInfo(o.getClass(), Object.class);
|
||||||
PropertyDescriptor[] propertyDescriptors = beanInfo.getPropertyDescriptors();
|
PropertyDescriptor[] propertyDescriptors = beanInfo.getPropertyDescriptors();
|
||||||
for (PropertyDescriptor propertyDescriptor : propertyDescriptors) {
|
for (PropertyDescriptor propertyDescriptor : propertyDescriptors) {
|
||||||
Class<?> propertyType = propertyDescriptor.getPropertyType();
|
Class<?> propertyType = propertyDescriptor.getPropertyType();
|
||||||
Object value = null;
|
Object value = null;
|
||||||
String fieldName = propertyDescriptor.getName();
|
String fieldName = propertyDescriptor.getName();
|
||||||
|
|
||||||
if (Strings.isNullOrEmpty(fieldName)) {
|
if (Strings.isNullOrEmpty(fieldName)) {
|
||||||
fieldName = propertyDescriptor.getDisplayName();
|
fieldName = propertyDescriptor.getDisplayName();
|
||||||
}
|
}
|
||||||
// Util.getLogger().info("获取类字段:" + fieldName);
|
// Util.getLogger().info("获取类字段:" + fieldName);
|
||||||
// Util.getLogger().info("获取类字段1:" + propertyDescriptor.getDisplayName());
|
// Util.getLogger().info("获取类字段1:" + propertyDescriptor.getDisplayName());
|
||||||
// Util.getLogger().info("获取的数据库数据:" + rs.getString(fieldName));
|
// Util.getLogger().info("获取的数据库数据:" + rs.getString(fieldName));
|
||||||
Field declaredField = o.getClass().getDeclaredField(fieldName);
|
Field declaredField = o.getClass().getDeclaredField(fieldName);
|
||||||
if (enable) {
|
if (enable) {
|
||||||
value = ResultMapper.typeHandler.get(propertyType) == null ? null : ResultMapper.typeHandler.get(propertyType).getValue(rs, Util.toUnderlineCase(fieldName), declaredField);
|
value = ResultMapper.typeHandler.get(propertyType) == null ? null : ResultMapper.typeHandler.get(propertyType).getValue(rs, Util.toUnderlineCase(fieldName), declaredField);
|
||||||
} else {
|
} else {
|
||||||
value = ResultMapper.typeHandler.get(propertyType) == null ? null : ResultMapper.typeHandler.get(propertyType).getValue(rs, fieldName, declaredField);
|
value = ResultMapper.typeHandler.get(propertyType) == null ? null : ResultMapper.typeHandler.get(propertyType).getValue(rs, fieldName, declaredField);
|
||||||
}
|
}
|
||||||
propertyDescriptor.getWriteMethod().invoke(o, value);
|
propertyDescriptor.getWriteMethod().invoke(o, value);
|
||||||
}
|
}
|
||||||
|
|
||||||
} catch (Exception e) {
|
} catch (Exception e) {
|
||||||
e.printStackTrace();
|
e.printStackTrace();
|
||||||
Util.getLogger().error("报错了,写入数据到实体类报错!\n" + Util.getErrString(e));
|
Util.getLogger().error("报错了,写入数据到实体类报错!\n" + Util.getErrString(e));
|
||||||
}
|
}
|
||||||
return o;
|
return o;
|
||||||
}
|
}
|
||||||
|
|
||||||
public Class<?> getRawType(Type type) {
|
public Class<?> getRawType(Type type) {
|
||||||
if (type instanceof Class) {
|
if (type instanceof Class) {
|
||||||
return (Class) type;
|
return (Class) type;
|
||||||
} else if (type instanceof ParameterizedType) {
|
} else if (type instanceof ParameterizedType) {
|
||||||
ParameterizedType parameterizedType = (ParameterizedType) type;
|
ParameterizedType parameterizedType = (ParameterizedType) type;
|
||||||
Type rawType = parameterizedType.getRawType();
|
Type rawType = parameterizedType.getRawType();
|
||||||
return (Class) rawType;
|
return (Class) rawType;
|
||||||
} else if (type instanceof GenericArrayType) {
|
} else if (type instanceof GenericArrayType) {
|
||||||
Type componentType = ((GenericArrayType) type).getGenericComponentType();
|
Type componentType = ((GenericArrayType) type).getGenericComponentType();
|
||||||
return Array.newInstance(getRawType(componentType), 0).getClass();
|
return Array.newInstance(getRawType(componentType), 0).getClass();
|
||||||
} else if (type instanceof TypeVariable) {
|
} else if (type instanceof TypeVariable) {
|
||||||
return Object.class;
|
return Object.class;
|
||||||
} else if (type instanceof WildcardType) {
|
} else if (type instanceof WildcardType) {
|
||||||
return getRawType(((WildcardType) type).getUpperBounds()[0]);
|
return getRawType(((WildcardType) type).getUpperBounds()[0]);
|
||||||
} else {
|
} else {
|
||||||
String className = type == null ? "null" : type.getClass().getName();
|
String className = type == null ? "null" : type.getClass().getName();
|
||||||
throw new IllegalArgumentException("Expected a Class, ParameterizedType, or GenericArrayType, but <" + type + "> is of type " + className);
|
throw new IllegalArgumentException("Expected a Class, ParameterizedType, or GenericArrayType, but <" + type + "> is of type " + className);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -1,305 +1,305 @@
|
||||||
package aiyh.utils.recordset;
|
package aiyh.utils.recordset;
|
||||||
|
|
||||||
import aiyh.utils.annotation.recordset.BatchSqlArgs;
|
import aiyh.utils.annotation.recordset.BatchSqlArgs;
|
||||||
import aiyh.utils.annotation.recordset.ParamMapper;
|
import aiyh.utils.annotation.recordset.ParamMapper;
|
||||||
import aiyh.utils.annotation.recordset.SqlString;
|
import aiyh.utils.annotation.recordset.SqlString;
|
||||||
import aiyh.utils.excention.BindingException;
|
import aiyh.utils.excention.BindingException;
|
||||||
import aiyh.utils.excention.MethodNotFindException;
|
import aiyh.utils.excention.MethodNotFindException;
|
||||||
import aiyh.utils.excention.ParseSqlException;
|
import aiyh.utils.excention.ParseSqlException;
|
||||||
import aiyh.utils.sqlUtil.sqlResult.impl.BatchSqlResultImpl;
|
import aiyh.utils.sqlUtil.sqlResult.impl.BatchSqlResultImpl;
|
||||||
import aiyh.utils.sqlUtil.sqlResult.impl.PrepSqlResultImpl;
|
import aiyh.utils.sqlUtil.sqlResult.impl.PrepSqlResultImpl;
|
||||||
import org.apache.commons.lang3.StringUtils;
|
import org.apache.commons.lang3.StringUtils;
|
||||||
|
|
||||||
import java.lang.reflect.InvocationTargetException;
|
import java.lang.reflect.InvocationTargetException;
|
||||||
import java.lang.reflect.Method;
|
import java.lang.reflect.Method;
|
||||||
import java.lang.reflect.Parameter;
|
import java.lang.reflect.Parameter;
|
||||||
import java.util.*;
|
import java.util.*;
|
||||||
import java.util.regex.Matcher;
|
import java.util.regex.Matcher;
|
||||||
import java.util.regex.Pattern;
|
import java.util.regex.Pattern;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @author EBU7-dev1-ayh
|
* @author EBU7-dev1-ayh
|
||||||
* create 2021/12/19 0019 15:28
|
* create 2021/12/19 0019 15:28
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
|
||||||
public class SqlHandler {
|
public class SqlHandler {
|
||||||
|
|
||||||
List<Object> sqlArgs = new ArrayList<>();
|
List<Object> sqlArgs = new ArrayList<>();
|
||||||
|
|
||||||
List<List> batchSqlArgs = new ArrayList<>();
|
List<List> batchSqlArgs = new ArrayList<>();
|
||||||
|
|
||||||
|
|
||||||
List<Object> batchSqlArgsList = new ArrayList();
|
List<Object> batchSqlArgsList = new ArrayList();
|
||||||
|
|
||||||
|
|
||||||
private Object batchObj = null;
|
private Object batchObj = null;
|
||||||
|
|
||||||
public PrepSqlResultImpl handler(String sql, boolean custom, Method method, Object[] args) {
|
public PrepSqlResultImpl handler(String sql, boolean custom, Method method, Object[] args) {
|
||||||
String findSql = findSql(sql, custom, method, args);
|
String findSql = findSql(sql, custom, method, args);
|
||||||
Map<String, Object> methodArgNameMap = buildMethodArgNameMap(method, args);
|
Map<String, Object> methodArgNameMap = buildMethodArgNameMap(method, args);
|
||||||
// 处理基本类型以及包装类
|
// 处理基本类型以及包装类
|
||||||
String parse;
|
String parse;
|
||||||
if (methodArgNameMap.size() == 0) {
|
if (methodArgNameMap.size() == 0) {
|
||||||
return new PrepSqlResultImpl(findSql, sqlArgs);
|
return new PrepSqlResultImpl(findSql, sqlArgs);
|
||||||
}
|
}
|
||||||
if (methodArgNameMap.size() == 1) {
|
if (methodArgNameMap.size() == 1) {
|
||||||
Optional<Object> first = methodArgNameMap.values().stream().findFirst();
|
Optional<Object> first = methodArgNameMap.values().stream().findFirst();
|
||||||
parse = parse(findSql, first.orElse(null));
|
parse = parse(findSql, first.orElse(null));
|
||||||
} else {
|
} else {
|
||||||
parse = parse(findSql, methodArgNameMap);
|
parse = parse(findSql, methodArgNameMap);
|
||||||
}
|
}
|
||||||
|
|
||||||
return new PrepSqlResultImpl(parse, sqlArgs);
|
return new PrepSqlResultImpl(parse, sqlArgs);
|
||||||
}
|
}
|
||||||
|
|
||||||
private String parseBatch(String findSql, Object o) {
|
private String parseBatch(String findSql, Object o) {
|
||||||
String parse = "";
|
String parse = "";
|
||||||
if (!batchSqlArgsList.isEmpty()) {
|
if (!batchSqlArgsList.isEmpty()) {
|
||||||
for (Object o1 : batchSqlArgsList) {
|
for (Object o1 : batchSqlArgsList) {
|
||||||
Map<String, Object> map = new HashMap<>(8);
|
Map<String, Object> map = new HashMap<>(8);
|
||||||
map.put("item", o1);
|
map.put("item", o1);
|
||||||
map.putAll((Map<String, Object>) o);
|
map.putAll((Map<String, Object>) o);
|
||||||
parse = parse(findSql, map);
|
parse = parse(findSql, map);
|
||||||
List<Object> tempArgs = new ArrayList<>();
|
List<Object> tempArgs = new ArrayList<>();
|
||||||
tempArgs.addAll(sqlArgs);
|
tempArgs.addAll(sqlArgs);
|
||||||
batchSqlArgs.add(tempArgs);
|
batchSqlArgs.add(tempArgs);
|
||||||
sqlArgs.clear();
|
sqlArgs.clear();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
if ("".equals(parse)) {
|
if ("".equals(parse)) {
|
||||||
parse = findSql;
|
parse = findSql;
|
||||||
}
|
}
|
||||||
return parse;
|
return parse;
|
||||||
}
|
}
|
||||||
|
|
||||||
public BatchSqlResultImpl handlerBatch(String sql, boolean custom, Method method, Object[] args) {
|
public BatchSqlResultImpl handlerBatch(String sql, boolean custom, Method method, Object[] args) {
|
||||||
String findSql = findSql(sql, custom, method, args);
|
String findSql = findSql(sql, custom, method, args);
|
||||||
Map<String, Object> methodArgNameMap = buildMethodArgNameMap(method, args);
|
Map<String, Object> methodArgNameMap = buildMethodArgNameMap(method, args);
|
||||||
// 处理基本类型以及包装类
|
// 处理基本类型以及包装类
|
||||||
String parse;
|
String parse;
|
||||||
if (methodArgNameMap.size() == 0) {
|
if (methodArgNameMap.size() == 0) {
|
||||||
Object o = batchSqlArgsList.get(0);
|
Object o = batchSqlArgsList.get(0);
|
||||||
if (o instanceof List) {
|
if (o instanceof List) {
|
||||||
return new BatchSqlResultImpl(findSql, batchSqlArgs);
|
return new BatchSqlResultImpl(findSql, batchSqlArgs);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
parse = parseBatch(findSql, methodArgNameMap);
|
parse = parseBatch(findSql, methodArgNameMap);
|
||||||
return new BatchSqlResultImpl(parse, batchSqlArgs);
|
return new BatchSqlResultImpl(parse, batchSqlArgs);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
private String findSql(String sql, boolean custom, Method method, Object[] args) {
|
private String findSql(String sql, boolean custom, Method method, Object[] args) {
|
||||||
String parsing = sql;
|
String parsing = sql;
|
||||||
if (custom) {
|
if (custom) {
|
||||||
// 自定义
|
// 自定义
|
||||||
Parameter[] parameters = method.getParameters();
|
Parameter[] parameters = method.getParameters();
|
||||||
try {
|
try {
|
||||||
if (parameters.length == 0) {
|
if (parameters.length == 0) {
|
||||||
throw new BindingException("cant not find sql parameter! this parameters is nothing!");
|
throw new BindingException("cant not find sql parameter! this parameters is nothing!");
|
||||||
}
|
}
|
||||||
} catch (NullPointerException e) {
|
} catch (NullPointerException e) {
|
||||||
throw new BindingException("cant not find sql parameter! this parameters is nothing!");
|
throw new BindingException("cant not find sql parameter! this parameters is nothing!");
|
||||||
}
|
}
|
||||||
for (int i = 0; i < parameters.length; i++) {
|
for (int i = 0; i < parameters.length; i++) {
|
||||||
Parameter parameter = parameters[i];
|
Parameter parameter = parameters[i];
|
||||||
Object arg = args[i];
|
Object arg = args[i];
|
||||||
Class<?> type = parameter.getType();
|
Class<?> type = parameter.getType();
|
||||||
SqlString sqlAnnotation = parameter.getAnnotation(SqlString.class);
|
SqlString sqlAnnotation = parameter.getAnnotation(SqlString.class);
|
||||||
if (sqlAnnotation != null && type.equals(String.class)) {
|
if (sqlAnnotation != null && type.equals(String.class)) {
|
||||||
try {
|
try {
|
||||||
parsing = arg.toString();
|
parsing = arg.toString();
|
||||||
} catch (NullPointerException e) {
|
} catch (NullPointerException e) {
|
||||||
throw new BindingException("sql String param is null!");
|
throw new BindingException("sql String param is null!");
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
return parsing;
|
return parsing;
|
||||||
}
|
}
|
||||||
|
|
||||||
private Map<String, Object> buildMethodArgNameMap(Method method, Object[] args) {
|
private Map<String, Object> buildMethodArgNameMap(Method method, Object[] args) {
|
||||||
Parameter[] parameters = method.getParameters();
|
Parameter[] parameters = method.getParameters();
|
||||||
Map<String, Object> params = new HashMap<>();
|
Map<String, Object> params = new HashMap<>();
|
||||||
// 参数处理
|
// 参数处理
|
||||||
try {
|
try {
|
||||||
for (int i = 0; i < parameters.length; i++) {
|
for (int i = 0; i < parameters.length; i++) {
|
||||||
Parameter parameter = parameters[i];
|
Parameter parameter = parameters[i];
|
||||||
Object arg = args[i];
|
Object arg = args[i];
|
||||||
String name = parameter.getName();
|
String name = parameter.getName();
|
||||||
Class<?> type = parameter.getType();
|
Class<?> type = parameter.getType();
|
||||||
SqlString sqlAnnotation = parameter.getAnnotation(SqlString.class);
|
SqlString sqlAnnotation = parameter.getAnnotation(SqlString.class);
|
||||||
ParamMapper paramAnnotation = parameter.getAnnotation(ParamMapper.class);
|
ParamMapper paramAnnotation = parameter.getAnnotation(ParamMapper.class);
|
||||||
if (sqlAnnotation != null && type.equals(String.class)) {
|
if (sqlAnnotation != null && type.equals(String.class)) {
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
if (paramAnnotation != null) {
|
if (paramAnnotation != null) {
|
||||||
params.put(paramAnnotation.value(), arg);
|
params.put(paramAnnotation.value(), arg);
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
BatchSqlArgs batchSqlArgs = parameter.getAnnotation(BatchSqlArgs.class);
|
BatchSqlArgs batchSqlArgs = parameter.getAnnotation(BatchSqlArgs.class);
|
||||||
if (batchSqlArgs != null) {
|
if (batchSqlArgs != null) {
|
||||||
try {
|
try {
|
||||||
this.batchSqlArgsList = (List<Object>) arg;
|
this.batchSqlArgsList = (List<Object>) arg;
|
||||||
} catch (Exception e) {
|
} catch (Exception e) {
|
||||||
throw new BindingException("can not parse batchSqlArgs for " + parameter.getName() + ", param index is " + i);
|
throw new BindingException("can not parse batchSqlArgs for " + parameter.getName() + ", param index is " + i);
|
||||||
}
|
}
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
params.put(name, arg);
|
params.put(name, arg);
|
||||||
}
|
}
|
||||||
} catch (NullPointerException e) {
|
} catch (NullPointerException e) {
|
||||||
throw new BindingException("cant not find sql parameter! this parameters is nothing!");
|
throw new BindingException("cant not find sql parameter! this parameters is nothing!");
|
||||||
}
|
}
|
||||||
return params;
|
return params;
|
||||||
}
|
}
|
||||||
|
|
||||||
private String parse(String sql, Object arg) {
|
private String parse(String sql, Object arg) {
|
||||||
String parseSql = sql;
|
String parseSql = sql;
|
||||||
String pattern = "\\$t\\{\\s*(?<regx>(?<field>\\w+)(\\.?(?<other>\\S+))*)\\s*}";
|
String pattern = "\\$t\\{\\s*(?<regx>(?<field>\\w+)(\\.?(?<other>\\S+))*)\\s*}";
|
||||||
Pattern compile = Pattern.compile(pattern);
|
Pattern compile = Pattern.compile(pattern);
|
||||||
Matcher matcher = compile.matcher(parseSql);
|
Matcher matcher = compile.matcher(parseSql);
|
||||||
while (matcher.find()) {
|
while (matcher.find()) {
|
||||||
String regx = matcher.group("regx");
|
String regx = matcher.group("regx");
|
||||||
String field = matcher.group("field");
|
String field = matcher.group("field");
|
||||||
String other = matcher.group("other");
|
String other = matcher.group("other");
|
||||||
Object value = getValueByRegx(regx, field, other, arg, true);
|
Object value = getValueByRegx(regx, field, other, arg, true);
|
||||||
parseSql = parseSql.replaceFirst(pattern, value.toString());
|
parseSql = parseSql.replaceFirst(pattern, value.toString());
|
||||||
}
|
}
|
||||||
pattern = "\\$\\{\\s*(?<regx>(?<field>\\w+)(\\.?(?<other>\\S+))*)\\s*}";
|
pattern = "\\$\\{\\s*(?<regx>(?<field>\\w+)(\\.?(?<other>\\S+))*)\\s*}";
|
||||||
compile = Pattern.compile(pattern);
|
compile = Pattern.compile(pattern);
|
||||||
matcher = compile.matcher(parseSql);
|
matcher = compile.matcher(parseSql);
|
||||||
while (matcher.find()) {
|
while (matcher.find()) {
|
||||||
String regx = matcher.group("regx");
|
String regx = matcher.group("regx");
|
||||||
String field = matcher.group("field");
|
String field = matcher.group("field");
|
||||||
String other = matcher.group("other");
|
String other = matcher.group("other");
|
||||||
Object value = getValueByRegx(regx, field, other, arg, false);
|
Object value = getValueByRegx(regx, field, other, arg, false);
|
||||||
parseSql = parseSql.replaceFirst(pattern, value.toString());
|
parseSql = parseSql.replaceFirst(pattern, value.toString());
|
||||||
}
|
}
|
||||||
|
|
||||||
// pattern = "#\\{\\s*(?<regx>(?<field>\\w+)(\\.?(?<other>\\S+))*)\\s*}";
|
// pattern = "#\\{\\s*(?<regx>(?<field>\\w+)(\\.?(?<other>\\S+))*)\\s*}";
|
||||||
pattern = "#\\{\\s*(?<regx>(?<field>\\w+)\\.*(?<other>\\w+)*)\\s*}";
|
pattern = "#\\{\\s*(?<regx>(?<field>\\w+)\\.*(?<other>\\w+)*)\\s*}";
|
||||||
compile = Pattern.compile(pattern);
|
compile = Pattern.compile(pattern);
|
||||||
matcher = compile.matcher(parseSql);
|
matcher = compile.matcher(parseSql);
|
||||||
while (matcher.find()) {
|
while (matcher.find()) {
|
||||||
String regx = matcher.group("regx");
|
String regx = matcher.group("regx");
|
||||||
String field = matcher.group("field");
|
String field = matcher.group("field");
|
||||||
String other = matcher.group("other");
|
String other = matcher.group("other");
|
||||||
Object value = getValueByRegx(regx, field, other, arg, true);
|
Object value = getValueByRegx(regx, field, other, arg, true);
|
||||||
parseSql = parseSql.replaceFirst(pattern, "?");
|
parseSql = parseSql.replaceFirst(pattern, "?");
|
||||||
sqlArgs.add(value);
|
sqlArgs.add(value);
|
||||||
}
|
}
|
||||||
return parseSql;
|
return parseSql;
|
||||||
}
|
}
|
||||||
|
|
||||||
private Object getValueByRegx(String regx, String field, String other, Object arg, boolean isEscape) {
|
private Object getValueByRegx(String regx, String field, String other, Object arg, boolean isEscape) {
|
||||||
if (!regx.contains(".")) {
|
if (!regx.contains(".")) {
|
||||||
return valueHandler(arg, field, isEscape);
|
return valueHandler(arg, field, isEscape);
|
||||||
}
|
}
|
||||||
String pattern = "(?<field>\\w+)\\.*(?<other>(\\S+)*)";
|
String pattern = "(?<field>\\w+)\\.*(?<other>(\\S+)*)";
|
||||||
Pattern compile = Pattern.compile(pattern);
|
Pattern compile = Pattern.compile(pattern);
|
||||||
Matcher matcher = compile.matcher(other);
|
Matcher matcher = compile.matcher(other);
|
||||||
Object o = valueHandler(arg, field, isEscape);
|
Object o = valueHandler(arg, field, isEscape);
|
||||||
if (matcher.find()) {
|
if (matcher.find()) {
|
||||||
String innerField = matcher.group("field");
|
String innerField = matcher.group("field");
|
||||||
String innerOther = matcher.group("other");
|
String innerOther = matcher.group("other");
|
||||||
return getValueByRegx(other, innerField, innerOther, o, isEscape);
|
return getValueByRegx(other, innerField, innerOther, o, isEscape);
|
||||||
}
|
}
|
||||||
// return getValueByRegx(other,)
|
// return getValueByRegx(other,)
|
||||||
throw new BindingException("Unable to find value " + other);
|
throw new BindingException("Unable to find value " + other);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
private Object valueHandler(Object arg, String key, boolean isEscape) {
|
private Object valueHandler(Object arg, String key, boolean isEscape) {
|
||||||
if (arg == null) {
|
if (arg == null) {
|
||||||
return null;
|
return null;
|
||||||
// throw new CustomerException(String.format("sql参数{%s} 为null,请检查!",key));
|
// throw new CustomerException(String.format("sql参数{%s} 为null,请检查!",key));
|
||||||
}
|
}
|
||||||
if (arg instanceof Number) {
|
if (arg instanceof Number) {
|
||||||
// 处理数字类型
|
// 处理数字类型
|
||||||
return arg;
|
return arg;
|
||||||
}
|
}
|
||||||
if (arg instanceof Boolean) {
|
if (arg instanceof Boolean) {
|
||||||
// 处理布尔类型
|
// 处理布尔类型
|
||||||
return arg;
|
return arg;
|
||||||
}
|
}
|
||||||
if (arg instanceof Character || arg instanceof String) {
|
if (arg instanceof Character || arg instanceof String) {
|
||||||
// 处理字符类型
|
// 处理字符类型
|
||||||
if (isEscape) {
|
if (isEscape) {
|
||||||
return arg;
|
return arg;
|
||||||
} else {
|
} else {
|
||||||
return "'" + arg + "'";
|
return "'" + arg + "'";
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
if (arg.getClass().isArray()) {
|
if (arg.getClass().isArray()) {
|
||||||
// throw new TypeNonsupportException("A value is expected, but a set is received!");
|
// throw new TypeNonsupportException("A value is expected, but a set is received!");
|
||||||
return StringUtils.join((Object[]) arg, ",");
|
return StringUtils.join((Object[]) arg, ",");
|
||||||
}
|
}
|
||||||
// 判断参数类型
|
// 判断参数类型
|
||||||
if (arg instanceof Collection) {
|
if (arg instanceof Collection) {
|
||||||
// list
|
// list
|
||||||
// throw new TypeNonsupportException("A value is expected, but a set is received!");
|
// throw new TypeNonsupportException("A value is expected, but a set is received!");
|
||||||
return StringUtils.join((Collection<?>) arg, ",");
|
return StringUtils.join((Collection<?>) arg, ",");
|
||||||
}
|
}
|
||||||
if (arg instanceof Map) {
|
if (arg instanceof Map) {
|
||||||
// map
|
// map
|
||||||
if (!((Map<?, ?>) arg).containsKey(key)) {
|
if (!((Map<?, ?>) arg).containsKey(key)) {
|
||||||
throw new ParseSqlException("Failed to find {" + key + "} related field after parsing exception!");
|
throw new ParseSqlException("Failed to find {" + key + "} related field after parsing exception!");
|
||||||
}
|
}
|
||||||
Object o = ((Map<?, ?>) arg).get(key);
|
Object o = ((Map<?, ?>) arg).get(key);
|
||||||
if (null == o) {
|
if (null == o) {
|
||||||
return "";
|
return "";
|
||||||
}
|
}
|
||||||
if (o instanceof Character || o instanceof String) {
|
if (o instanceof Character || o instanceof String) {
|
||||||
// 处理字符类型
|
// 处理字符类型
|
||||||
if (isEscape) {
|
if (isEscape) {
|
||||||
return o;
|
return o;
|
||||||
} else {
|
} else {
|
||||||
return "'" + o + "'";
|
return "'" + o + "'";
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
if (o instanceof Collection) {
|
if (o instanceof Collection) {
|
||||||
return valueHandler(o, key, isEscape);
|
return valueHandler(o, key, isEscape);
|
||||||
}
|
}
|
||||||
if (o.getClass().isArray()) {
|
if (o.getClass().isArray()) {
|
||||||
return valueHandler(o, key, isEscape);
|
return valueHandler(o, key, isEscape);
|
||||||
}
|
}
|
||||||
if (o instanceof Number) {
|
if (o instanceof Number) {
|
||||||
// 处理数字类型
|
// 处理数字类型
|
||||||
return valueHandler(o, key, isEscape);
|
return valueHandler(o, key, isEscape);
|
||||||
}
|
}
|
||||||
if (o instanceof Boolean) {
|
if (o instanceof Boolean) {
|
||||||
// 处理布尔类型
|
// 处理布尔类型
|
||||||
return valueHandler(o, key, isEscape);
|
return valueHandler(o, key, isEscape);
|
||||||
}
|
}
|
||||||
if (o instanceof Character || o instanceof String) {
|
if (o instanceof Character || o instanceof String) {
|
||||||
// 处理字符类型
|
// 处理字符类型
|
||||||
return valueHandler(o, key, isEscape);
|
return valueHandler(o, key, isEscape);
|
||||||
}
|
}
|
||||||
return o;
|
return o;
|
||||||
}
|
}
|
||||||
String methodName = "get" + key.substring(0, 1).toUpperCase() + key.substring(1);
|
String methodName = "get" + key.substring(0, 1).toUpperCase() + key.substring(1);
|
||||||
// 当做javaBean处理
|
// 当做javaBean处理
|
||||||
try {
|
try {
|
||||||
|
|
||||||
Method method = arg.getClass().getMethod(methodName);
|
Method method = arg.getClass().getMethod(methodName);
|
||||||
Object invoke = method.invoke(arg);
|
Object invoke = method.invoke(arg);
|
||||||
if (invoke instanceof Character || invoke instanceof String) {
|
if (invoke instanceof Character || invoke instanceof String) {
|
||||||
// 处理字符类型
|
// 处理字符类型
|
||||||
if (isEscape) {
|
if (isEscape) {
|
||||||
return invoke;
|
return invoke;
|
||||||
} else {
|
} else {
|
||||||
return "'" + invoke + "'";
|
return "'" + invoke + "'";
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
return invoke;
|
return invoke;
|
||||||
} catch (NoSuchMethodException e) {
|
} catch (NoSuchMethodException e) {
|
||||||
// e.printStackTrace();
|
// e.printStackTrace();
|
||||||
throw new MethodNotFindException(methodName + " is not find!");
|
throw new MethodNotFindException(methodName + " is not find!");
|
||||||
} catch (InvocationTargetException | IllegalAccessException e) {
|
} catch (InvocationTargetException | IllegalAccessException e) {
|
||||||
e.printStackTrace();
|
e.printStackTrace();
|
||||||
throw new RuntimeException(e.toString());
|
throw new RuntimeException(e.toString());
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -1,23 +1,23 @@
|
||||||
package aiyh.utils.recordset;
|
package aiyh.utils.recordset;
|
||||||
|
|
||||||
import weaver.conn.RecordSet;
|
import weaver.conn.RecordSet;
|
||||||
|
|
||||||
import java.lang.reflect.Field;
|
import java.lang.reflect.Field;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @author EBU7-dev1-ayh
|
* @author EBU7-dev1-ayh
|
||||||
* create 2021/12/21 0021 13:06
|
* create 2021/12/21 0021 13:06
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
|
||||||
public class StringTypeHandler implements TypeHandler{
|
public class StringTypeHandler implements TypeHandler{
|
||||||
@Override
|
@Override
|
||||||
public Object getValue(RecordSet rs, String fieldName, Field declaredField) {
|
public Object getValue(RecordSet rs, String fieldName, Field declaredField) {
|
||||||
return rs.getString(fieldName);
|
return rs.getString(fieldName);
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public Object getValue(RecordSet rs, int index,Field declaredField) {
|
public Object getValue(RecordSet rs, int index,Field declaredField) {
|
||||||
return rs.getString(index);
|
return rs.getString(index);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -1,15 +1,15 @@
|
||||||
package aiyh.utils.recordset;
|
package aiyh.utils.recordset;
|
||||||
|
|
||||||
import weaver.conn.RecordSet;
|
import weaver.conn.RecordSet;
|
||||||
|
|
||||||
import java.lang.reflect.Field;
|
import java.lang.reflect.Field;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @author @author EBU7-dev1-ay
|
* @author @author EBU7-dev1-ay
|
||||||
* create 2021/12/21 0021 13:05
|
* create 2021/12/21 0021 13:05
|
||||||
*/
|
*/
|
||||||
|
|
||||||
public interface TypeHandler {
|
public interface TypeHandler {
|
||||||
Object getValue(RecordSet rs, String fieldName, Field declaredField);
|
Object getValue(RecordSet rs, String fieldName, Field declaredField);
|
||||||
Object getValue(RecordSet rs,int index,Field declaredField);
|
Object getValue(RecordSet rs,int index,Field declaredField);
|
||||||
}
|
}
|
||||||
|
|
|
@ -1,98 +1,98 @@
|
||||||
package aiyh.utils.zwl.common;
|
package aiyh.utils.zwl.common;
|
||||||
|
|
||||||
|
|
||||||
import weaver.common.StringUtil;
|
import weaver.common.StringUtil;
|
||||||
import weaver.conn.RecordSetTrans;
|
import weaver.conn.RecordSetTrans;
|
||||||
import weaver.general.Util;
|
import weaver.general.Util;
|
||||||
import weaver.hrm.User;
|
import weaver.hrm.User;
|
||||||
import weaver.interfaces.workflow.action.Action;
|
import weaver.interfaces.workflow.action.Action;
|
||||||
import weaver.soa.workflow.request.RequestInfo;
|
import weaver.soa.workflow.request.RequestInfo;
|
||||||
import weaver.workflow.request.RequestManager;
|
import weaver.workflow.request.RequestManager;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* 自定义Action实现类,添加通用参数
|
* 自定义Action实现类,添加通用参数
|
||||||
* @author bleach
|
* @author bleach
|
||||||
* @date 2019-10-09
|
* @date 2019-10-09
|
||||||
* @version 1.0
|
* @version 1.0
|
||||||
*/
|
*/
|
||||||
public abstract class CusBaseAction extends ToolUtil implements Action {
|
public abstract class CusBaseAction extends ToolUtil implements Action {
|
||||||
//当前类名称
|
//当前类名称
|
||||||
private String className = this.getClass().getName();
|
private String className = this.getClass().getName();
|
||||||
|
|
||||||
|
|
||||||
protected RequestInfo requestInfo;//流程请求信息实体类
|
protected RequestInfo requestInfo;//流程请求信息实体类
|
||||||
protected RecordSetTrans rsts = null;//流程操作事务数据集
|
protected RecordSetTrans rsts = null;//流程操作事务数据集
|
||||||
protected String tablename;//当前流程表单名称
|
protected String tablename;//当前流程表单名称
|
||||||
protected String requestId;//流程请求ID
|
protected String requestId;//流程请求ID
|
||||||
protected String workflowId;//流程类型ID
|
protected String workflowId;//流程类型ID
|
||||||
protected User user = null;//当前用户
|
protected User user = null;//当前用户
|
||||||
protected int creater = -1;//流程创建人ID
|
protected int creater = -1;//流程创建人ID
|
||||||
protected RequestManager reqManager = null;
|
protected RequestManager reqManager = null;
|
||||||
protected String[] baseArray = new String[3];
|
protected String[] baseArray = new String[3];
|
||||||
|
|
||||||
protected abstract String handle();//Action 具体操作
|
protected abstract String handle();//Action 具体操作
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* 实现父类方法
|
* 实现父类方法
|
||||||
*
|
*
|
||||||
* @param requestInfo requestInfo对象
|
* @param requestInfo requestInfo对象
|
||||||
* @return string类型的数据
|
* @return string类型的数据
|
||||||
*/
|
*/
|
||||||
@Override
|
@Override
|
||||||
public String execute(RequestInfo requestInfo) {
|
public String execute(RequestInfo requestInfo) {
|
||||||
this.requestInfo = requestInfo;
|
this.requestInfo = requestInfo;
|
||||||
|
|
||||||
this.rsts = requestInfo.getRsTrans();
|
this.rsts = requestInfo.getRsTrans();
|
||||||
if (this.rsts == null) {
|
if (this.rsts == null) {
|
||||||
rsts = new RecordSetTrans();
|
rsts = new RecordSetTrans();
|
||||||
}
|
}
|
||||||
this.initParam();
|
this.initParam();
|
||||||
return handle();
|
return handle();
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* 初始化常用参数
|
* 初始化常用参数
|
||||||
*/
|
*/
|
||||||
private void initParam() {
|
private void initParam() {
|
||||||
this.requestId = StringUtil.vString(requestInfo.getRequestid());
|
this.requestId = StringUtil.vString(requestInfo.getRequestid());
|
||||||
this.workflowId = StringUtil.vString(requestInfo.getWorkflowid());
|
this.workflowId = StringUtil.vString(requestInfo.getWorkflowid());
|
||||||
this.reqManager = requestInfo.getRequestManager();
|
this.reqManager = requestInfo.getRequestManager();
|
||||||
this.user = reqManager.getUser();
|
this.user = reqManager.getUser();
|
||||||
this.creater = reqManager.getCreater();
|
this.creater = reqManager.getCreater();
|
||||||
|
|
||||||
this.tablename = requestInfo.getRequestManager().getBillTableName();
|
this.tablename = requestInfo.getRequestManager().getBillTableName();
|
||||||
|
|
||||||
//通过系统请求管理类获取表单名称失败,再次查询
|
//通过系统请求管理类获取表单名称失败,再次查询
|
||||||
if ("".equals(this.tablename)) {
|
if ("".equals(this.tablename)) {
|
||||||
tablename = getBillTableNameByWorkflowId(this.workflowId);
|
tablename = getBillTableNameByWorkflowId(this.workflowId);
|
||||||
}
|
}
|
||||||
|
|
||||||
//获取流程基础数据
|
//获取流程基础数据
|
||||||
String select_base_sql = "select * from workflow_requestbase where requestid = ?";
|
String select_base_sql = "select * from workflow_requestbase where requestid = ?";
|
||||||
try {
|
try {
|
||||||
if (rsts == null) {
|
if (rsts == null) {
|
||||||
rsts = new RecordSetTrans();
|
rsts = new RecordSetTrans();
|
||||||
}
|
}
|
||||||
|
|
||||||
String request_name = "";
|
String request_name = "";
|
||||||
String request_mark = "";
|
String request_mark = "";
|
||||||
|
|
||||||
if (rsts.executeQuery(select_base_sql, requestId)) {
|
if (rsts.executeQuery(select_base_sql, requestId)) {
|
||||||
while (rsts.next()) {
|
while (rsts.next()) {
|
||||||
request_name = Util.null2String(rsts.getString("requestname"));
|
request_name = Util.null2String(rsts.getString("requestname"));
|
||||||
request_mark = Util.null2String(rsts.getString("requestmark"));
|
request_mark = Util.null2String(rsts.getString("requestmark"));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
baseArray[0] = this.requestId;
|
baseArray[0] = this.requestId;
|
||||||
baseArray[1] = request_name;
|
baseArray[1] = request_name;
|
||||||
baseArray[2] = request_mark;
|
baseArray[2] = request_mark;
|
||||||
|
|
||||||
this.writeNewDebuggerLog(className, "main_requestname:[" + request_name + "],main_requestmark:[" + request_mark + "],workflowid:[" + workflowId + "],requestid:[" + requestId + "],tablename:[" + tablename + "]");
|
this.writeNewDebuggerLog(className, "main_requestname:[" + request_name + "],main_requestmark:[" + request_mark + "],workflowid:[" + workflowId + "],requestid:[" + requestId + "],tablename:[" + tablename + "]");
|
||||||
} catch (Exception e1) {
|
} catch (Exception e1) {
|
||||||
// TODO Auto-generated catch block
|
// TODO Auto-generated catch block
|
||||||
e1.printStackTrace();
|
e1.printStackTrace();
|
||||||
this.writeNewDebuggerLog(className, "get workflow dataset error:[" + e1.getMessage() + "/" + e1.toString() + "]");
|
this.writeNewDebuggerLog(className, "get workflow dataset error:[" + e1.getMessage() + "/" + e1.toString() + "]");
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -1,89 +1,89 @@
|
||||||
package aiyh.utils.zwl.common.logging;
|
package aiyh.utils.zwl.common.logging;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* 写日志(log4j)
|
* 写日志(log4j)
|
||||||
* @date 2020-03-10
|
* @date 2020-03-10
|
||||||
* @version 1.0
|
* @version 1.0
|
||||||
*/
|
*/
|
||||||
public class Log4JLogger implements Logger {
|
public class Log4JLogger implements Logger {
|
||||||
|
|
||||||
private org.apache.log4j.Logger log;
|
private org.apache.log4j.Logger log;
|
||||||
//类名
|
//类名
|
||||||
private String classname;
|
private String classname;
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public String getClassname() {
|
public String getClassname() {
|
||||||
return classname;
|
return classname;
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void setClassname(String classname) {
|
public void setClassname(String classname) {
|
||||||
this.classname = classname;
|
this.classname = classname;
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public boolean isDebugEnabled() {
|
public boolean isDebugEnabled() {
|
||||||
return log.isDebugEnabled();
|
return log.isDebugEnabled();
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public boolean isInfoEnabled() {
|
public boolean isInfoEnabled() {
|
||||||
return log.isInfoEnabled();
|
return log.isInfoEnabled();
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void debug(Object message) {
|
public void debug(Object message) {
|
||||||
String method = Thread.currentThread().getStackTrace()[2].getMethodName();
|
String method = Thread.currentThread().getStackTrace()[2].getMethodName();
|
||||||
log.debug(classname+"."+method+"() - "+message);
|
log.debug(classname+"."+method+"() - "+message);
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void debug(Object message, Throwable exception) {
|
public void debug(Object message, Throwable exception) {
|
||||||
String method = Thread.currentThread().getStackTrace()[2].getMethodName();
|
String method = Thread.currentThread().getStackTrace()[2].getMethodName();
|
||||||
log.debug(classname+"."+method+"() - "+message, exception);
|
log.debug(classname+"."+method+"() - "+message, exception);
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void info(Object message) {
|
public void info(Object message) {
|
||||||
String method = Thread.currentThread().getStackTrace()[2].getMethodName();
|
String method = Thread.currentThread().getStackTrace()[2].getMethodName();
|
||||||
log.info(classname+"."+method+"() - "+message);
|
log.info(classname+"."+method+"() - "+message);
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void info(Object message, Throwable exception) {
|
public void info(Object message, Throwable exception) {
|
||||||
String method = Thread.currentThread().getStackTrace()[2].getMethodName();
|
String method = Thread.currentThread().getStackTrace()[2].getMethodName();
|
||||||
log.info(classname+"."+method+"() - "+message, exception);
|
log.info(classname+"."+method+"() - "+message, exception);
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void warn(Object message) {
|
public void warn(Object message) {
|
||||||
String method = Thread.currentThread().getStackTrace()[2].getMethodName();
|
String method = Thread.currentThread().getStackTrace()[2].getMethodName();
|
||||||
log.warn(classname+"."+method+"() - "+message);
|
log.warn(classname+"."+method+"() - "+message);
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void warn(Object message, Throwable exception) {
|
public void warn(Object message, Throwable exception) {
|
||||||
String method = Thread.currentThread().getStackTrace()[2].getMethodName();
|
String method = Thread.currentThread().getStackTrace()[2].getMethodName();
|
||||||
log.warn(classname+"."+method+"() - "+message, exception);
|
log.warn(classname+"."+method+"() - "+message, exception);
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void error(Object message) {
|
public void error(Object message) {
|
||||||
String method = Thread.currentThread().getStackTrace()[2].getMethodName();
|
String method = Thread.currentThread().getStackTrace()[2].getMethodName();
|
||||||
log.error(classname+"."+method+"() - "+message);
|
log.error(classname+"."+method+"() - "+message);
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void error(Object message, Throwable exception) {
|
public void error(Object message, Throwable exception) {
|
||||||
String method = Thread.currentThread().getStackTrace()[2].getMethodName();
|
String method = Thread.currentThread().getStackTrace()[2].getMethodName();
|
||||||
log.error(classname+"."+method+"() - "+message, exception);
|
log.error(classname+"."+method+"() - "+message, exception);
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void init(String name) {
|
public void init(String name) {
|
||||||
if("".equals(name)) {
|
if("".equals(name)) {
|
||||||
name = "cuslog";
|
name = "cuslog";
|
||||||
}
|
}
|
||||||
log = org.apache.log4j.Logger.getLogger(name);
|
log = org.apache.log4j.Logger.getLogger(name);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -1,78 +1,78 @@
|
||||||
package aiyh.utils.zwl.common.logging;
|
package aiyh.utils.zwl.common.logging;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* 日志接口(写)
|
* 日志接口(写)
|
||||||
*
|
*
|
||||||
* @author zwl
|
* @author zwl
|
||||||
* @date 2020-03-10
|
* @date 2020-03-10
|
||||||
*/
|
*/
|
||||||
public interface Logger {
|
public interface Logger {
|
||||||
|
|
||||||
public boolean isDebugEnabled();
|
public boolean isDebugEnabled();
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* 打印debug日志
|
* 打印debug日志
|
||||||
* @param message 消息
|
* @param message 消息
|
||||||
*/
|
*/
|
||||||
public void debug(Object message);
|
public void debug(Object message);
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* 打印debug日志
|
* 打印debug日志
|
||||||
* @param message 消息
|
* @param message 消息
|
||||||
* @param exception 异常
|
* @param exception 异常
|
||||||
*/
|
*/
|
||||||
public void debug(Object message, Throwable exception);
|
public void debug(Object message, Throwable exception);
|
||||||
|
|
||||||
public boolean isInfoEnabled();
|
public boolean isInfoEnabled();
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* 打印info日志
|
* 打印info日志
|
||||||
* @param message 消息
|
* @param message 消息
|
||||||
*/
|
*/
|
||||||
public void info(Object message);
|
public void info(Object message);
|
||||||
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* 打印info日志
|
* 打印info日志
|
||||||
* @param message 消息
|
* @param message 消息
|
||||||
* @param exception 异常
|
* @param exception 异常
|
||||||
*/
|
*/
|
||||||
public void info(Object message, Throwable exception);
|
public void info(Object message, Throwable exception);
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* 打印warn日志
|
* 打印warn日志
|
||||||
* @param message 消息
|
* @param message 消息
|
||||||
*/
|
*/
|
||||||
public void warn(Object message);
|
public void warn(Object message);
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* 打印warn日志
|
* 打印warn日志
|
||||||
* @param message 消息
|
* @param message 消息
|
||||||
* @param exception 异常
|
* @param exception 异常
|
||||||
*/
|
*/
|
||||||
public void warn(Object message, Throwable exception);
|
public void warn(Object message, Throwable exception);
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* 打印error日志
|
* 打印error日志
|
||||||
* @param message 错误消息
|
* @param message 错误消息
|
||||||
*/
|
*/
|
||||||
public void error(Object message);
|
public void error(Object message);
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* 打印error日志
|
* 打印error日志
|
||||||
* @param message 消息
|
* @param message 消息
|
||||||
* @param exception 异常
|
* @param exception 异常
|
||||||
*/
|
*/
|
||||||
public void error(Object message, Throwable exception);
|
public void error(Object message, Throwable exception);
|
||||||
|
|
||||||
public String getClassname();
|
public String getClassname();
|
||||||
|
|
||||||
public void setClassname(String classname);
|
public void setClassname(String classname);
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* 初始化
|
* 初始化
|
||||||
*
|
*
|
||||||
* @param name logger名称
|
* @param name logger名称
|
||||||
*/
|
*/
|
||||||
public void init(String name);
|
public void init(String name);
|
||||||
}
|
}
|
||||||
|
|
|
@ -1,49 +1,49 @@
|
||||||
package aiyh.utils.zwl.common.logging;
|
package aiyh.utils.zwl.common.logging;
|
||||||
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* 日志工厂类
|
* 日志工厂类
|
||||||
*
|
*
|
||||||
* @author zwl
|
* @author zwl
|
||||||
* @date 2020-03-10
|
* @date 2020-03-10
|
||||||
* @version 1.0
|
* @version 1.0
|
||||||
*/
|
*/
|
||||||
public class LoggerFactory {
|
public class LoggerFactory {
|
||||||
private static final String loggerName = "cus";
|
private static final String loggerName = "cus";
|
||||||
|
|
||||||
public static Logger getLogger(String LogName, String clazz) {
|
public static Logger getLogger(String LogName, String clazz) {
|
||||||
if("".equals(LogName)) {
|
if("".equals(LogName)) {
|
||||||
LogName = loggerName;
|
LogName = loggerName;
|
||||||
}
|
}
|
||||||
Logger logger = new Log4JLogger();
|
Logger logger = new Log4JLogger();
|
||||||
logger.setClassname(clazz);
|
logger.setClassname(clazz);
|
||||||
logger.init(LogName);
|
logger.init(LogName);
|
||||||
return logger;
|
return logger;
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* 获取指定类的logger对象
|
* 获取指定类的logger对象
|
||||||
* @param clazz 类
|
* @param clazz 类
|
||||||
* @return 日志对象
|
* @return 日志对象
|
||||||
*/
|
*/
|
||||||
public static Logger getLogger(Class<?> clazz) {
|
public static Logger getLogger(Class<?> clazz) {
|
||||||
return getLogger(loggerName,clazz.getCanonicalName());
|
return getLogger(loggerName,clazz.getCanonicalName());
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* 获取指定类的logger对象
|
* 获取指定类的logger对象
|
||||||
* @param className 类名
|
* @param className 类名
|
||||||
* @return 日志对象
|
* @return 日志对象
|
||||||
*/
|
*/
|
||||||
public static Logger getLogger(String className) {
|
public static Logger getLogger(String className) {
|
||||||
return getLogger(loggerName,className);
|
return getLogger(loggerName,className);
|
||||||
}
|
}
|
||||||
/**
|
/**
|
||||||
* 获取未指定指定类的logger对象
|
* 获取未指定指定类的logger对象
|
||||||
* @return 日志对象
|
* @return 日志对象
|
||||||
*/
|
*/
|
||||||
public static Logger getLogger() {
|
public static Logger getLogger() {
|
||||||
String className = Thread.currentThread().getStackTrace()[2].getClassName();
|
String className = Thread.currentThread().getStackTrace()[2].getClassName();
|
||||||
return getLogger(loggerName, className);
|
return getLogger(loggerName, className);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -0,0 +1,52 @@
|
||||||
|
package com.api.xuanran.wang.saic_travel.model_create_workflow.controller;
|
||||||
|
|
||||||
|
import aiyh.utils.ApiResult;
|
||||||
|
import aiyh.utils.Util;
|
||||||
|
import com.alibaba.fastjson.JSONObject;
|
||||||
|
import org.apache.log4j.Logger;
|
||||||
|
import weaver.hrm.HrmUserVarify;
|
||||||
|
import weaver.hrm.User;
|
||||||
|
import weaver.xuanran.wang.common.util.CommonUtil;
|
||||||
|
|
||||||
|
import javax.servlet.http.HttpServletRequest;
|
||||||
|
import javax.servlet.http.HttpServletResponse;
|
||||||
|
import javax.ws.rs.*;
|
||||||
|
import javax.ws.rs.core.Context;
|
||||||
|
import javax.ws.rs.core.MediaType;
|
||||||
|
import java.util.ArrayList;
|
||||||
|
import java.util.Arrays;
|
||||||
|
import java.util.List;
|
||||||
|
import java.util.stream.Collectors;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* <h1>根据建模选择的数据id创建流程</h1>
|
||||||
|
* @Author xuanran.wang
|
||||||
|
* @Date 2022/12/5 11:53
|
||||||
|
*/
|
||||||
|
@Path("/wxr/saicTravel/")
|
||||||
|
public class CusCreateWorkFlowController {
|
||||||
|
|
||||||
|
private final Logger logger = Util.getLogger();
|
||||||
|
|
||||||
|
@Path("cusCreateWorkFlow")
|
||||||
|
@POST
|
||||||
|
@Produces(MediaType.TEXT_PLAIN)
|
||||||
|
public String getOrgChartTree(@Context HttpServletRequest request, @Context HttpServletResponse response) {
|
||||||
|
User logInUser = HrmUserVarify.getUser(request, response);
|
||||||
|
if(logInUser == null){
|
||||||
|
return ApiResult.error(403,"请先登录!");
|
||||||
|
}
|
||||||
|
String choiceData = request.getParameter("choiceData");
|
||||||
|
int modelId = Util.getIntValue(request.getParameter("modelId"), -1);
|
||||||
|
List<String> dataList = Arrays.stream(choiceData.split(",")).collect(Collectors.toList());
|
||||||
|
List<String> requestIds = CommonUtil.doCreateWorkFlow(modelId, dataList);
|
||||||
|
List<String> errorData = new ArrayList<>();
|
||||||
|
for (int i = 0; i < requestIds.size(); i++) {
|
||||||
|
if (Util.getIntValue(requestIds.get(i), -1) < 0) {
|
||||||
|
errorData.add(dataList.get(i));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
logger.error(Util.logStr("执行创建流程失败集合: {}",JSONObject.toJSONString(errorData)));
|
||||||
|
return ApiResult.success(errorData);
|
||||||
|
}
|
||||||
|
}
|
|
@ -44,7 +44,7 @@ public interface OrgChartMapper {
|
||||||
" inner join hrmjobtitles job on hrm.JOBTITLE = job.id " +
|
" inner join hrmjobtitles job on hrm.JOBTITLE = job.id " +
|
||||||
" inner join cus_fielddata cus on cus.ID = hrm.ID " +
|
" inner join cus_fielddata cus on cus.ID = hrm.ID " +
|
||||||
" and cus.SCOPE = 'HrmCustomFieldByInfoType' " +
|
" and cus.SCOPE = 'HrmCustomFieldByInfoType' " +
|
||||||
" and cus.SCOPEID = -1 " +
|
" and cus.SCOPEID = 1 " +
|
||||||
" inner join hrmdepartment dept on dept.id = hrm.DEPARTMENTID " +
|
" inner join hrmdepartment dept on dept.id = hrm.DEPARTMENTID " +
|
||||||
"where hrm.status in (0, 1)")
|
"where hrm.status in (0, 1)")
|
||||||
List<HrmResource> selectAll(@ParamMapper("typeOfEmploymentFiled") String typeOfEmploymentField,
|
List<HrmResource> selectAll(@ParamMapper("typeOfEmploymentFiled") String typeOfEmploymentField,
|
||||||
|
|
|
@ -1,6 +1,7 @@
|
||||||
package com.api.youhong.ai.pcn.organization.orgchart.service;
|
package com.api.youhong.ai.pcn.organization.orgchart.service;
|
||||||
|
|
||||||
import aiyh.utils.Util;
|
import aiyh.utils.Util;
|
||||||
|
import aiyh.utils.excention.CustomerException;
|
||||||
import cn.hutool.core.lang.Assert;
|
import cn.hutool.core.lang.Assert;
|
||||||
import com.api.youhong.ai.pcn.organization.orgchart.dto.HrmResourceDto;
|
import com.api.youhong.ai.pcn.organization.orgchart.dto.HrmResourceDto;
|
||||||
import com.api.youhong.ai.pcn.organization.orgchart.mapper.OrgChartMapper;
|
import com.api.youhong.ai.pcn.organization.orgchart.mapper.OrgChartMapper;
|
||||||
|
@ -45,28 +46,17 @@ public class OrgChartService {
|
||||||
String lastNameEnField = Util.getCusConfigValue("lastNameEnField");
|
String lastNameEnField = Util.getCusConfigValue("lastNameEnField");
|
||||||
Assert.notBlank(lastNameEnField, "config [lastNameEnField] is null or blank!");
|
Assert.notBlank(lastNameEnField, "config [lastNameEnField] is null or blank!");
|
||||||
List<HrmResource> hrmResourceList = mapper.selectAll(typeOfEmploymentField, lastNameEnField);
|
List<HrmResource> hrmResourceList = mapper.selectAll(typeOfEmploymentField, lastNameEnField);
|
||||||
|
if (Objects.isNull(hrmResourceList) || hrmResourceList.isEmpty()) {
|
||||||
|
throw new CustomerException("查询不到相关人员!");
|
||||||
|
}
|
||||||
//List<HrmResourceDto> hrmResourceDtoList = new ArrayList();
|
//List<HrmResourceDto> hrmResourceDtoList = new ArrayList();
|
||||||
AtomicReference<HrmResourceDto> currentUser = new AtomicReference<>();
|
AtomicReference<HrmResourceDto> currentUser = new AtomicReference<>();
|
||||||
/* ******************* 将pojo转换为Dto对象,对节点属性默认值赋值,找出当前用户并设置显示 ******************* */
|
/* ******************* 将pojo转换为Dto对象,对节点属性默认值赋值,找出当前用户并设置显示 ******************* */
|
||||||
List<HrmResourceDto> hrmResourceDtoList = hrmResourceList.stream()
|
List<HrmResourceDto> hrmResourceDtoList = hrmResourceList.stream().map(struct::hrmResourceToDto).peek(item -> Builder.startSet(item).with(HrmResourceDto::setShow, 0).with(HrmResourceDto::setShowBrother, 0).with(HrmResourceDto::setShowChildren, 0).endSet()).collect(Collectors.toList());
|
||||||
.map(struct::hrmResourceToDto)
|
hrmResourceDtoList.stream().filter(item -> item.getId() == userId).forEach(item -> {
|
||||||
.peek(item -> Builder.startSet(item)
|
Builder.startSet(item).with(HrmResourceDto::setShow, 1).with(HrmResourceDto::setShowBrother, 1).with(HrmResourceDto::setShowChildren, 1).with(HrmResourceDto::setCurrent, true).endSet();
|
||||||
.with(HrmResourceDto::setShow, 0)
|
currentUser.set(item);
|
||||||
.with(HrmResourceDto::setShowBrother, 0)
|
});
|
||||||
.with(HrmResourceDto::setShowChildren, 0)
|
|
||||||
.endSet())
|
|
||||||
.collect(Collectors.toList());
|
|
||||||
hrmResourceDtoList.stream()
|
|
||||||
.filter(item -> item.getId() == userId)
|
|
||||||
.forEach(item -> {
|
|
||||||
Builder.startSet(item)
|
|
||||||
.with(HrmResourceDto::setShow, 1)
|
|
||||||
.with(HrmResourceDto::setShowBrother, 1)
|
|
||||||
.with(HrmResourceDto::setShowChildren, 1)
|
|
||||||
.with(HrmResourceDto::setCurrent, true)
|
|
||||||
.endSet();
|
|
||||||
currentUser.set(item);
|
|
||||||
});
|
|
||||||
Assert.notNull(currentUser, "not find current login user info!");
|
Assert.notNull(currentUser, "not find current login user info!");
|
||||||
/* ******************* 查找当前登陆人员的所有上级 ******************* */
|
/* ******************* 查找当前登陆人员的所有上级 ******************* */
|
||||||
String currentUserManagerStr = currentUser.get().getManagerStr();
|
String currentUserManagerStr = currentUser.get().getManagerStr();
|
||||||
|
@ -74,16 +64,9 @@ public class OrgChartService {
|
||||||
currentUserManagerStr = "";
|
currentUserManagerStr = "";
|
||||||
}
|
}
|
||||||
currentUserManagerStr = Util.removeSeparator(currentUserManagerStr, ",");
|
currentUserManagerStr = Util.removeSeparator(currentUserManagerStr, ",");
|
||||||
List<Integer> currentUserManagerList = Arrays.stream(currentUserManagerStr.split(","))
|
List<Integer> currentUserManagerList = Arrays.stream(currentUserManagerStr.split(",")).map(Integer::parseInt).collect(Collectors.toList());
|
||||||
.map(Integer::parseInt)
|
|
||||||
.collect(Collectors.toList());
|
|
||||||
/* ******************* 对当前用户的所有直接上级设置标识 ******************* */
|
/* ******************* 对当前用户的所有直接上级设置标识 ******************* */
|
||||||
hrmResourceDtoList.stream()
|
hrmResourceDtoList.stream().filter(item -> currentUserManagerList.contains(item.getId())).forEach(item -> Builder.startSet(item).with(HrmResourceDto::setShowChildren, 1).with(HrmResourceDto::setCurrentParent, true).endSet());
|
||||||
.filter(item -> currentUserManagerList.contains(item.getId()))
|
|
||||||
.forEach(item -> Builder.startSet(item)
|
|
||||||
.with(HrmResourceDto::setShowChildren, 1)
|
|
||||||
.with(HrmResourceDto::setCurrentParent, true)
|
|
||||||
.endSet());
|
|
||||||
|
|
||||||
/* ******************* 查询当前用户的是否全部展示或显示小红点的配置信息 ******************* */
|
/* ******************* 查询当前用户的是否全部展示或显示小红点的配置信息 ******************* */
|
||||||
ShowPointOrAll showPointOrAll = mapper.selectShowPointOrAll(userId);
|
ShowPointOrAll showPointOrAll = mapper.selectShowPointOrAll(userId);
|
||||||
|
@ -92,34 +75,21 @@ public class OrgChartService {
|
||||||
/* ******************* 转换dto为Vo并且设置根节点标识 ******************* */
|
/* ******************* 转换dto为Vo并且设置根节点标识 ******************* */
|
||||||
orgChartNodeVoList = hrmResourceDtoList.stream()
|
orgChartNodeVoList = hrmResourceDtoList.stream()
|
||||||
.map(struct::hrmResourceDtoToVo)
|
.map(struct::hrmResourceDtoToVo)
|
||||||
|
.peek(item -> item.setType(-1))
|
||||||
.collect(Collectors.toList());
|
.collect(Collectors.toList());
|
||||||
} else {
|
} else {
|
||||||
/* ******************* 转换dto为Vo并且设置根节点标识 ******************* */
|
/* ******************* 转换dto为Vo并且设置根节点标识 ******************* */
|
||||||
orgChartNodeVoList = hrmResourceDtoList.stream()
|
orgChartNodeVoList = hrmResourceDtoList.stream().map(struct::hrmResourceDtoToVo).peek(item -> {
|
||||||
.map(struct::hrmResourceDtoToVo)
|
if (showPointOrAll.isShowAll()) {
|
||||||
.peek(item -> {
|
Builder.startSet(item).with(OrgChartNodeVo::setShow, 1).with(OrgChartNodeVo::setShowBrother, 1).with(OrgChartNodeVo::setShowChildren, 1).endSet();
|
||||||
if (showPointOrAll.isShowAll()) {
|
}
|
||||||
Builder.startSet(item)
|
if (!showPointOrAll.isShowType()) {
|
||||||
.with(OrgChartNodeVo::setShow, 1)
|
item.setType(-1);
|
||||||
.with(OrgChartNodeVo::setShowBrother, 1)
|
}
|
||||||
.with(OrgChartNodeVo::setShowChildren, 1)
|
}).collect(Collectors.toList());
|
||||||
.endSet();
|
|
||||||
}
|
|
||||||
if (!showPointOrAll.isShowType()) {
|
|
||||||
item.setType(-1);
|
|
||||||
}
|
|
||||||
})
|
|
||||||
.collect(Collectors.toList());
|
|
||||||
|
|
||||||
}
|
}
|
||||||
return Util.listToTree(orgChartNodeVoList, OrgChartNodeVo::getId,
|
return Util.listToTree(orgChartNodeVoList, OrgChartNodeVo::getId, OrgChartNodeVo::getManagerId, OrgChartNodeVo::getChildren, OrgChartNodeVo::setChildren, parentId -> parentId == null || parentId <= 0).stream().peek(item -> item.setIsRoot(true)).peek(item -> recursionChildrenNums(item, 0)).collect(Collectors.toList());
|
||||||
OrgChartNodeVo::getManagerId, OrgChartNodeVo::getChildren,
|
|
||||||
OrgChartNodeVo::setChildren,
|
|
||||||
parentId -> parentId == null || parentId <= 0)
|
|
||||||
.stream()
|
|
||||||
.peek(item -> item.setIsRoot(true))
|
|
||||||
.peek(item -> recursionChildrenNums(item, 0))
|
|
||||||
.collect(Collectors.toList());
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
|
@ -1,163 +1,163 @@
|
||||||
package weaver.xiao.commons.config.dao;
|
package weaver.xiao.commons.config.dao;
|
||||||
|
|
||||||
import weaver.conn.RecordSet;
|
import weaver.conn.RecordSet;
|
||||||
import weaver.general.Util;
|
import weaver.general.Util;
|
||||||
import weaver.xiao.commons.config.entity.DocImageFile;
|
import weaver.xiao.commons.config.entity.DocImageFile;
|
||||||
import weaver.xiao.commons.config.entity.FieldMessage;
|
import weaver.xiao.commons.config.entity.FieldMessage;
|
||||||
import weaver.xiao.commons.config.entity.MappingDetail;
|
import weaver.xiao.commons.config.entity.MappingDetail;
|
||||||
import weaver.xiao.commons.config.entity.RequestMappingConfig;
|
import weaver.xiao.commons.config.entity.RequestMappingConfig;
|
||||||
import weaver.xiao.commons.config.enumtype.DataSourceEnum;
|
import weaver.xiao.commons.config.enumtype.DataSourceEnum;
|
||||||
import weaver.xiao.commons.exception.ValueDealException;
|
import weaver.xiao.commons.exception.ValueDealException;
|
||||||
import weaver.xiao.commons.utils.SqlUtil;
|
import weaver.xiao.commons.utils.SqlUtil;
|
||||||
import weaver.zwl.common.ToolUtil;
|
import weaver.zwl.common.ToolUtil;
|
||||||
|
|
||||||
import java.util.ArrayList;
|
import java.util.ArrayList;
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
import java.util.Objects;
|
import java.util.Objects;
|
||||||
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @author XiaoBokang
|
* @author XiaoBokang
|
||||||
* @create 2021/12/29 9:46
|
* @create 2021/12/29 9:46
|
||||||
*/
|
*/
|
||||||
|
|
||||||
public class ConfigMappingCMD {
|
public class ConfigMappingCMD {
|
||||||
|
|
||||||
private final ToolUtil toolUtil = new ToolUtil();
|
private final ToolUtil toolUtil = new ToolUtil();
|
||||||
private final String configTableName = "uf_request_config";
|
private final String configTableName = "uf_request_config";
|
||||||
private final SqlUtil sqlUtil = new SqlUtil();
|
private final SqlUtil sqlUtil = new SqlUtil();
|
||||||
|
|
||||||
public RequestMappingConfig selectByUniqueCode(String uniqueCode) {
|
public RequestMappingConfig selectByUniqueCode(String uniqueCode) {
|
||||||
toolUtil.writeDebuggerLog("=======================查询配置列表=======================");
|
toolUtil.writeDebuggerLog("=======================查询配置列表=======================");
|
||||||
RequestMappingConfig requestMappingConfig = new RequestMappingConfig();
|
RequestMappingConfig requestMappingConfig = new RequestMappingConfig();
|
||||||
RecordSet recordSet = new RecordSet();
|
RecordSet recordSet = new RecordSet();
|
||||||
String querySql = "select id,workflow,requestUrl,dataSource,uniqueCode, relationWorkFlow,cusWhereSql from " + configTableName + " where uniqueCode = ?";
|
String querySql = "select id,workflow,requestUrl,dataSource,uniqueCode, relationWorkFlow,cusWhereSql from " + configTableName + " where uniqueCode = ?";
|
||||||
toolUtil.writeDebuggerLog("执行查询的sql query mainRequestMappingConfig list sql new>>>>" + querySql + " uniqueCode >>" + uniqueCode);
|
toolUtil.writeDebuggerLog("执行查询的sql query mainRequestMappingConfig list sql new>>>>" + querySql + " uniqueCode >>" + uniqueCode);
|
||||||
recordSet.executeQuery(querySql, uniqueCode);
|
recordSet.executeQuery(querySql, uniqueCode);
|
||||||
if (recordSet.next()) {
|
if (recordSet.next()) {
|
||||||
int mainId = Util.getIntValue(recordSet.getString("id"));
|
int mainId = Util.getIntValue(recordSet.getString("id"));
|
||||||
requestMappingConfig = sqlUtil.recordSetToEntityByEntity(recordSet, RequestMappingConfig.class);
|
requestMappingConfig = sqlUtil.recordSetToEntityByEntity(recordSet, RequestMappingConfig.class);
|
||||||
this.setDetailMapping(mainId, requestMappingConfig);
|
this.setDetailMapping(mainId, requestMappingConfig);
|
||||||
}
|
}
|
||||||
return requestMappingConfig;
|
return requestMappingConfig;
|
||||||
}
|
}
|
||||||
|
|
||||||
private void setDetailMapping(int mainId, RequestMappingConfig requestMappingConfig) {
|
private void setDetailMapping(int mainId, RequestMappingConfig requestMappingConfig) {
|
||||||
// 查询明细1的信息
|
// 查询明细1的信息
|
||||||
RecordSet detail1RecordSet = new RecordSet();
|
RecordSet detail1RecordSet = new RecordSet();
|
||||||
String dataSource = requestMappingConfig.getDataSource();
|
String dataSource = requestMappingConfig.getDataSource();
|
||||||
if (Objects.isNull(dataSource) || "".equals(dataSource)) {
|
if (Objects.isNull(dataSource) || "".equals(dataSource)) {
|
||||||
dataSource = "0";
|
dataSource = "0";
|
||||||
}
|
}
|
||||||
DataSourceEnum anEnum = DataSourceEnum.getEnum(dataSource);
|
DataSourceEnum anEnum = DataSourceEnum.getEnum(dataSource);
|
||||||
String queryDetail1Sql = "";
|
String queryDetail1Sql = "";
|
||||||
switch (anEnum) {
|
switch (anEnum) {
|
||||||
case CUS_TABLE:
|
case CUS_TABLE:
|
||||||
queryDetail1Sql = "select paramName,paramType,getValueType,dataSource,belongTo,workflowField,modelField,fieldName,valueContext," +
|
queryDetail1Sql = "select paramName,paramType,getValueType,dataSource,belongTo,workflowField,modelField,fieldName,valueContext," +
|
||||||
" from " + configTableName + "_dt1 config ";
|
" from " + configTableName + "_dt1 config ";
|
||||||
break;
|
break;
|
||||||
case WORKFLOW:
|
case WORKFLOW:
|
||||||
queryDetail1Sql = "select paramName,paramType,getValueType,dataSource,belongTo,workflowField,modelField,valueContext,relationWorkFlowField, " +
|
queryDetail1Sql = "select paramName,paramType,getValueType,dataSource,belongTo,workflowField,modelField,valueContext,relationWorkFlowField, " +
|
||||||
" fv.id fieldId,fv.fieldname,fv.tablename,fv.indexdesc " +
|
" fv.id fieldId,fv.fieldname,fv.tablename,fv.indexdesc " +
|
||||||
" from " + configTableName + "_dt1 config " +
|
" from " + configTableName + "_dt1 config " +
|
||||||
" left join workflow_field_table_view fv " +
|
" left join workflow_field_table_view fv " +
|
||||||
" on config.workflowField = fv.id or config.relationWorkFlowField = fv.id" +
|
" on config.workflowField = fv.id or config.relationWorkFlowField = fv.id" +
|
||||||
" where mainid = ? ";
|
" where mainid = ? ";
|
||||||
break;
|
break;
|
||||||
case MODEL:
|
case MODEL:
|
||||||
queryDetail1Sql = "select paramName,paramType,getValueType,dataSource,belongTo,workflowField,modelField,fieldName,valueContext, " +
|
queryDetail1Sql = "select paramName,paramType,getValueType,dataSource,belongTo,workflowField,modelField,fieldName,valueContext, " +
|
||||||
" fv.id fieldId,fv.fieldname,fv.tablename,fv.indexdesc " +
|
" fv.id fieldId,fv.fieldname,fv.tablename,fv.indexdesc " +
|
||||||
" from " + configTableName + "_dt1 config " +
|
" from " + configTableName + "_dt1 config " +
|
||||||
" left join workflow_field_table_view fv on config.modelField = fv.id " +
|
" left join workflow_field_table_view fv on config.modelField = fv.id " +
|
||||||
" where mainid = ? ";
|
" where mainid = ? ";
|
||||||
break;
|
break;
|
||||||
default:
|
default:
|
||||||
throw new ValueDealException("不支持的数据来源");
|
throw new ValueDealException("不支持的数据来源");
|
||||||
}
|
}
|
||||||
toolUtil.writeDebuggerLog("执行查询的明细1sql query detail1Sql >>>>" + queryDetail1Sql + " mainId:" + mainId);
|
toolUtil.writeDebuggerLog("执行查询的明细1sql query detail1Sql >>>>" + queryDetail1Sql + " mainId:" + mainId);
|
||||||
detail1RecordSet.executeQuery(queryDetail1Sql, mainId);
|
detail1RecordSet.executeQuery(queryDetail1Sql, mainId);
|
||||||
List<MappingDetail> mappingDetails = new ArrayList<>();
|
List<MappingDetail> mappingDetails = new ArrayList<>();
|
||||||
while (detail1RecordSet.next()) {
|
while (detail1RecordSet.next()) {
|
||||||
MappingDetail mappingDetail = sqlUtil.recordSetToEntityByEntity(detail1RecordSet, MappingDetail.class);
|
MappingDetail mappingDetail = sqlUtil.recordSetToEntityByEntity(detail1RecordSet, MappingDetail.class);
|
||||||
String getValueType = mappingDetail.getGetValueType();
|
String getValueType = mappingDetail.getGetValueType();
|
||||||
// 设置流程字段相关信息
|
// 设置流程字段相关信息
|
||||||
// if("0".equals(getValueType) || "4".equals(getValueType)){
|
// if("0".equals(getValueType) || "4".equals(getValueType)){
|
||||||
FieldMessage fieldMessage = sqlUtil.recordSetToEntityByEntity(detail1RecordSet, FieldMessage.class);
|
FieldMessage fieldMessage = sqlUtil.recordSetToEntityByEntity(detail1RecordSet, FieldMessage.class);
|
||||||
mappingDetail.setFieldMassage(fieldMessage);
|
mappingDetail.setFieldMassage(fieldMessage);
|
||||||
// }
|
// }
|
||||||
mappingDetails.add(mappingDetail);
|
mappingDetails.add(mappingDetail);
|
||||||
}
|
}
|
||||||
// 查询明细2的信息
|
// 查询明细2的信息
|
||||||
RecordSet detail2RecordSet = new RecordSet();
|
RecordSet detail2RecordSet = new RecordSet();
|
||||||
String queryDetail2Sql = "select paramName,belongTo,childType,dataSource,detailId,cusWhereSql from uf_request_config_dt2 where mainid = ?";
|
String queryDetail2Sql = "select paramName,belongTo,childType,dataSource,detailId,cusWhereSql from uf_request_config_dt2 where mainid = ?";
|
||||||
toolUtil.writeDebuggerLog("执行查询的明细sql query detail2Sql >>>>" + queryDetail2Sql + " mainId:" + mainId);
|
toolUtil.writeDebuggerLog("执行查询的明细sql query detail2Sql >>>>" + queryDetail2Sql + " mainId:" + mainId);
|
||||||
detail2RecordSet.executeQuery(queryDetail2Sql, mainId);
|
detail2RecordSet.executeQuery(queryDetail2Sql, mainId);
|
||||||
while (detail2RecordSet.next()) {
|
while (detail2RecordSet.next()) {
|
||||||
MappingDetail mappingDetail = sqlUtil.recordSetToEntityByEntity(detail2RecordSet, MappingDetail.class);
|
MappingDetail mappingDetail = sqlUtil.recordSetToEntityByEntity(detail2RecordSet, MappingDetail.class);
|
||||||
mappingDetail.setParamType("6");// 设置参数类型为List
|
mappingDetail.setParamType("6");// 设置参数类型为List
|
||||||
mappingDetails.add(mappingDetail);
|
mappingDetails.add(mappingDetail);
|
||||||
}
|
}
|
||||||
// 查询明细3的信息
|
// 查询明细3的信息
|
||||||
RecordSet detail3RecordSet = new RecordSet();
|
RecordSet detail3RecordSet = new RecordSet();
|
||||||
String queryDetail3Sql = "select paramName,belongTo from uf_request_config_dt3 where mainid = ?";
|
String queryDetail3Sql = "select paramName,belongTo from uf_request_config_dt3 where mainid = ?";
|
||||||
toolUtil.writeDebuggerLog("执行查询的明细sql query detail3Sql >>>>" + queryDetail3Sql + " mainId:" + mainId);
|
toolUtil.writeDebuggerLog("执行查询的明细sql query detail3Sql >>>>" + queryDetail3Sql + " mainId:" + mainId);
|
||||||
detail3RecordSet.executeQuery(queryDetail3Sql, mainId);
|
detail3RecordSet.executeQuery(queryDetail3Sql, mainId);
|
||||||
while (detail3RecordSet.next()) {
|
while (detail3RecordSet.next()) {
|
||||||
MappingDetail mappingDetail = sqlUtil.recordSetToEntityByEntity(detail3RecordSet, MappingDetail.class);
|
MappingDetail mappingDetail = sqlUtil.recordSetToEntityByEntity(detail3RecordSet, MappingDetail.class);
|
||||||
mappingDetail.setParamType("5");// 设置参数类型为Object
|
mappingDetail.setParamType("5");// 设置参数类型为Object
|
||||||
mappingDetails.add(mappingDetail);
|
mappingDetails.add(mappingDetail);
|
||||||
}
|
}
|
||||||
requestMappingConfig.setConfigDetail(mappingDetails);
|
requestMappingConfig.setConfigDetail(mappingDetails);
|
||||||
// //查询明细4的信息
|
// //查询明细4的信息
|
||||||
// RecordSet detail4RecordSet = new RecordSet();
|
// RecordSet detail4RecordSet = new RecordSet();
|
||||||
// List<ResponseMapping> responseMappingList = new ArrayList<>();
|
// List<ResponseMapping> responseMappingList = new ArrayList<>();
|
||||||
// String queryDetail4Sql = "select responseFieldName,workflowField,mainOrDetail,detailTableId,workflowFieldName from uf_request_config_dt4 where mainid = ?";
|
// String queryDetail4Sql = "select responseFieldName,workflowField,mainOrDetail,detailTableId,workflowFieldName from uf_request_config_dt4 where mainid = ?";
|
||||||
// toolUtil.writeDebuggerLog("执行查询的明细sql query detail4Sql >>>>"+queryDetail4Sql+" mainId:"+mainId);
|
// toolUtil.writeDebuggerLog("执行查询的明细sql query detail4Sql >>>>"+queryDetail4Sql+" mainId:"+mainId);
|
||||||
// detail4RecordSet.executeQuery(queryDetail4Sql,mainId);
|
// detail4RecordSet.executeQuery(queryDetail4Sql,mainId);
|
||||||
// while (detail4RecordSet.next()){
|
// while (detail4RecordSet.next()){
|
||||||
// ResponseMapping responseMapping = sqlUtil.recordSetToEntityByEntity(detail4RecordSet, ResponseMapping.class);
|
// ResponseMapping responseMapping = sqlUtil.recordSetToEntityByEntity(detail4RecordSet, ResponseMapping.class);
|
||||||
// responseMappingList.add(responseMapping);
|
// responseMappingList.add(responseMapping);
|
||||||
// }
|
// }
|
||||||
// requestMappingConfig.setResponseMappingList(responseMappingList);
|
// requestMappingConfig.setResponseMappingList(responseMappingList);
|
||||||
requestMappingConfig.setConfigDetail(mappingDetails);
|
requestMappingConfig.setConfigDetail(mappingDetails);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* <h2>查询附件信息</h2>
|
* <h2>查询附件信息</h2>
|
||||||
*
|
*
|
||||||
* @param docIds 文档id
|
* @param docIds 文档id
|
||||||
* @return 附件信息
|
* @return 附件信息
|
||||||
* @author YouHong.ai
|
* @author YouHong.ai
|
||||||
*/
|
*/
|
||||||
public List<DocImageFile> selectDocImageFileList(String docIds) {
|
public List<DocImageFile> selectDocImageFileList(String docIds) {
|
||||||
String sql = "select docfile.IMAGEFILEID,docfile.IMAGEFILENAME,docfile.DOCID,docfile.ID, " +
|
String sql = "select docfile.IMAGEFILEID,docfile.IMAGEFILENAME,docfile.DOCID,docfile.ID, " +
|
||||||
" imf.FILESIZE " +
|
" imf.FILESIZE " +
|
||||||
"from docimagefile docfile " +
|
"from docimagefile docfile " +
|
||||||
"left join imagefile imf on imf.IMAGEFILEID = docfile.IMAGEFILEID " +
|
"left join imagefile imf on imf.IMAGEFILEID = docfile.IMAGEFILEID " +
|
||||||
"where docid in (" + docIds + ")";
|
"where docid in (" + docIds + ")";
|
||||||
RecordSet rs = new RecordSet();
|
RecordSet rs = new RecordSet();
|
||||||
rs.executeQuery(sql);
|
rs.executeQuery(sql);
|
||||||
List<DocImageFile> docImageFileList = new ArrayList<>();
|
List<DocImageFile> docImageFileList = new ArrayList<>();
|
||||||
while (rs.next()) {
|
while (rs.next()) {
|
||||||
String IMAGEFILEID = rs.getString("IMAGEFILEID");
|
String IMAGEFILEID = rs.getString("IMAGEFILEID");
|
||||||
String IMAGEFILENAME = rs.getString("IMAGEFILENAME");
|
String IMAGEFILENAME = rs.getString("IMAGEFILENAME");
|
||||||
String DOCID = rs.getString("DOCID");
|
String DOCID = rs.getString("DOCID");
|
||||||
String ID = rs.getString("ID");
|
String ID = rs.getString("ID");
|
||||||
String fileSize = rs.getString("FILESIZE");
|
String fileSize = rs.getString("FILESIZE");
|
||||||
DocImageFile docImageFile = new DocImageFile();
|
DocImageFile docImageFile = new DocImageFile();
|
||||||
docImageFile.setImageFileId(Util.getIntValue(IMAGEFILEID));
|
docImageFile.setImageFileId(Util.getIntValue(IMAGEFILEID));
|
||||||
docImageFile.setImageFileName(IMAGEFILENAME);
|
docImageFile.setImageFileName(IMAGEFILENAME);
|
||||||
docImageFile.setDocId(Util.getIntValue(DOCID));
|
docImageFile.setDocId(Util.getIntValue(DOCID));
|
||||||
docImageFile.setId(Util.getIntValue(ID));
|
docImageFile.setId(Util.getIntValue(ID));
|
||||||
docImageFile.setFileSize(Util.getIntValue(fileSize) / 1024L);
|
docImageFile.setFileSize(Util.getIntValue(fileSize) / 1024L);
|
||||||
docImageFileList.add(docImageFile);
|
docImageFileList.add(docImageFile);
|
||||||
}
|
}
|
||||||
if (docImageFileList.isEmpty()) {
|
if (docImageFileList.isEmpty()) {
|
||||||
throw new NullPointerException("附件字段不存在值!请检查数据表或配置表数据类型是否正确!");
|
throw new NullPointerException("附件字段不存在值!请检查数据表或配置表数据类型是否正确!");
|
||||||
}
|
}
|
||||||
return docImageFileList;
|
return docImageFileList;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -1,26 +1,26 @@
|
||||||
package weaver.xiao.commons.config.entity;
|
package weaver.xiao.commons.config.entity;
|
||||||
|
|
||||||
import lombok.Data;
|
import lombok.Data;
|
||||||
import weaver.xiao.commons.utils.annotation.SqlFieldMapping;
|
import weaver.xiao.commons.utils.annotation.SqlFieldMapping;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @author XiaoBokang
|
* @author XiaoBokang
|
||||||
* @create 2021/12/31 10:15
|
* @create 2021/12/31 10:15
|
||||||
*/
|
*/
|
||||||
|
|
||||||
@Data
|
@Data
|
||||||
public class FieldMessage {
|
public class FieldMessage {
|
||||||
|
|
||||||
@SqlFieldMapping("fieldId")
|
@SqlFieldMapping("fieldId")
|
||||||
private String fieldId;
|
private String fieldId;
|
||||||
|
|
||||||
@SqlFieldMapping("fieldName")
|
@SqlFieldMapping("fieldName")
|
||||||
private String fieldName;
|
private String fieldName;
|
||||||
|
|
||||||
@SqlFieldMapping("indexDesc")
|
@SqlFieldMapping("indexDesc")
|
||||||
private String indexDesc;
|
private String indexDesc;
|
||||||
|
|
||||||
@SqlFieldMapping("tableName")
|
@SqlFieldMapping("tableName")
|
||||||
private String tableName;
|
private String tableName;
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -1,53 +1,53 @@
|
||||||
package weaver.xiao.commons.config.entity;
|
package weaver.xiao.commons.config.entity;
|
||||||
|
|
||||||
import lombok.Data;
|
import lombok.Data;
|
||||||
import weaver.xiao.commons.utils.annotation.SqlFieldMapping;
|
import weaver.xiao.commons.utils.annotation.SqlFieldMapping;
|
||||||
|
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @author XiaoBokang
|
* @author XiaoBokang
|
||||||
* @create 2021/12/28 17:45
|
* @create 2021/12/28 17:45
|
||||||
*/
|
*/
|
||||||
|
|
||||||
@Data
|
@Data
|
||||||
public class MappingDetail {
|
public class MappingDetail {
|
||||||
|
|
||||||
@SqlFieldMapping("paramName")
|
@SqlFieldMapping("paramName")
|
||||||
private String paramName;
|
private String paramName;
|
||||||
|
|
||||||
@SqlFieldMapping("paramType")
|
@SqlFieldMapping("paramType")
|
||||||
private String paramType;
|
private String paramType;
|
||||||
|
|
||||||
@SqlFieldMapping("getValueType")
|
@SqlFieldMapping("getValueType")
|
||||||
private String getValueType;
|
private String getValueType;
|
||||||
|
|
||||||
@SqlFieldMapping("childType")
|
@SqlFieldMapping("childType")
|
||||||
private String childType;
|
private String childType;
|
||||||
|
|
||||||
@SqlFieldMapping("dataSource")
|
@SqlFieldMapping("dataSource")
|
||||||
private String dataSource;
|
private String dataSource;
|
||||||
|
|
||||||
@SqlFieldMapping("detailId")
|
@SqlFieldMapping("detailId")
|
||||||
private String detailId;
|
private String detailId;
|
||||||
|
|
||||||
@SqlFieldMapping("belongTo")
|
@SqlFieldMapping("belongTo")
|
||||||
private String belongTo;
|
private String belongTo;
|
||||||
|
|
||||||
@SqlFieldMapping("workflowField")
|
@SqlFieldMapping("workflowField")
|
||||||
private String workflowField;
|
private String workflowField;
|
||||||
|
|
||||||
@SqlFieldMapping("valueContext")
|
@SqlFieldMapping("valueContext")
|
||||||
private String valueContext;
|
private String valueContext;
|
||||||
|
|
||||||
@SqlFieldMapping("relationWorkFlowField")
|
@SqlFieldMapping("relationWorkFlowField")
|
||||||
private String relationWorkFlowField;
|
private String relationWorkFlowField;
|
||||||
|
|
||||||
@SqlFieldMapping("cusWhereSql")
|
@SqlFieldMapping("cusWhereSql")
|
||||||
private String cusWhereSql;
|
private String cusWhereSql;
|
||||||
|
|
||||||
private List<MappingDetail> childList;
|
private List<MappingDetail> childList;
|
||||||
|
|
||||||
private FieldMessage fieldMassage;
|
private FieldMessage fieldMassage;
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -34,4 +34,14 @@ public class MultipartFile {
|
||||||
* 文件大小
|
* 文件大小
|
||||||
*/
|
*/
|
||||||
Long fileSize;
|
Long fileSize;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 文件id
|
||||||
|
*/
|
||||||
|
private Integer imageFileId;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* docId
|
||||||
|
*/
|
||||||
|
private Integer docId;
|
||||||
}
|
}
|
||||||
|
|
|
@ -1,48 +1,48 @@
|
||||||
package weaver.xiao.commons.config.entity;
|
package weaver.xiao.commons.config.entity;
|
||||||
|
|
||||||
|
|
||||||
import lombok.Data;
|
import lombok.Data;
|
||||||
import weaver.xiao.commons.utils.annotation.SqlFieldMapping;
|
import weaver.xiao.commons.utils.annotation.SqlFieldMapping;
|
||||||
|
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @author XiaoBokang
|
* @author XiaoBokang
|
||||||
* @create 2021/12/28 17:43
|
* @create 2021/12/28 17:43
|
||||||
*/
|
*/
|
||||||
|
|
||||||
@Data
|
@Data
|
||||||
public class RequestMappingConfig {
|
public class RequestMappingConfig {
|
||||||
|
|
||||||
@SqlFieldMapping("workflow")
|
@SqlFieldMapping("workflow")
|
||||||
private String workflow;
|
private String workflow;
|
||||||
|
|
||||||
@SqlFieldMapping("requestUrl")
|
@SqlFieldMapping("requestUrl")
|
||||||
private String requestUrl;
|
private String requestUrl;
|
||||||
|
|
||||||
@SqlFieldMapping("uniqueCode")
|
@SqlFieldMapping("uniqueCode")
|
||||||
private String uniqueCode;
|
private String uniqueCode;
|
||||||
|
|
||||||
@SqlFieldMapping("dataSource")
|
@SqlFieldMapping("dataSource")
|
||||||
private String dataSource;
|
private String dataSource;
|
||||||
|
|
||||||
@SqlFieldMapping("modelId")
|
@SqlFieldMapping("modelId")
|
||||||
private String modelId;
|
private String modelId;
|
||||||
|
|
||||||
@SqlFieldMapping("tableName")
|
@SqlFieldMapping("tableName")
|
||||||
private String tableName;
|
private String tableName;
|
||||||
|
|
||||||
@SqlFieldMapping("urlDesc")
|
@SqlFieldMapping("urlDesc")
|
||||||
private String urlDesc;
|
private String urlDesc;
|
||||||
|
|
||||||
@SqlFieldMapping("relationWorkFlow")
|
@SqlFieldMapping("relationWorkFlow")
|
||||||
private String relationWorkFlow;
|
private String relationWorkFlow;
|
||||||
|
|
||||||
@SqlFieldMapping("cusWhereSql")
|
@SqlFieldMapping("cusWhereSql")
|
||||||
private String cusWhereSql;
|
private String cusWhereSql;
|
||||||
|
|
||||||
private List<MappingDetail> configDetail;
|
private List<MappingDetail> configDetail;
|
||||||
|
|
||||||
private List<ResponseMapping> responseMappingList;
|
private List<ResponseMapping> responseMappingList;
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -1,17 +1,17 @@
|
||||||
package weaver.xiao.commons.config.entity;
|
package weaver.xiao.commons.config.entity;
|
||||||
|
|
||||||
import lombok.Data;
|
import lombok.Data;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @author XiaoBokang
|
* @author XiaoBokang
|
||||||
* @create 2022/4/12 22:28
|
* @create 2022/4/12 22:28
|
||||||
*/
|
*/
|
||||||
|
|
||||||
@Data
|
@Data
|
||||||
public class ResponseMapping {
|
public class ResponseMapping {
|
||||||
private String responseFieldName;
|
private String responseFieldName;
|
||||||
private String workflowField;
|
private String workflowField;
|
||||||
private String mainOrDetail;
|
private String mainOrDetail;
|
||||||
private String detailTableId;
|
private String detailTableId;
|
||||||
private String workflowFieldName;
|
private String workflowFieldName;
|
||||||
}
|
}
|
||||||
|
|
|
@ -1,35 +1,35 @@
|
||||||
package weaver.xiao.commons.config.enumtype;
|
package weaver.xiao.commons.config.enumtype;
|
||||||
|
|
||||||
import java.util.EnumSet;
|
import java.util.EnumSet;
|
||||||
import java.util.HashMap;
|
import java.util.HashMap;
|
||||||
import java.util.Map;
|
import java.util.Map;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @author XiaoBokang
|
* @author XiaoBokang
|
||||||
* @create 2022/6/14 12:26
|
* @create 2022/6/14 12:26
|
||||||
*/
|
*/
|
||||||
|
|
||||||
public enum DataSourceEnum {
|
public enum DataSourceEnum {
|
||||||
|
|
||||||
WORKFLOW("0"),
|
WORKFLOW("0"),
|
||||||
MODEL("1"),
|
MODEL("1"),
|
||||||
CUS_TABLE("2");
|
CUS_TABLE("2");
|
||||||
|
|
||||||
private static final Map<String, DataSourceEnum> LOOK_UP = new HashMap<>(8);
|
private static final Map<String, DataSourceEnum> LOOK_UP = new HashMap<>(8);
|
||||||
|
|
||||||
static {
|
static {
|
||||||
for (DataSourceEnum dataSource : EnumSet.allOf(DataSourceEnum.class)){
|
for (DataSourceEnum dataSource : EnumSet.allOf(DataSourceEnum.class)){
|
||||||
LOOK_UP.put(dataSource.value,dataSource);
|
LOOK_UP.put(dataSource.value,dataSource);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
public final String value;
|
public final String value;
|
||||||
|
|
||||||
DataSourceEnum(String value){
|
DataSourceEnum(String value){
|
||||||
this.value = value;
|
this.value = value;
|
||||||
}
|
}
|
||||||
|
|
||||||
public static DataSourceEnum getEnum(String value){
|
public static DataSourceEnum getEnum(String value){
|
||||||
return LOOK_UP.get(value);
|
return LOOK_UP.get(value);
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -1,44 +1,44 @@
|
||||||
package weaver.xiao.commons.config.enumtype;
|
package weaver.xiao.commons.config.enumtype;
|
||||||
|
|
||||||
import java.util.EnumSet;
|
import java.util.EnumSet;
|
||||||
import java.util.HashMap;
|
import java.util.HashMap;
|
||||||
import java.util.Map;
|
import java.util.Map;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @author XiaoBokang
|
* @author XiaoBokang
|
||||||
* @create 2022/6/14 13:13
|
* @create 2022/6/14 13:13
|
||||||
*/
|
*/
|
||||||
|
|
||||||
public enum GetValueTypeEnum {
|
public enum GetValueTypeEnum {
|
||||||
|
|
||||||
WORKFLOW_FIELD("0"),
|
WORKFLOW_FIELD("0"),
|
||||||
DEFAULT_VALUE("1"),
|
DEFAULT_VALUE("1"),
|
||||||
CURRENT_TIME("3"),
|
CURRENT_TIME("3"),
|
||||||
CUS_SQL("4"),
|
CUS_SQL("4"),
|
||||||
REQUEST_ID("5"),
|
REQUEST_ID("5"),
|
||||||
MAIN_DATA_ID("6"),
|
MAIN_DATA_ID("6"),
|
||||||
RANDOM("7"),
|
RANDOM("7"),
|
||||||
ATTACHMENT("8"),
|
ATTACHMENT("8"),
|
||||||
|
|
||||||
CUS_INTERFACE("9"),
|
CUS_INTERFACE("9"),
|
||||||
|
|
||||||
CUS_FIELD("10");
|
CUS_FIELD("10");
|
||||||
|
|
||||||
private static final Map<String, GetValueTypeEnum> LOOK_UP = new HashMap<>(8);
|
private static final Map<String, GetValueTypeEnum> LOOK_UP = new HashMap<>(8);
|
||||||
|
|
||||||
static {
|
static {
|
||||||
for (GetValueTypeEnum getValueTypeEnum : EnumSet.allOf(GetValueTypeEnum.class)) {
|
for (GetValueTypeEnum getValueTypeEnum : EnumSet.allOf(GetValueTypeEnum.class)) {
|
||||||
LOOK_UP.put(getValueTypeEnum.value, getValueTypeEnum);
|
LOOK_UP.put(getValueTypeEnum.value, getValueTypeEnum);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
public final String value;
|
public final String value;
|
||||||
|
|
||||||
GetValueTypeEnum(String value) {
|
GetValueTypeEnum(String value) {
|
||||||
this.value = value;
|
this.value = value;
|
||||||
}
|
}
|
||||||
|
|
||||||
public static GetValueTypeEnum getEnum(String value) {
|
public static GetValueTypeEnum getEnum(String value) {
|
||||||
return LOOK_UP.get(value);
|
return LOOK_UP.get(value);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -1,43 +1,49 @@
|
||||||
package weaver.xiao.commons.config.enumtype;
|
package weaver.xiao.commons.config.enumtype;
|
||||||
|
|
||||||
import java.util.EnumSet;
|
import java.util.EnumSet;
|
||||||
import java.util.HashMap;
|
import java.util.HashMap;
|
||||||
import java.util.Map;
|
import java.util.Map;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @author XiaoBokang
|
* <h1>参数类型枚举类</h1>
|
||||||
* @create 2022/6/14 12:56
|
* @author XiaoBokang
|
||||||
*/
|
* @create 2022/6/14 12:56
|
||||||
|
* <h1>版本改动说明 : </h1>
|
||||||
public enum ParamTypeEnum {
|
* <p>
|
||||||
|
* v2.0 xuanran.wang 2022-12-06
|
||||||
STRING("0"),
|
* 增加Object类型的枚举 字段值来自于自定义接口时可以选此选项 保留自定义接口返回参数类型
|
||||||
INT("1"),
|
* </p>
|
||||||
DOUBLE("2"),
|
*/
|
||||||
DATE("3"),
|
public enum ParamTypeEnum {
|
||||||
DATE_TIME("4"),
|
|
||||||
OBJECT("5"),
|
STRING("0"),
|
||||||
LIST("6"),
|
INT("1"),
|
||||||
CUS_DATE_STR("7"),
|
DOUBLE("2"),
|
||||||
TIME_STAMP("8"),
|
DATE("3"),
|
||||||
DATE_VAL("9"),
|
DATE_TIME("4"),
|
||||||
Boolean("10");
|
OBJECT("5"),
|
||||||
|
LIST("6"),
|
||||||
|
CUS_DATE_STR("7"),
|
||||||
private static final Map<String, ParamTypeEnum> LOOK_UP = new HashMap<>(8);
|
TIME_STAMP("8"),
|
||||||
|
DATE_VAL("9"),
|
||||||
static {
|
Boolean("10"),
|
||||||
for (ParamTypeEnum paramTypeEnum : EnumSet.allOf(ParamTypeEnum.class)){
|
Object("11");
|
||||||
LOOK_UP.put(paramTypeEnum.value,paramTypeEnum);
|
|
||||||
}
|
|
||||||
}
|
private static final Map<String, ParamTypeEnum> LOOK_UP = new HashMap<>(8);
|
||||||
public final String value;
|
|
||||||
|
static {
|
||||||
ParamTypeEnum(String value){
|
for (ParamTypeEnum paramTypeEnum : EnumSet.allOf(ParamTypeEnum.class)){
|
||||||
this.value = value;
|
LOOK_UP.put(paramTypeEnum.value,paramTypeEnum);
|
||||||
}
|
}
|
||||||
|
}
|
||||||
public static ParamTypeEnum getEnum(String value){
|
public final String value;
|
||||||
return LOOK_UP.get(value);
|
|
||||||
}
|
ParamTypeEnum(String value){
|
||||||
}
|
this.value = value;
|
||||||
|
}
|
||||||
|
|
||||||
|
public static ParamTypeEnum getEnum(String value){
|
||||||
|
return LOOK_UP.get(value);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
File diff suppressed because it is too large
Load Diff
|
@ -1,21 +1,21 @@
|
||||||
package weaver.xiao.commons.exception;
|
package weaver.xiao.commons.exception;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @author XiaoBokang
|
* @author XiaoBokang
|
||||||
* @create 2022/1/12 11:06
|
* @create 2022/1/12 11:06
|
||||||
*/
|
*/
|
||||||
|
|
||||||
public class RequestException extends RuntimeException{
|
public class RequestException extends RuntimeException{
|
||||||
public RequestException(String message){
|
public RequestException(String message){
|
||||||
super(message);
|
super(message);
|
||||||
}
|
}
|
||||||
|
|
||||||
public RequestException(String message, Throwable cause) {
|
public RequestException(String message, Throwable cause) {
|
||||||
super(message, cause);
|
super(message, cause);
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public synchronized Throwable fillInStackTrace() {
|
public synchronized Throwable fillInStackTrace() {
|
||||||
return super.fillInStackTrace();
|
return super.fillInStackTrace();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -1,22 +1,22 @@
|
||||||
package weaver.xiao.commons.exception;
|
package weaver.xiao.commons.exception;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @author XiaoBokang
|
* @author XiaoBokang
|
||||||
* @create 2022/1/4 9:50
|
* @create 2022/1/4 9:50
|
||||||
*/
|
*/
|
||||||
|
|
||||||
public class ValueDealException extends RuntimeException{
|
public class ValueDealException extends RuntimeException{
|
||||||
|
|
||||||
public ValueDealException(String message){
|
public ValueDealException(String message){
|
||||||
super(message);
|
super(message);
|
||||||
}
|
}
|
||||||
|
|
||||||
public ValueDealException(String message, Throwable cause) {
|
public ValueDealException(String message, Throwable cause) {
|
||||||
super(message, cause);
|
super(message, cause);
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public synchronized Throwable fillInStackTrace() {
|
public synchronized Throwable fillInStackTrace() {
|
||||||
return super.fillInStackTrace();
|
return super.fillInStackTrace();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -1,70 +1,70 @@
|
||||||
package weaver.xiao.commons.utils;
|
package weaver.xiao.commons.utils;
|
||||||
|
|
||||||
import com.alibaba.fastjson.JSONObject;
|
import com.alibaba.fastjson.JSONObject;
|
||||||
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @author XiaoBokang
|
* @author XiaoBokang
|
||||||
* @create 2021/9/9 19:33
|
* @create 2021/9/9 19:33
|
||||||
*/
|
*/
|
||||||
|
|
||||||
public class JsonResult {
|
public class JsonResult {
|
||||||
|
|
||||||
private Integer code;
|
private Integer code;
|
||||||
private String message;
|
private String message;
|
||||||
private Object Data;
|
private Object Data;
|
||||||
|
|
||||||
public JsonResult(Integer code, String message, Object data) {
|
public JsonResult(Integer code, String message, Object data) {
|
||||||
this.code = code;
|
this.code = code;
|
||||||
this.message = message;
|
this.message = message;
|
||||||
Data = data;
|
Data = data;
|
||||||
}
|
}
|
||||||
|
|
||||||
public static String success(String message){
|
public static String success(String message){
|
||||||
return JSONObject.toJSONString(new JsonResult(200,message,null));
|
return JSONObject.toJSONString(new JsonResult(200,message,null));
|
||||||
}
|
}
|
||||||
public static String success(){
|
public static String success(){
|
||||||
return JSONObject.toJSONString(new JsonResult(200,"success",null));
|
return JSONObject.toJSONString(new JsonResult(200,"success",null));
|
||||||
}
|
}
|
||||||
public static String successData(String message,Object data){
|
public static String successData(String message,Object data){
|
||||||
return JSONObject.toJSONString(new JsonResult(200,message,data));
|
return JSONObject.toJSONString(new JsonResult(200,message,data));
|
||||||
}
|
}
|
||||||
public static String successData(Object data){
|
public static String successData(Object data){
|
||||||
return JSONObject.toJSONString(new JsonResult(200,"success",data));
|
return JSONObject.toJSONString(new JsonResult(200,"success",data));
|
||||||
}
|
}
|
||||||
|
|
||||||
public static String error(int code,String message){
|
public static String error(int code,String message){
|
||||||
return JSONObject.toJSONString(new JsonResult(code,message,null));
|
return JSONObject.toJSONString(new JsonResult(code,message,null));
|
||||||
}
|
}
|
||||||
public static String error(String message){
|
public static String error(String message){
|
||||||
return JSONObject.toJSONString(new JsonResult(500,message,null));
|
return JSONObject.toJSONString(new JsonResult(500,message,null));
|
||||||
}
|
}
|
||||||
public static String error(){
|
public static String error(){
|
||||||
return JSONObject.toJSONString(new JsonResult(500,"fail",null));
|
return JSONObject.toJSONString(new JsonResult(500,"fail",null));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
public Integer getCode() {
|
public Integer getCode() {
|
||||||
return code;
|
return code;
|
||||||
}
|
}
|
||||||
|
|
||||||
public void setCode(Integer code) {
|
public void setCode(Integer code) {
|
||||||
this.code = code;
|
this.code = code;
|
||||||
}
|
}
|
||||||
|
|
||||||
public String getMessage() {
|
public String getMessage() {
|
||||||
return message;
|
return message;
|
||||||
}
|
}
|
||||||
|
|
||||||
public void setMessage(String message) {
|
public void setMessage(String message) {
|
||||||
this.message = message;
|
this.message = message;
|
||||||
}
|
}
|
||||||
|
|
||||||
public Object getData() {
|
public Object getData() {
|
||||||
return Data;
|
return Data;
|
||||||
}
|
}
|
||||||
|
|
||||||
public void setData(Object data) {
|
public void setData(Object data) {
|
||||||
Data = data;
|
Data = data;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -1,73 +1,73 @@
|
||||||
package weaver.xiao.commons.utils;
|
package weaver.xiao.commons.utils;
|
||||||
|
|
||||||
import org.apache.log4j.*;
|
import org.apache.log4j.*;
|
||||||
|
|
||||||
import java.io.File;
|
import java.io.File;
|
||||||
import java.io.PrintWriter;
|
import java.io.PrintWriter;
|
||||||
import java.io.StringWriter;
|
import java.io.StringWriter;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @author XiaoBokang
|
* @author XiaoBokang
|
||||||
* @create 2022/3/3 14:16
|
* @create 2022/3/3 14:16
|
||||||
*/
|
*/
|
||||||
|
|
||||||
public class LogUtil {
|
public class LogUtil {
|
||||||
|
|
||||||
private static volatile Logger log = null;
|
private static volatile Logger log = null;
|
||||||
|
|
||||||
public static Logger getLogger(){
|
public static Logger getLogger(){
|
||||||
return LogUtil.getLogger(weaver.general.GCONST.getLogPath() + "cus" + File.separator + "util_cus" + File.separator + "cus.log");
|
return LogUtil.getLogger(weaver.general.GCONST.getLogPath() + "cus" + File.separator + "util_cus" + File.separator + "cus.log");
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* 获取日志对象
|
* 获取日志对象
|
||||||
* @return 日志对象
|
* @return 日志对象
|
||||||
*/
|
*/
|
||||||
public static Logger getLogger(String file) {
|
public static Logger getLogger(String file) {
|
||||||
if (log == null) {
|
if (log == null) {
|
||||||
synchronized (LogUtil.class) {
|
synchronized (LogUtil.class) {
|
||||||
if (log == null) {
|
if (log == null) {
|
||||||
DailyRollingFileAppender appender = new DailyRollingFileAppender();
|
DailyRollingFileAppender appender = new DailyRollingFileAppender();
|
||||||
log = Logger.getLogger("xbk_cus");
|
log = Logger.getLogger("xbk_cus");
|
||||||
appender.setName("xbk_cus");
|
appender.setName("xbk_cus");
|
||||||
appender.setEncoding("UTF-8");
|
appender.setEncoding("UTF-8");
|
||||||
appender.setDatePattern("'_'yyyyMMdd'.log'");
|
appender.setDatePattern("'_'yyyyMMdd'.log'");
|
||||||
appender.setFile(file);
|
appender.setFile(file);
|
||||||
appender.setThreshold(Priority.DEBUG);
|
appender.setThreshold(Priority.DEBUG);
|
||||||
appender.setLayout(new PatternLayout("[%-5p] [%d{yyyy-MM-dd HH:mm:ss,SSS}] [%r] [Thread:%t][%F.%M:%L] ==> : %m %x %n"));
|
appender.setLayout(new PatternLayout("[%-5p] [%d{yyyy-MM-dd HH:mm:ss,SSS}] [%r] [Thread:%t][%F.%M:%L] ==> : %m %x %n"));
|
||||||
appender.setAppend(true);
|
appender.setAppend(true);
|
||||||
appender.activateOptions();
|
appender.activateOptions();
|
||||||
log.addAppender(appender);
|
log.addAppender(appender);
|
||||||
boolean enableDebug = true;
|
boolean enableDebug = true;
|
||||||
if (!enableDebug) {
|
if (!enableDebug) {
|
||||||
log.setLevel(Level.INFO);
|
log.setLevel(Level.INFO);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
return log;
|
return log;
|
||||||
}
|
}
|
||||||
|
|
||||||
public static Logger getSqlLogger(){
|
public static Logger getSqlLogger(){
|
||||||
return LogUtil.getLogger(weaver.general.GCONST.getLogPath() + "cus" + File.separator + "sql" + File.separator + "cussql.log");
|
return LogUtil.getLogger(weaver.general.GCONST.getLogPath() + "cus" + File.separator + "sql" + File.separator + "cussql.log");
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* 获取堆栈中的异常信息
|
* 获取堆栈中的异常信息
|
||||||
* @param throwable 异常
|
* @param throwable 异常
|
||||||
* @return
|
* @return
|
||||||
*/
|
*/
|
||||||
public static String getExceptionStr(Throwable throwable){
|
public static String getExceptionStr(Throwable throwable){
|
||||||
StringWriter stringWriter = new StringWriter();
|
StringWriter stringWriter = new StringWriter();
|
||||||
throwable.printStackTrace(new PrintWriter(stringWriter,true));
|
throwable.printStackTrace(new PrintWriter(stringWriter,true));
|
||||||
String s = stringWriter.getBuffer().toString();
|
String s = stringWriter.getBuffer().toString();
|
||||||
try{
|
try{
|
||||||
stringWriter.close();
|
stringWriter.close();
|
||||||
}catch (Exception ignored){
|
}catch (Exception ignored){
|
||||||
ignored.printStackTrace();
|
ignored.printStackTrace();
|
||||||
}
|
}
|
||||||
return s;
|
return s;
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -1,26 +1,26 @@
|
||||||
package weaver.xiao.commons.utils;
|
package weaver.xiao.commons.utils;
|
||||||
|
|
||||||
import java.util.HashMap;
|
import java.util.HashMap;
|
||||||
import java.util.Map;
|
import java.util.Map;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @author XiaoBokang
|
* @author XiaoBokang
|
||||||
* @create 2021/8/20 14:01
|
* @create 2021/8/20 14:01
|
||||||
*/
|
*/
|
||||||
|
|
||||||
public class PreMap extends HashMap<String,Object> implements Map<String,Object> {
|
public class PreMap extends HashMap<String,Object> implements Map<String,Object> {
|
||||||
|
|
||||||
public PreMap(){
|
public PreMap(){
|
||||||
super();
|
super();
|
||||||
}
|
}
|
||||||
|
|
||||||
public static PreMap create(){
|
public static PreMap create(){
|
||||||
return new PreMap();
|
return new PreMap();
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public PreMap put(String key, Object value){
|
public PreMap put(String key, Object value){
|
||||||
super.put(key,value);
|
super.put(key,value);
|
||||||
return this;
|
return this;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -1,57 +1,57 @@
|
||||||
package weaver.xiao.commons.utils;
|
package weaver.xiao.commons.utils;
|
||||||
|
|
||||||
import weaver.common.util.string.StringUtil;
|
import weaver.common.util.string.StringUtil;
|
||||||
import weaver.general.GCONST;
|
import weaver.general.GCONST;
|
||||||
|
|
||||||
import java.io.*;
|
import java.io.*;
|
||||||
import java.util.Enumeration;
|
import java.util.Enumeration;
|
||||||
import java.util.HashMap;
|
import java.util.HashMap;
|
||||||
import java.util.Map;
|
import java.util.Map;
|
||||||
import java.util.Properties;
|
import java.util.Properties;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @author XiaoBokang
|
* @author XiaoBokang
|
||||||
* @create 2022/3/10 11:13
|
* @create 2022/3/10 11:13
|
||||||
*/
|
*/
|
||||||
|
|
||||||
public class PropUtil {
|
public class PropUtil {
|
||||||
/**
|
/**
|
||||||
* 通过文件名获取到对应的配置文件map对象
|
* 通过文件名获取到对应的配置文件map对象
|
||||||
* @param fileName prop/文件夹下的文件名(不包含.properties)
|
* @param fileName prop/文件夹下的文件名(不包含.properties)
|
||||||
* @return 配置文件对应的map对象
|
* @return 配置文件对应的map对象
|
||||||
*/
|
*/
|
||||||
public static Map<String, Object> getProperties2Map(String fileName) {
|
public static Map<String, Object> getProperties2Map(String fileName) {
|
||||||
String propertyPath = GCONST.getPropertyPath();
|
String propertyPath = GCONST.getPropertyPath();
|
||||||
if (StringUtil.isNullOrEmpty(fileName)) {
|
if (StringUtil.isNullOrEmpty(fileName)) {
|
||||||
return null;
|
return null;
|
||||||
}
|
}
|
||||||
if (fileName.contains(".properties")) {
|
if (fileName.contains(".properties")) {
|
||||||
fileName = fileName.replace(".properties", "");
|
fileName = fileName.replace(".properties", "");
|
||||||
}
|
}
|
||||||
String path = propertyPath + File.separator + fileName + ".properties";
|
String path = propertyPath + File.separator + fileName + ".properties";
|
||||||
Properties prop = new Properties();
|
Properties prop = new Properties();
|
||||||
Map<String, Object> map = new HashMap<>();
|
Map<String, Object> map = new HashMap<>();
|
||||||
InputStream inputStream = null;
|
InputStream inputStream = null;
|
||||||
try {
|
try {
|
||||||
inputStream = new BufferedInputStream(new FileInputStream(path));
|
inputStream = new BufferedInputStream(new FileInputStream(path));
|
||||||
prop.load(inputStream);
|
prop.load(inputStream);
|
||||||
Enumeration<?> enumeration = prop.propertyNames();
|
Enumeration<?> enumeration = prop.propertyNames();
|
||||||
while (enumeration.hasMoreElements()) {
|
while (enumeration.hasMoreElements()) {
|
||||||
String key = String.valueOf(enumeration.nextElement());
|
String key = String.valueOf(enumeration.nextElement());
|
||||||
map.put(key, prop.getProperty(key));
|
map.put(key, prop.getProperty(key));
|
||||||
}
|
}
|
||||||
} catch (IOException e) {
|
} catch (IOException e) {
|
||||||
throw new RuntimeException("找不到文件:" + path);
|
throw new RuntimeException("找不到文件:" + path);
|
||||||
} finally {
|
} finally {
|
||||||
try {
|
try {
|
||||||
if (inputStream != null) {
|
if (inputStream != null) {
|
||||||
inputStream.close();
|
inputStream.close();
|
||||||
}
|
}
|
||||||
} catch (IOException e) {
|
} catch (IOException e) {
|
||||||
e.printStackTrace();
|
e.printStackTrace();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
return map;
|
return map;
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -1,59 +1,59 @@
|
||||||
package weaver.xiao.commons.utils;
|
package weaver.xiao.commons.utils;
|
||||||
|
|
||||||
import lombok.Data;
|
import lombok.Data;
|
||||||
|
|
||||||
import java.io.InputStream;
|
import java.io.InputStream;
|
||||||
import java.util.HashMap;
|
import java.util.HashMap;
|
||||||
import java.util.Map;
|
import java.util.Map;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @author XiaoBokang
|
* @author XiaoBokang
|
||||||
* @create 2021/8/23 16:34
|
* @create 2021/8/23 16:34
|
||||||
*/
|
*/
|
||||||
|
|
||||||
@Data
|
@Data
|
||||||
public class RequestBaseInfo{
|
public class RequestBaseInfo{
|
||||||
|
|
||||||
private String type;
|
private String type;
|
||||||
private String url;
|
private String url;
|
||||||
private Object params;
|
private Object params;
|
||||||
private InputStream[] inputStreams;
|
private InputStream[] inputStreams;
|
||||||
private String[] fileNames;
|
private String[] fileNames;
|
||||||
private String fileField;
|
private String fileField;
|
||||||
private Map<String,String > headers;
|
private Map<String,String > headers;
|
||||||
|
|
||||||
private static final Map<String,String > HEADER_NORMAL = new HashMap<>();
|
private static final Map<String,String > HEADER_NORMAL = new HashMap<>();
|
||||||
private static final Map<String,Object > PARAMS_NORMAL = new HashMap<>();
|
private static final Map<String,Object > PARAMS_NORMAL = new HashMap<>();
|
||||||
|
|
||||||
|
|
||||||
public static RequestBaseInfo create(String type, String url){
|
public static RequestBaseInfo create(String type, String url){
|
||||||
return create(type,url,HEADER_NORMAL,PARAMS_NORMAL);
|
return create(type,url,HEADER_NORMAL,PARAMS_NORMAL);
|
||||||
}
|
}
|
||||||
|
|
||||||
public static RequestBaseInfo create(String type, String url, Map<String, String> headers){
|
public static RequestBaseInfo create(String type, String url, Map<String, String> headers){
|
||||||
return create(type,url,headers,PARAMS_NORMAL);
|
return create(type,url,headers,PARAMS_NORMAL);
|
||||||
}
|
}
|
||||||
|
|
||||||
public static RequestBaseInfo create(String type, String url, Map<String, String> headers, Object params){
|
public static RequestBaseInfo create(String type, String url, Map<String, String> headers, Object params){
|
||||||
RequestBaseInfo requestInfo = new RequestBaseInfo();
|
RequestBaseInfo requestInfo = new RequestBaseInfo();
|
||||||
requestInfo.setType(type.toUpperCase());
|
requestInfo.setType(type.toUpperCase());
|
||||||
requestInfo.setUrl(url);
|
requestInfo.setUrl(url);
|
||||||
requestInfo.setParams(params);
|
requestInfo.setParams(params);
|
||||||
requestInfo.setHeaders(headers);
|
requestInfo.setHeaders(headers);
|
||||||
return requestInfo;
|
return requestInfo;
|
||||||
}
|
}
|
||||||
|
|
||||||
public static RequestBaseInfo createByFile(String type, String url, Map<String, String> headers, Object params, InputStream[] inputStreams, String fileField, String[] fileNames){
|
public static RequestBaseInfo createByFile(String type, String url, Map<String, String> headers, Object params, InputStream[] inputStreams, String fileField, String[] fileNames){
|
||||||
RequestBaseInfo requestInfo = new RequestBaseInfo();
|
RequestBaseInfo requestInfo = new RequestBaseInfo();
|
||||||
requestInfo.setType(type.toUpperCase());
|
requestInfo.setType(type.toUpperCase());
|
||||||
requestInfo.setUrl(url);
|
requestInfo.setUrl(url);
|
||||||
requestInfo.setParams(params);
|
requestInfo.setParams(params);
|
||||||
requestInfo.setHeaders(headers);
|
requestInfo.setHeaders(headers);
|
||||||
requestInfo.setInputStreams(inputStreams);
|
requestInfo.setInputStreams(inputStreams);
|
||||||
requestInfo.setFileNames(fileNames);
|
requestInfo.setFileNames(fileNames);
|
||||||
requestInfo.setFileField(fileField);
|
requestInfo.setFileField(fileField);
|
||||||
return requestInfo;
|
return requestInfo;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -1,165 +1,165 @@
|
||||||
package weaver.xiao.commons.utils;
|
package weaver.xiao.commons.utils;
|
||||||
|
|
||||||
import com.alibaba.fastjson.JSON;
|
import com.alibaba.fastjson.JSON;
|
||||||
import com.fasterxml.jackson.databind.ObjectMapper;
|
import com.fasterxml.jackson.databind.ObjectMapper;
|
||||||
import org.apache.http.HttpEntity;
|
import org.apache.http.HttpEntity;
|
||||||
import org.apache.http.client.methods.*;
|
import org.apache.http.client.methods.*;
|
||||||
import org.apache.http.entity.ContentType;
|
import org.apache.http.entity.ContentType;
|
||||||
import org.apache.http.entity.StringEntity;
|
import org.apache.http.entity.StringEntity;
|
||||||
import org.apache.http.entity.mime.HttpMultipartMode;
|
import org.apache.http.entity.mime.HttpMultipartMode;
|
||||||
import org.apache.http.entity.mime.MultipartEntityBuilder;
|
import org.apache.http.entity.mime.MultipartEntityBuilder;
|
||||||
import org.apache.http.impl.client.DefaultHttpClient;
|
import org.apache.http.impl.client.DefaultHttpClient;
|
||||||
import org.apache.http.util.EntityUtils;
|
import org.apache.http.util.EntityUtils;
|
||||||
import weaver.xiao.commons.exception.RequestException;
|
import weaver.xiao.commons.exception.RequestException;
|
||||||
import weaver.zwl.common.ToolUtil;
|
import weaver.zwl.common.ToolUtil;
|
||||||
import weaver.wechat.request.HttpManager;
|
import weaver.wechat.request.HttpManager;
|
||||||
|
|
||||||
import javax.ws.rs.core.MediaType;
|
import javax.ws.rs.core.MediaType;
|
||||||
import java.io.IOException;
|
import java.io.IOException;
|
||||||
import java.io.InputStream;
|
import java.io.InputStream;
|
||||||
import java.io.PrintWriter;
|
import java.io.PrintWriter;
|
||||||
import java.io.StringWriter;
|
import java.io.StringWriter;
|
||||||
import java.nio.charset.StandardCharsets;
|
import java.nio.charset.StandardCharsets;
|
||||||
import java.util.Map;
|
import java.util.Map;
|
||||||
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @author XiaoBokang
|
* @author XiaoBokang
|
||||||
* @create 2021/8/9 10:09
|
* @create 2021/8/9 10:09
|
||||||
*/
|
*/
|
||||||
|
|
||||||
public class RequestUtil {
|
public class RequestUtil {
|
||||||
|
|
||||||
public static <T> T apiRequest(RequestBaseInfo requestInfo, Class<T> tClass){
|
public static <T> T apiRequest(RequestBaseInfo requestInfo, Class<T> tClass){
|
||||||
|
|
||||||
Map<String,String> headers = requestInfo.getHeaders();
|
Map<String,String> headers = requestInfo.getHeaders();
|
||||||
T result = null;
|
T result = null;
|
||||||
|
|
||||||
switch(requestInfo.getType()){
|
switch(requestInfo.getType()){
|
||||||
case "GET" :{
|
case "GET" :{
|
||||||
String sendUrl = serializableUrl(requestInfo.getUrl(), (Map<String, Object>) requestInfo.getParams());
|
String sendUrl = serializableUrl(requestInfo.getUrl(), (Map<String, Object>) requestInfo.getParams());
|
||||||
HttpGet httpGet = new HttpGet(sendUrl);
|
HttpGet httpGet = new HttpGet(sendUrl);
|
||||||
headers.forEach(httpGet::setHeader);
|
headers.forEach(httpGet::setHeader);
|
||||||
result = apiSend(httpGet,tClass);
|
result = apiSend(httpGet,tClass);
|
||||||
}break;
|
}break;
|
||||||
case "POST" :{
|
case "POST" :{
|
||||||
HttpPost httpPost = new HttpPost(requestInfo.getUrl());
|
HttpPost httpPost = new HttpPost(requestInfo.getUrl());
|
||||||
headers.forEach(httpPost::setHeader);
|
headers.forEach(httpPost::setHeader);
|
||||||
httpPost.setEntity(new StringEntity(JSON.toJSONString(requestInfo.getParams()),"UTF-8"));
|
httpPost.setEntity(new StringEntity(JSON.toJSONString(requestInfo.getParams()),"UTF-8"));
|
||||||
new ToolUtil().writeErrorLog("请求信息:url:"+requestInfo.getUrl()+" params:"+JSON.toJSONString(requestInfo.getParams()));
|
new ToolUtil().writeErrorLog("请求信息:url:"+requestInfo.getUrl()+" params:"+JSON.toJSONString(requestInfo.getParams()));
|
||||||
result = apiSend(httpPost,tClass);}break;
|
result = apiSend(httpPost,tClass);}break;
|
||||||
case "PUT" :{
|
case "PUT" :{
|
||||||
HttpPut httpPut = new HttpPut(requestInfo.getUrl());
|
HttpPut httpPut = new HttpPut(requestInfo.getUrl());
|
||||||
headers.forEach(httpPut::setHeader);
|
headers.forEach(httpPut::setHeader);
|
||||||
httpPut.setEntity(new StringEntity(JSON.toJSONString(requestInfo.getParams()),"UTF-8"));
|
httpPut.setEntity(new StringEntity(JSON.toJSONString(requestInfo.getParams()),"UTF-8"));
|
||||||
result = apiSend(httpPut,tClass);}break;
|
result = apiSend(httpPut,tClass);}break;
|
||||||
}
|
}
|
||||||
|
|
||||||
return result;
|
return result;
|
||||||
}
|
}
|
||||||
|
|
||||||
public static <T> T POSTBySerializableUrl(RequestBaseInfo requestInfo, Class<T> tClass){
|
public static <T> T POSTBySerializableUrl(RequestBaseInfo requestInfo, Class<T> tClass){
|
||||||
T result = null;
|
T result = null;
|
||||||
Map<String,String> headers = requestInfo.getHeaders();
|
Map<String,String> headers = requestInfo.getHeaders();
|
||||||
String url = serializableUrl(requestInfo.getUrl(), (Map<String, Object>) requestInfo.getParams());
|
String url = serializableUrl(requestInfo.getUrl(), (Map<String, Object>) requestInfo.getParams());
|
||||||
HttpPost httpPost = new HttpPost(url);
|
HttpPost httpPost = new HttpPost(url);
|
||||||
headers.forEach(httpPost::setHeader);
|
headers.forEach(httpPost::setHeader);
|
||||||
new ToolUtil().writeErrorLog("请求信息:url:"+requestInfo.getUrl()+" params:"+JSON.toJSONString(requestInfo.getParams()));
|
new ToolUtil().writeErrorLog("请求信息:url:"+requestInfo.getUrl()+" params:"+JSON.toJSONString(requestInfo.getParams()));
|
||||||
result = apiSend(httpPost,tClass);
|
result = apiSend(httpPost,tClass);
|
||||||
return result;
|
return result;
|
||||||
}
|
}
|
||||||
|
|
||||||
public static <T> T apiUploadFileByInputStream(RequestBaseInfo requestInfo, Class<T> tClass){
|
public static <T> T apiUploadFileByInputStream(RequestBaseInfo requestInfo, Class<T> tClass){
|
||||||
Map<String,Object> params = (Map<String, Object>) requestInfo.getParams();
|
Map<String,Object> params = (Map<String, Object>) requestInfo.getParams();
|
||||||
HttpPost httpPost = new HttpPost(requestInfo.getUrl());
|
HttpPost httpPost = new HttpPost(requestInfo.getUrl());
|
||||||
requestInfo.getHeaders().forEach(httpPost::setHeader);
|
requestInfo.getHeaders().forEach(httpPost::setHeader);
|
||||||
MultipartEntityBuilder builder = MultipartEntityBuilder.create();
|
MultipartEntityBuilder builder = MultipartEntityBuilder.create();
|
||||||
builder.setCharset(StandardCharsets.UTF_8);
|
builder.setCharset(StandardCharsets.UTF_8);
|
||||||
builder.setMode(HttpMultipartMode.BROWSER_COMPATIBLE);
|
builder.setMode(HttpMultipartMode.BROWSER_COMPATIBLE);
|
||||||
InputStream[] inputStreams = requestInfo.getInputStreams();
|
InputStream[] inputStreams = requestInfo.getInputStreams();
|
||||||
String[] fileNames = requestInfo.getFileNames();
|
String[] fileNames = requestInfo.getFileNames();
|
||||||
for (int i = 0; i < inputStreams.length; i++) {
|
for (int i = 0; i < inputStreams.length; i++) {
|
||||||
builder.addBinaryBody(requestInfo.getFileField(),inputStreams[i],ContentType.MULTIPART_FORM_DATA,fileNames[i]);
|
builder.addBinaryBody(requestInfo.getFileField(),inputStreams[i],ContentType.MULTIPART_FORM_DATA,fileNames[i]);
|
||||||
}
|
}
|
||||||
params.forEach((k,v)->{
|
params.forEach((k,v)->{
|
||||||
builder.addTextBody(k,JSON.toJSONString(v),ContentType.create(MediaType.TEXT_PLAIN,"UTF-8"));
|
builder.addTextBody(k,JSON.toJSONString(v),ContentType.create(MediaType.TEXT_PLAIN,"UTF-8"));
|
||||||
});
|
});
|
||||||
HttpEntity entity = builder.build();
|
HttpEntity entity = builder.build();
|
||||||
httpPost.setEntity(entity);
|
httpPost.setEntity(entity);
|
||||||
return apiSend(httpPost,tClass);
|
return apiSend(httpPost,tClass);
|
||||||
}
|
}
|
||||||
|
|
||||||
public static <T> T apiSend(
|
public static <T> T apiSend(
|
||||||
HttpUriRequest httpRequest,
|
HttpUriRequest httpRequest,
|
||||||
Class<T> resClass
|
Class<T> resClass
|
||||||
){
|
){
|
||||||
DefaultHttpClient httpClient = HttpManager.getHttpClient();
|
DefaultHttpClient httpClient = HttpManager.getHttpClient();
|
||||||
CloseableHttpResponse execute = null;
|
CloseableHttpResponse execute = null;
|
||||||
T res = null;
|
T res = null;
|
||||||
try {
|
try {
|
||||||
new ToolUtil().writeDebuggerLog("开始发送请求:request start -----------------");
|
new ToolUtil().writeDebuggerLog("开始发送请求:request start -----------------");
|
||||||
execute = httpClient.execute(httpRequest);
|
execute = httpClient.execute(httpRequest);
|
||||||
if(execute.getStatusLine().getStatusCode() == 200){
|
if(execute.getStatusLine().getStatusCode() == 200){
|
||||||
new ToolUtil().writeDebuggerLog("请求发送成功:request send success -----------------");
|
new ToolUtil().writeDebuggerLog("请求发送成功:request send success -----------------");
|
||||||
HttpEntity entity = execute.getEntity();
|
HttpEntity entity = execute.getEntity();
|
||||||
String response= EntityUtils.toString(entity,"utf-8");
|
String response= EntityUtils.toString(entity,"utf-8");
|
||||||
// ObjectMapper mapper = new ObjectMapper();
|
// ObjectMapper mapper = new ObjectMapper();
|
||||||
// CollectionType listType = mapper.getTypeFactory().constructCollectionType(ArrayList.class, Map.class);
|
// CollectionType listType = mapper.getTypeFactory().constructCollectionType(ArrayList.class, Map.class);
|
||||||
// List<Map<String,Object>> list = mapper.readValue(response, listType);
|
// List<Map<String,Object>> list = mapper.readValue(response, listType);
|
||||||
// result.put("res",list);
|
// result.put("res",list);
|
||||||
if(resClass.equals(String.class)){
|
if(resClass.equals(String.class)){
|
||||||
return (T) response;
|
return (T) response;
|
||||||
}else {
|
}else {
|
||||||
ObjectMapper objectMapper = new ObjectMapper();
|
ObjectMapper objectMapper = new ObjectMapper();
|
||||||
res = objectMapper.readValue(response, resClass);
|
res = objectMapper.readValue(response, resClass);
|
||||||
}
|
}
|
||||||
}else {
|
}else {
|
||||||
HttpEntity entity = execute.getEntity();
|
HttpEntity entity = execute.getEntity();
|
||||||
String response = EntityUtils.toString(entity,"utf-8");
|
String response = EntityUtils.toString(entity,"utf-8");
|
||||||
new ToolUtil().writeDebuggerLog("请求状态不为200,返回信息为:"+response);
|
new ToolUtil().writeDebuggerLog("请求状态不为200,返回信息为:"+response);
|
||||||
throw new RequestException("请求状态异常:"+response);
|
throw new RequestException("请求状态异常:"+response);
|
||||||
}
|
}
|
||||||
} catch (IOException e) {
|
} catch (IOException e) {
|
||||||
new ToolUtil().writeDebuggerLog("请求发生异常 request error>>>"+e);
|
new ToolUtil().writeDebuggerLog("请求发生异常 request error>>>"+e);
|
||||||
try {
|
try {
|
||||||
if(execute != null) {
|
if(execute != null) {
|
||||||
execute.close();
|
execute.close();
|
||||||
}
|
}
|
||||||
} catch (IOException ioException) {
|
} catch (IOException ioException) {
|
||||||
ioException.printStackTrace();
|
ioException.printStackTrace();
|
||||||
}
|
}
|
||||||
e.printStackTrace();
|
e.printStackTrace();
|
||||||
throw new RequestException("请求调用异常:"+e);
|
throw new RequestException("请求调用异常:"+e);
|
||||||
}
|
}
|
||||||
return res;
|
return res;
|
||||||
}
|
}
|
||||||
|
|
||||||
public static String serializableUrl(String url,Map<String,Object> params){
|
public static String serializableUrl(String url,Map<String,Object> params){
|
||||||
if(params == null || params.isEmpty()){
|
if(params == null || params.isEmpty()){
|
||||||
return url;
|
return url;
|
||||||
}
|
}
|
||||||
url += "?";
|
url += "?";
|
||||||
for (Map.Entry entry: params.entrySet()){
|
for (Map.Entry entry: params.entrySet()){
|
||||||
url += entry.getKey() + "=" + entry.getValue() + "&";
|
url += entry.getKey() + "=" + entry.getValue() + "&";
|
||||||
}
|
}
|
||||||
return url.substring(0,url.length()-1);
|
return url.substring(0,url.length()-1);
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* 获取堆栈中的异常信息
|
* 获取堆栈中的异常信息
|
||||||
* @param throwable 异常
|
* @param throwable 异常
|
||||||
* @return
|
* @return
|
||||||
*/
|
*/
|
||||||
public static String getExceptionStr(Throwable throwable){
|
public static String getExceptionStr(Throwable throwable){
|
||||||
StringWriter stringWriter = new StringWriter();
|
StringWriter stringWriter = new StringWriter();
|
||||||
throwable.printStackTrace(new PrintWriter(stringWriter,true));
|
throwable.printStackTrace(new PrintWriter(stringWriter,true));
|
||||||
String s = stringWriter.getBuffer().toString();
|
String s = stringWriter.getBuffer().toString();
|
||||||
try{
|
try{
|
||||||
stringWriter.close();
|
stringWriter.close();
|
||||||
}catch (Exception ignored){
|
}catch (Exception ignored){
|
||||||
ignored.printStackTrace();
|
ignored.printStackTrace();
|
||||||
}
|
}
|
||||||
return s;
|
return s;
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -1,260 +1,260 @@
|
||||||
package weaver.xiao.commons.utils;
|
package weaver.xiao.commons.utils;
|
||||||
|
|
||||||
import org.apache.log4j.Logger;
|
import org.apache.log4j.Logger;
|
||||||
import weaver.conn.RecordSet;
|
import weaver.conn.RecordSet;
|
||||||
import weaver.formmode.data.ModeDataIdUpdate;
|
import weaver.formmode.data.ModeDataIdUpdate;
|
||||||
import weaver.formmode.setup.ModeRightInfo;
|
import weaver.formmode.setup.ModeRightInfo;
|
||||||
import weaver.general.TimeUtil;
|
import weaver.general.TimeUtil;
|
||||||
import weaver.general.Util;
|
import weaver.general.Util;
|
||||||
import weaver.xiao.commons.utils.annotation.SqlFieldMapping;
|
import weaver.xiao.commons.utils.annotation.SqlFieldMapping;
|
||||||
|
|
||||||
|
|
||||||
import java.lang.reflect.Field;
|
import java.lang.reflect.Field;
|
||||||
import java.util.*;
|
import java.util.*;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @author XiaoBokang
|
* @author XiaoBokang
|
||||||
* @create 2021/12/7 14:19
|
* @create 2021/12/7 14:19
|
||||||
*/
|
*/
|
||||||
|
|
||||||
public class SqlUtil {
|
public class SqlUtil {
|
||||||
|
|
||||||
private final Logger logger = LogUtil.getSqlLogger();
|
private final Logger logger = LogUtil.getSqlLogger();
|
||||||
ModeDataIdUpdate mdu = ModeDataIdUpdate.getInstance();
|
ModeDataIdUpdate mdu = ModeDataIdUpdate.getInstance();
|
||||||
ModeRightInfo mri = new ModeRightInfo();
|
ModeRightInfo mri = new ModeRightInfo();
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* 通过列名将数据库结果集转换成指定的实体类
|
* 通过列名将数据库结果集转换成指定的实体类
|
||||||
* @param recordSet 数据库结果集
|
* @param recordSet 数据库结果集
|
||||||
* @param tClass 实体类文件
|
* @param tClass 实体类文件
|
||||||
* @param <T> 泛型
|
* @param <T> 泛型
|
||||||
* @return
|
* @return
|
||||||
*/
|
*/
|
||||||
public <T> T recordSetToEntityByEntity(RecordSet recordSet, Class<T> tClass){
|
public <T> T recordSetToEntityByEntity(RecordSet recordSet, Class<T> tClass){
|
||||||
T res = null;
|
T res = null;
|
||||||
try{
|
try{
|
||||||
String[] columnNames = recordSet.getColumnName();
|
String[] columnNames = recordSet.getColumnName();
|
||||||
if(tClass.equals(Map.class)){
|
if(tClass.equals(Map.class)){
|
||||||
Map<String,Object> tempRes = new HashMap<>();
|
Map<String,Object> tempRes = new HashMap<>();
|
||||||
for (String columnName : columnNames) {
|
for (String columnName : columnNames) {
|
||||||
tempRes.put(columnName,recordSet.getString(columnName));
|
tempRes.put(columnName,recordSet.getString(columnName));
|
||||||
}
|
}
|
||||||
res = (T) tempRes;
|
res = (T) tempRes;
|
||||||
}else {
|
}else {
|
||||||
Field[] declaredFields = tClass.getDeclaredFields();
|
Field[] declaredFields = tClass.getDeclaredFields();
|
||||||
res = tClass.newInstance();
|
res = tClass.newInstance();
|
||||||
for (Field field : declaredFields) {
|
for (Field field : declaredFields) {
|
||||||
field.setAccessible(true);
|
field.setAccessible(true);
|
||||||
SqlFieldMapping annotation = field.getAnnotation(SqlFieldMapping.class);
|
SqlFieldMapping annotation = field.getAnnotation(SqlFieldMapping.class);
|
||||||
Class<?> fieldType = field.getType();
|
Class<?> fieldType = field.getType();
|
||||||
if(annotation != null){
|
if(annotation != null){
|
||||||
String value = annotation.value();
|
String value = annotation.value();
|
||||||
int type = annotation.type();
|
int type = annotation.type();
|
||||||
Object valueText = null;
|
Object valueText = null;
|
||||||
switch (type){
|
switch (type){
|
||||||
case 1:{
|
case 1:{
|
||||||
String tempValue = Util.null2String(recordSet.getString(value));
|
String tempValue = Util.null2String(recordSet.getString(value));
|
||||||
valueText = this.getFieldVal(fieldType,tempValue);
|
valueText = this.getFieldVal(fieldType,tempValue);
|
||||||
}break;
|
}break;
|
||||||
case 2:{
|
case 2:{
|
||||||
valueText = this.getFieldVal(fieldType,value);
|
valueText = this.getFieldVal(fieldType,value);
|
||||||
}break;
|
}break;
|
||||||
}
|
}
|
||||||
field.set(res,valueText);
|
field.set(res,valueText);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}catch (Exception e){
|
}catch (Exception e){
|
||||||
logger.info("转换实体类异常:"+e);
|
logger.info("转换实体类异常:"+e);
|
||||||
}
|
}
|
||||||
return res;
|
return res;
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* 通过字段类型获取字段的值
|
* 通过字段类型获取字段的值
|
||||||
* @param fieldType 字段类型
|
* @param fieldType 字段类型
|
||||||
* @param tempValue 转换前的字符串值
|
* @param tempValue 转换前的字符串值
|
||||||
* @return
|
* @return
|
||||||
*/
|
*/
|
||||||
public Object getFieldVal(Class<?> fieldType,String tempValue){
|
public Object getFieldVal(Class<?> fieldType,String tempValue){
|
||||||
Object fieldVal = null;
|
Object fieldVal = null;
|
||||||
if(fieldType.equals(int.class)){
|
if(fieldType.equals(int.class)){
|
||||||
fieldVal = Util.getIntValue(tempValue);
|
fieldVal = Util.getIntValue(tempValue);
|
||||||
}else if(fieldType.equals(String.class)){
|
}else if(fieldType.equals(String.class)){
|
||||||
fieldVal = Util.null2String(tempValue);
|
fieldVal = Util.null2String(tempValue);
|
||||||
}else if(fieldType.equals(boolean.class)){
|
}else if(fieldType.equals(boolean.class)){
|
||||||
fieldVal = Boolean.parseBoolean(tempValue);
|
fieldVal = Boolean.parseBoolean(tempValue);
|
||||||
}else {
|
}else {
|
||||||
fieldVal = "";
|
fieldVal = "";
|
||||||
}
|
}
|
||||||
return fieldVal;
|
return fieldVal;
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* 构建更新语句
|
* 构建更新语句
|
||||||
* @param tableName 表名
|
* @param tableName 表名
|
||||||
* @param updateParam 更新参数
|
* @param updateParam 更新参数
|
||||||
* @param whereParam 条件参数
|
* @param whereParam 条件参数
|
||||||
* @return
|
* @return
|
||||||
*/
|
*/
|
||||||
public boolean updateMode(String tableName, Map<String, Object> updateParam, Map<String, Object> whereParam) {
|
public boolean updateMode(String tableName, Map<String, Object> updateParam, Map<String, Object> whereParam) {
|
||||||
RecordSet recordSet = new RecordSet();
|
RecordSet recordSet = new RecordSet();
|
||||||
List<Object> paramList = new ArrayList<>();
|
List<Object> paramList = new ArrayList<>();
|
||||||
String updateSql = buildUpdateSql(tableName, updateParam, whereParam, paramList);
|
String updateSql = buildUpdateSql(tableName, updateParam, whereParam, paramList);
|
||||||
logger.info("向表"+tableName+"更新数据>>>" + updateSql + " param:" + paramList);
|
logger.info("向表"+tableName+"更新数据>>>" + updateSql + " param:" + paramList);
|
||||||
boolean updateFlag = recordSet.executeUpdate(updateSql, paramList);
|
boolean updateFlag = recordSet.executeUpdate(updateSql, paramList);
|
||||||
logger.info("更新标识:" + updateFlag);
|
logger.info("更新标识:" + updateFlag);
|
||||||
return updateFlag;
|
return updateFlag;
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* 构建更新sql语句,收集参数信息
|
* 构建更新sql语句,收集参数信息
|
||||||
* @param tableName 表名
|
* @param tableName 表名
|
||||||
* @param updateParam 更新参数
|
* @param updateParam 更新参数
|
||||||
* @param whereParam 条件参数
|
* @param whereParam 条件参数
|
||||||
* @param paramList 参数集合
|
* @param paramList 参数集合
|
||||||
* @return
|
* @return
|
||||||
*/
|
*/
|
||||||
public String buildUpdateSql(String tableName, Map<String, Object> updateParam, Map<String, Object> whereParam,List<Object> paramList){
|
public String buildUpdateSql(String tableName, Map<String, Object> updateParam, Map<String, Object> whereParam,List<Object> paramList){
|
||||||
StringBuilder updateBuilder = new StringBuilder("update ");
|
StringBuilder updateBuilder = new StringBuilder("update ");
|
||||||
updateBuilder.append(tableName).append(" set ");
|
updateBuilder.append(tableName).append(" set ");
|
||||||
Set<Map.Entry<String, Object>> updateEntries = updateParam.entrySet();
|
Set<Map.Entry<String, Object>> updateEntries = updateParam.entrySet();
|
||||||
for (Map.Entry<String, Object> updateEntry : updateEntries) {
|
for (Map.Entry<String, Object> updateEntry : updateEntries) {
|
||||||
updateBuilder.append(updateEntry.getKey())
|
updateBuilder.append(updateEntry.getKey())
|
||||||
.append(" = ?,");
|
.append(" = ?,");
|
||||||
paramList.add(updateEntry.getValue());
|
paramList.add(updateEntry.getValue());
|
||||||
}
|
}
|
||||||
StringBuilder whereBuilder = new StringBuilder();
|
StringBuilder whereBuilder = new StringBuilder();
|
||||||
Set<Map.Entry<String, Object>> whereEntries = whereParam.entrySet();
|
Set<Map.Entry<String, Object>> whereEntries = whereParam.entrySet();
|
||||||
for (Map.Entry<String, Object> whereEntry : whereEntries) {
|
for (Map.Entry<String, Object> whereEntry : whereEntries) {
|
||||||
whereBuilder.append(" and ")
|
whereBuilder.append(" and ")
|
||||||
.append(whereEntry.getKey())
|
.append(whereEntry.getKey())
|
||||||
.append(" = ? ");
|
.append(" = ? ");
|
||||||
paramList.add(whereEntry.getValue());
|
paramList.add(whereEntry.getValue());
|
||||||
}
|
}
|
||||||
String preStr = updateBuilder.substring(0, updateBuilder.length() - 1) + " ";
|
String preStr = updateBuilder.substring(0, updateBuilder.length() - 1) + " ";
|
||||||
String fixStr = whereBuilder.toString();
|
String fixStr = whereBuilder.toString();
|
||||||
if(!"".equals(fixStr)){
|
if(!"".equals(fixStr)){
|
||||||
fixStr = fixStr.replaceFirst(" and "," where ");
|
fixStr = fixStr.replaceFirst(" and "," where ");
|
||||||
}
|
}
|
||||||
return preStr + fixStr;
|
return preStr + fixStr;
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* 向表插入数据
|
* 向表插入数据
|
||||||
* @param tableName 表名
|
* @param tableName 表名
|
||||||
* @param insertParam 插入参数
|
* @param insertParam 插入参数
|
||||||
* @return
|
* @return
|
||||||
*/
|
*/
|
||||||
public boolean insertTable(String tableName, Map<String, Object> insertParam) {
|
public boolean insertTable(String tableName, Map<String, Object> insertParam) {
|
||||||
RecordSet recordSet = new RecordSet();
|
RecordSet recordSet = new RecordSet();
|
||||||
//构建新建sql语句,收集参数信息
|
//构建新建sql语句,收集参数信息
|
||||||
List<Object> paramList = new ArrayList<>();
|
List<Object> paramList = new ArrayList<>();
|
||||||
String insertSql = buildInsetSql(tableName, insertParam, paramList);
|
String insertSql = buildInsetSql(tableName, insertParam, paramList);
|
||||||
logger.info("向表"+tableName+"插入数据>>>" + insertSql + " param:" + paramList);
|
logger.info("向表"+tableName+"插入数据>>>" + insertSql + " param:" + paramList);
|
||||||
boolean flag = recordSet.executeUpdate(insertSql, paramList);
|
boolean flag = recordSet.executeUpdate(insertSql, paramList);
|
||||||
logger.info("插入标识:" + flag);
|
logger.info("插入标识:" + flag);
|
||||||
return flag;
|
return flag;
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* 构建新建sql语句,收集参数信息
|
* 构建新建sql语句,收集参数信息
|
||||||
* @param tableName 表名
|
* @param tableName 表名
|
||||||
* @param insertParam 插入参数
|
* @param insertParam 插入参数
|
||||||
* @param paramList 返回数据集合
|
* @param paramList 返回数据集合
|
||||||
* @return
|
* @return
|
||||||
*/
|
*/
|
||||||
public String buildInsetSql(String tableName, Map<String, Object> insertParam,List<Object> paramList){
|
public String buildInsetSql(String tableName, Map<String, Object> insertParam,List<Object> paramList){
|
||||||
StringBuilder suffixBuilder = new StringBuilder();
|
StringBuilder suffixBuilder = new StringBuilder();
|
||||||
StringBuilder prefixBuilder = new StringBuilder();
|
StringBuilder prefixBuilder = new StringBuilder();
|
||||||
prefixBuilder.append("insert into ")
|
prefixBuilder.append("insert into ")
|
||||||
.append(tableName).append("(");
|
.append(tableName).append("(");
|
||||||
suffixBuilder.append(" values (");
|
suffixBuilder.append(" values (");
|
||||||
Set<Map.Entry<String, Object>> entries = insertParam.entrySet();
|
Set<Map.Entry<String, Object>> entries = insertParam.entrySet();
|
||||||
for (Map.Entry<String, Object> entry : entries) {
|
for (Map.Entry<String, Object> entry : entries) {
|
||||||
String key = entry.getKey();
|
String key = entry.getKey();
|
||||||
Object value = entry.getValue();
|
Object value = entry.getValue();
|
||||||
prefixBuilder.append(key).append(",");
|
prefixBuilder.append(key).append(",");
|
||||||
suffixBuilder.append("?,");
|
suffixBuilder.append("?,");
|
||||||
paramList.add(value);
|
paramList.add(value);
|
||||||
}
|
}
|
||||||
String suffixString = suffixBuilder.substring(0, suffixBuilder.length() - 1);
|
String suffixString = suffixBuilder.substring(0, suffixBuilder.length() - 1);
|
||||||
String prefixString = prefixBuilder.substring(0, prefixBuilder.length() - 1);
|
String prefixString = prefixBuilder.substring(0, prefixBuilder.length() - 1);
|
||||||
String insertSql = prefixString + ")" + suffixString+")";
|
String insertSql = prefixString + ")" + suffixString+")";
|
||||||
return insertSql;
|
return insertSql;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* 将接口调用信息插入至建模中
|
* 将接口调用信息插入至建模中
|
||||||
* @param tableName 表名
|
* @param tableName 表名
|
||||||
* @param param 插入信息
|
* @param param 插入信息
|
||||||
* @param modeId 模块id
|
* @param modeId 模块id
|
||||||
* @return
|
* @return
|
||||||
*/
|
*/
|
||||||
public int insertToMode(String tableName,Map<String,Object> param,String modeId){
|
public int insertToMode(String tableName,Map<String,Object> param,String modeId){
|
||||||
logger.info("=====插入建模信息====");
|
logger.info("=====插入建模信息====");
|
||||||
if(modeId == null || "".equals(modeId)) {
|
if(modeId == null || "".equals(modeId)) {
|
||||||
modeId = this.getModeIdByTableName(tableName);
|
modeId = this.getModeIdByTableName(tableName);
|
||||||
}
|
}
|
||||||
logger.info("通过表名获取modeId ==>modeId"+modeId+" tableName==>"+tableName);
|
logger.info("通过表名获取modeId ==>modeId"+modeId+" tableName==>"+tableName);
|
||||||
Map<String,Object> whereParam = new HashMap<>();
|
Map<String,Object> whereParam = new HashMap<>();
|
||||||
int dataId = mdu.getModeDataNewId(tableName, Util.getIntValue(modeId,-1), 1, 0, TimeUtil.getCurrentDateString(), TimeUtil.getOnlyCurrentTimeString());
|
int dataId = mdu.getModeDataNewId(tableName, Util.getIntValue(modeId,-1), 1, 0, TimeUtil.getCurrentDateString(), TimeUtil.getOnlyCurrentTimeString());
|
||||||
whereParam.put("id",dataId);
|
whereParam.put("id",dataId);
|
||||||
boolean updateFlag = this.updateMode(tableName, param, whereParam);
|
boolean updateFlag = this.updateMode(tableName, param, whereParam);
|
||||||
if(updateFlag){
|
if(updateFlag){
|
||||||
mri.rebuildModeDataShareByEdit(1, Util.getIntValue(modeId,-1),dataId);
|
mri.rebuildModeDataShareByEdit(1, Util.getIntValue(modeId,-1),dataId);
|
||||||
}else {
|
}else {
|
||||||
logger.info("更新失败,从表==>"+tableName+" 删除数据:"+dataId);
|
logger.info("更新失败,从表==>"+tableName+" 删除数据:"+dataId);
|
||||||
String deleteSql = "delete from "+tableName+" where id = ?";
|
String deleteSql = "delete from "+tableName+" where id = ?";
|
||||||
RecordSet deleteRecordSet = new RecordSet();
|
RecordSet deleteRecordSet = new RecordSet();
|
||||||
deleteRecordSet.executeUpdate(deleteSql,dataId);
|
deleteRecordSet.executeUpdate(deleteSql,dataId);
|
||||||
}
|
}
|
||||||
return dataId;
|
return dataId;
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* 将接口调用信息插入至建模中不做权限重构
|
* 将接口调用信息插入至建模中不做权限重构
|
||||||
* @param tableName 表名
|
* @param tableName 表名
|
||||||
* @param param 插入信息
|
* @param param 插入信息
|
||||||
* @param modeId 模块id
|
* @param modeId 模块id
|
||||||
* @return
|
* @return
|
||||||
*/
|
*/
|
||||||
public int insertToModeNoRight(String tableName,Map<String,Object> param,String modeId){
|
public int insertToModeNoRight(String tableName,Map<String,Object> param,String modeId){
|
||||||
logger.info("=====插入建模信息====");
|
logger.info("=====插入建模信息====");
|
||||||
if(modeId == null || "".equals(modeId)) {
|
if(modeId == null || "".equals(modeId)) {
|
||||||
modeId = this.getModeIdByTableName(tableName);
|
modeId = this.getModeIdByTableName(tableName);
|
||||||
}
|
}
|
||||||
logger.info("通过表名获取modeId ==>modeId"+modeId+" tableName==>"+tableName);
|
logger.info("通过表名获取modeId ==>modeId"+modeId+" tableName==>"+tableName);
|
||||||
Map<String,Object> whereParam = new HashMap<>();
|
Map<String,Object> whereParam = new HashMap<>();
|
||||||
int dataId = mdu.getModeDataNewId(tableName, Util.getIntValue(modeId,-1), 1, 0, TimeUtil.getCurrentDateString(), TimeUtil.getOnlyCurrentTimeString());
|
int dataId = mdu.getModeDataNewId(tableName, Util.getIntValue(modeId,-1), 1, 0, TimeUtil.getCurrentDateString(), TimeUtil.getOnlyCurrentTimeString());
|
||||||
whereParam.put("id",dataId);
|
whereParam.put("id",dataId);
|
||||||
boolean updateFlag = this.updateMode(tableName, param, whereParam);
|
boolean updateFlag = this.updateMode(tableName, param, whereParam);
|
||||||
if(updateFlag){
|
if(updateFlag){
|
||||||
return dataId;
|
return dataId;
|
||||||
}else {
|
}else {
|
||||||
logger.info("更新失败,从表==>"+tableName+" 删除数据:"+dataId);
|
logger.info("更新失败,从表==>"+tableName+" 删除数据:"+dataId);
|
||||||
String deleteSql = "delete from "+tableName+" where id = ?";
|
String deleteSql = "delete from "+tableName+" where id = ?";
|
||||||
RecordSet deleteRecordSet = new RecordSet();
|
RecordSet deleteRecordSet = new RecordSet();
|
||||||
deleteRecordSet.executeUpdate(deleteSql,dataId);
|
deleteRecordSet.executeUpdate(deleteSql,dataId);
|
||||||
}
|
}
|
||||||
return -1;
|
return -1;
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* 通过表名查询模块id
|
* 通过表名查询模块id
|
||||||
* @param tableName 表名
|
* @param tableName 表名
|
||||||
* @return
|
* @return
|
||||||
*/
|
*/
|
||||||
public String getModeIdByTableName(String tableName){
|
public String getModeIdByTableName(String tableName){
|
||||||
String modeId = "";
|
String modeId = "";
|
||||||
String querySql = "select id from modeinfo where formid = (select id from workflow_bill where tablename = ?)";
|
String querySql = "select id from modeinfo where formid = (select id from workflow_bill where tablename = ?)";
|
||||||
RecordSet recordSet = new RecordSet();
|
RecordSet recordSet = new RecordSet();
|
||||||
recordSet.executeQuery(querySql,tableName);
|
recordSet.executeQuery(querySql,tableName);
|
||||||
if(recordSet.next()){
|
if(recordSet.next()){
|
||||||
modeId = Util.null2String(recordSet.getString("id"));
|
modeId = Util.null2String(recordSet.getString("id"));
|
||||||
}
|
}
|
||||||
return modeId;
|
return modeId;
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -1,21 +1,21 @@
|
||||||
package weaver.xiao.commons.utils.annotation;
|
package weaver.xiao.commons.utils.annotation;
|
||||||
|
|
||||||
import java.lang.annotation.ElementType;
|
import java.lang.annotation.ElementType;
|
||||||
import java.lang.annotation.Retention;
|
import java.lang.annotation.Retention;
|
||||||
import java.lang.annotation.RetentionPolicy;
|
import java.lang.annotation.RetentionPolicy;
|
||||||
import java.lang.annotation.Target;
|
import java.lang.annotation.Target;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @author XiaoBokang
|
* @author XiaoBokang
|
||||||
* @create 2022/5/10 18:22
|
* @create 2022/5/10 18:22
|
||||||
*/
|
*/
|
||||||
|
|
||||||
@Target(ElementType.FIELD)
|
@Target(ElementType.FIELD)
|
||||||
@Retention(RetentionPolicy.RUNTIME)
|
@Retention(RetentionPolicy.RUNTIME)
|
||||||
public @interface SqlFieldMapping {
|
public @interface SqlFieldMapping {
|
||||||
/** 字段所属 1:数据库值,2:默认值 */
|
/** 字段所属 1:数据库值,2:默认值 */
|
||||||
int type() default 1;
|
int type() default 1;
|
||||||
/** 数据库字段名或默认值 */
|
/** 数据库字段名或默认值 */
|
||||||
String value();
|
String value();
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -6,7 +6,7 @@ import java.lang.annotation.RetentionPolicy;
|
||||||
import java.lang.annotation.Target;
|
import java.lang.annotation.Target;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* <h1></h1>
|
* <h1>自定义日期转换注解</h1>
|
||||||
*
|
*
|
||||||
* @Author xuanran.wang
|
* @Author xuanran.wang
|
||||||
* @Date 2022/11/25 15:55
|
* @Date 2022/11/25 15:55
|
||||||
|
@ -14,6 +14,12 @@ import java.lang.annotation.Target;
|
||||||
@Target({ElementType.FIELD,ElementType.TYPE})
|
@Target({ElementType.FIELD,ElementType.TYPE})
|
||||||
@Retention(RetentionPolicy.RUNTIME)
|
@Retention(RetentionPolicy.RUNTIME)
|
||||||
public @interface CusDateFormat {
|
public @interface CusDateFormat {
|
||||||
|
/**
|
||||||
|
* <h2>源格式</h2>
|
||||||
|
**/
|
||||||
String from();
|
String from();
|
||||||
|
/**
|
||||||
|
* <h2>目标格式</h2>
|
||||||
|
**/
|
||||||
String to() default "yyyy-MM-dd";
|
String to() default "yyyy-MM-dd";
|
||||||
}
|
}
|
||||||
|
|
|
@ -1,11 +1,9 @@
|
||||||
package weaver.xuanran.wang.common.mapper;
|
package weaver.xuanran.wang.common.mapper;
|
||||||
|
|
||||||
import aiyh.utils.annotation.recordset.Delete;
|
import aiyh.utils.annotation.recordset.*;
|
||||||
import aiyh.utils.annotation.recordset.ParamMapper;
|
|
||||||
import aiyh.utils.annotation.recordset.Select;
|
|
||||||
import aiyh.utils.annotation.recordset.SqlMapper;
|
|
||||||
|
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
|
import java.util.Map;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @Author xuanran.wang
|
* @Author xuanran.wang
|
||||||
|
@ -43,4 +41,13 @@ public interface CommonMapper {
|
||||||
@Delete("delete from $t{tableName} where id in (${ids})")
|
@Delete("delete from $t{tableName} where id in (${ids})")
|
||||||
boolean deleteModelDataByIds(@ParamMapper("tableName") String tableName,
|
boolean deleteModelDataByIds(@ParamMapper("tableName") String tableName,
|
||||||
@ParamMapper("ids") List<String> ids);
|
@ParamMapper("ids") List<String> ids);
|
||||||
|
|
||||||
|
@Select("SELECT mp.id,m.formId,mpd.triggerWorkflowSetId " +
|
||||||
|
"FROM MODE_PageExpand mp " +
|
||||||
|
"INNER JOIN modeInfo m " +
|
||||||
|
"on mp.modeId = m.id " +
|
||||||
|
"LEFT JOIN mode_pageExpandDetail mpd " +
|
||||||
|
"ON mp.id = mpd.mainId " +
|
||||||
|
"WHERE mp.modeid = #{modelId} AND mp.isSystem = 1 AND mp.iSSystemFlag = 1")
|
||||||
|
Map<String, Integer> getExpendConfigByModeId(@ParamMapper("modelId") int modelId);
|
||||||
}
|
}
|
||||||
|
|
|
@ -2,16 +2,24 @@ package weaver.xuanran.wang.common.util;
|
||||||
|
|
||||||
import aiyh.utils.Util;
|
import aiyh.utils.Util;
|
||||||
import aiyh.utils.excention.CustomerException;
|
import aiyh.utils.excention.CustomerException;
|
||||||
|
import com.alibaba.fastjson.JSONObject;
|
||||||
import org.apache.commons.collections.CollectionUtils;
|
import org.apache.commons.collections.CollectionUtils;
|
||||||
import org.apache.commons.collections.MapUtils;
|
import org.apache.commons.collections.MapUtils;
|
||||||
|
import org.apache.commons.io.FileUtils;
|
||||||
import org.apache.commons.lang3.StringUtils;
|
import org.apache.commons.lang3.StringUtils;
|
||||||
import org.apache.log4j.Logger;
|
import org.apache.log4j.Logger;
|
||||||
|
import weaver.conn.RecordSet;
|
||||||
|
import weaver.formmode.data.ModeDataApproval;
|
||||||
|
import weaver.hrm.User;
|
||||||
import weaver.xuanran.wang.common.annocation.CusDateFormat;
|
import weaver.xuanran.wang.common.annocation.CusDateFormat;
|
||||||
import weaver.xuanran.wang.common.annocation.ParamNotNull;
|
import weaver.xuanran.wang.common.annocation.ParamNotNull;
|
||||||
|
import weaver.xuanran.wang.common.mapper.CommonMapper;
|
||||||
|
|
||||||
import java.io.*;
|
import java.io.*;
|
||||||
import java.lang.reflect.Field;
|
import java.lang.reflect.Field;
|
||||||
import java.nio.charset.Charset;
|
import java.nio.charset.Charset;
|
||||||
|
import java.nio.file.Files;
|
||||||
|
import java.nio.file.Paths;
|
||||||
import java.text.ParseException;
|
import java.text.ParseException;
|
||||||
import java.text.SimpleDateFormat;
|
import java.text.SimpleDateFormat;
|
||||||
import java.util.*;
|
import java.util.*;
|
||||||
|
@ -26,12 +34,26 @@ import java.util.zip.ZipFile;
|
||||||
* @Date 2022/11/23 10:25
|
* @Date 2022/11/23 10:25
|
||||||
*/
|
*/
|
||||||
public class CommonUtil {
|
public class CommonUtil {
|
||||||
|
/**
|
||||||
private final Logger logger = Util.getLogger();
|
* <h2>日志对象</h2>
|
||||||
|
**/
|
||||||
public static final int SQL_IN_PAGE_SIZE = 100;
|
private static final Logger logger = Util.getLogger(CommonUtil.class.getName());
|
||||||
|
/**
|
||||||
private static final SimpleDateFormat DATE_FORMAT = new SimpleDateFormat("yyyy-MM-dd");
|
* <h2>sql用in的时候分割集合大小</h2>
|
||||||
|
**/
|
||||||
|
public static int SQL_IN_PAGE_SIZE = 100;
|
||||||
|
/**
|
||||||
|
* <h2>最大删除次数</h2>
|
||||||
|
**/
|
||||||
|
public static int DEL_MAX_COUNT = 5;
|
||||||
|
/**
|
||||||
|
* <h2>线程睡眠时间</h2>
|
||||||
|
**/
|
||||||
|
public static int THREAD_SLEEP = 200;
|
||||||
|
/**
|
||||||
|
* <h2>通用工具mapper</h2>
|
||||||
|
**/
|
||||||
|
private static final CommonMapper commonMapper = Util.getMapper(CommonMapper.class);
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* <h1>将文件解压至指定文件夹中</h1>
|
* <h1>将文件解压至指定文件夹中</h1>
|
||||||
|
@ -47,6 +69,8 @@ public class CommonUtil {
|
||||||
}
|
}
|
||||||
// 开始解压
|
// 开始解压
|
||||||
ZipFile zipFile = null;
|
ZipFile zipFile = null;
|
||||||
|
InputStream is = null;
|
||||||
|
FileOutputStream fos = null;
|
||||||
try {
|
try {
|
||||||
zipFile = new ZipFile(new File(srcFilePath), Charset.forName("GBK"));
|
zipFile = new ZipFile(new File(srcFilePath), Charset.forName("GBK"));
|
||||||
Enumeration<?> entries = zipFile.entries();
|
Enumeration<?> entries = zipFile.entries();
|
||||||
|
@ -55,16 +79,25 @@ public class CommonUtil {
|
||||||
if (entry.isDirectory()) {
|
if (entry.isDirectory()) {
|
||||||
String dirPath = acceptFilePath + File.separator + entry.getName();
|
String dirPath = acceptFilePath + File.separator + entry.getName();
|
||||||
File dir = new File(dirPath);
|
File dir = new File(dirPath);
|
||||||
dir.mkdirs();
|
boolean mkdirs = dir.mkdirs();
|
||||||
|
if(!mkdirs){
|
||||||
|
throw new CustomerException("创建文件夹失败!, 文件夹路径:[ " + dirPath + " ]");
|
||||||
|
}
|
||||||
} else {
|
} else {
|
||||||
String temp = acceptFilePath + File.separator + entry.getName();
|
String temp = acceptFilePath + File.separator + entry.getName();
|
||||||
File targetFile = new File(temp);
|
File targetFile = new File(temp);
|
||||||
if(!targetFile.getParentFile().exists()){
|
if(!targetFile.getParentFile().exists()){
|
||||||
targetFile.getParentFile().mkdirs();
|
boolean mkdirs = targetFile.getParentFile().mkdirs();
|
||||||
|
if(!mkdirs){
|
||||||
|
throw new CustomerException("创建文件夹失败!, 文件夹路径:[ " + targetFile.getParentFile() + " ]");
|
||||||
|
}
|
||||||
}
|
}
|
||||||
targetFile.createNewFile();
|
boolean newFile = targetFile.createNewFile();
|
||||||
InputStream is = zipFile.getInputStream(entry);
|
if(!newFile){
|
||||||
FileOutputStream fos = new FileOutputStream(targetFile);
|
throw new CustomerException("创建文件失败!, 文件路径:[ " + temp + " ]");
|
||||||
|
}
|
||||||
|
is = zipFile.getInputStream(entry);
|
||||||
|
fos = new FileOutputStream(targetFile);
|
||||||
int len;
|
int len;
|
||||||
byte[] buf = new byte[1024];
|
byte[] buf = new byte[1024];
|
||||||
while ((len = is.read(buf)) != -1) {
|
while ((len = is.read(buf)) != -1) {
|
||||||
|
@ -85,6 +118,20 @@ public class CommonUtil {
|
||||||
e.printStackTrace();
|
e.printStackTrace();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
if(fos != null){
|
||||||
|
try {
|
||||||
|
fos.close();
|
||||||
|
} catch (IOException e) {
|
||||||
|
e.printStackTrace();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
if(is != null){
|
||||||
|
try {
|
||||||
|
is.close();
|
||||||
|
} catch (IOException e) {
|
||||||
|
e.printStackTrace();
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -102,14 +149,17 @@ public class CommonUtil {
|
||||||
File file = new File(filePath);
|
File file = new File(filePath);
|
||||||
BufferedReader reader = null;
|
BufferedReader reader = null;
|
||||||
StringBuilder builder = new StringBuilder();
|
StringBuilder builder = new StringBuilder();
|
||||||
|
FileReader fileReader = null;
|
||||||
try {
|
try {
|
||||||
reader = new BufferedReader(new FileReader(file));
|
fileReader = new FileReader(file);
|
||||||
|
reader = new BufferedReader(fileReader);
|
||||||
String tempString = null;
|
String tempString = null;
|
||||||
// 一次读入一行,直到读入null为文件结束
|
// 一次读入一行,直到读入null为文件结束
|
||||||
while ((tempString = reader.readLine()) != null) {
|
while ((tempString = reader.readLine()) != null) {
|
||||||
builder.append(tempString);
|
builder.append(tempString);
|
||||||
}
|
}
|
||||||
reader.close();
|
reader.close();
|
||||||
|
fileReader.close();
|
||||||
} catch (IOException e) {
|
} catch (IOException e) {
|
||||||
e.printStackTrace();
|
e.printStackTrace();
|
||||||
} finally {
|
} finally {
|
||||||
|
@ -117,6 +167,14 @@ public class CommonUtil {
|
||||||
try {
|
try {
|
||||||
reader.close();
|
reader.close();
|
||||||
} catch (IOException ie) {
|
} catch (IOException ie) {
|
||||||
|
logger.error("关闭io流异常, " + ie.getMessage());
|
||||||
|
}
|
||||||
|
}
|
||||||
|
if(fileReader != null){
|
||||||
|
try {
|
||||||
|
fileReader.close();
|
||||||
|
} catch (IOException ie) {
|
||||||
|
logger.error("关闭io流异常, " + ie.getMessage());
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -129,7 +187,7 @@ public class CommonUtil {
|
||||||
* @dateTime 2022/11/23 15:59
|
* @dateTime 2022/11/23 15:59
|
||||||
* @param t 需要判断的对象
|
* @param t 需要判断的对象
|
||||||
**/
|
**/
|
||||||
public static <T> void checkParamNotNull(T t) throws IllegalAccessException {
|
public static <T> void checkParamNotNull(T t){
|
||||||
Class<?> clazz = t.getClass();
|
Class<?> clazz = t.getClass();
|
||||||
Field[] fields = clazz.getDeclaredFields();
|
Field[] fields = clazz.getDeclaredFields();
|
||||||
for (Field field : fields) {
|
for (Field field : fields) {
|
||||||
|
@ -138,7 +196,12 @@ public class CommonUtil {
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
field.setAccessible(true);
|
field.setAccessible(true);
|
||||||
Object value = field.get(t);
|
Object value = null;
|
||||||
|
try {
|
||||||
|
value = field.get(t);
|
||||||
|
}catch (IllegalAccessException e){
|
||||||
|
throw new CustomerException("获取类字段值异常: " + e.getMessage());
|
||||||
|
}
|
||||||
Class<?> valueClass = field.getType();
|
Class<?> valueClass = field.getType();
|
||||||
boolean isNull = false;
|
boolean isNull = false;
|
||||||
if(valueClass.isAssignableFrom(String.class)){
|
if(valueClass.isAssignableFrom(String.class)){
|
||||||
|
@ -180,8 +243,10 @@ public class CommonUtil {
|
||||||
return Stream.iterate(0, n -> n + 1)
|
return Stream.iterate(0, n -> n + 1)
|
||||||
.limit(maxSize)
|
.limit(maxSize)
|
||||||
.parallel()
|
.parallel()
|
||||||
.map(a -> list.parallelStream().skip((long) a * splitSize).limit(splitSize).collect(Collectors.toList()))
|
.map(a -> list.parallelStream()
|
||||||
.filter(b -> !b.isEmpty())
|
.skip((long) a * splitSize).limit(splitSize)
|
||||||
|
.collect(Collectors.toList())
|
||||||
|
).filter(b -> !b.isEmpty())
|
||||||
.collect(Collectors.toList());
|
.collect(Collectors.toList());
|
||||||
}
|
}
|
||||||
/**
|
/**
|
||||||
|
@ -213,4 +278,245 @@ public class CommonUtil {
|
||||||
throw new RuntimeException(Util.logStr("解析日期失败!当前传入转化格式:[{}],待转化日期:[{}]", to, date));
|
throw new RuntimeException(Util.logStr("解析日期失败!当前传入转化格式:[{}],待转化日期:[{}]", to, date));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* <h1>通过数据id删除数据</h1>
|
||||||
|
* @author xuanran.wang
|
||||||
|
* @dateTime 2022/11/28 12:07
|
||||||
|
* @param ids 数据集合
|
||||||
|
* @param tableName 表名
|
||||||
|
* @return true/false
|
||||||
|
**/
|
||||||
|
public static boolean deleteDataByIds(List<String> ids, String tableName) {
|
||||||
|
return deleteDataByIds(ids, tableName, SQL_IN_PAGE_SIZE);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* <h1>通过数据id删除数据</h1>
|
||||||
|
* @author xuanran.wang
|
||||||
|
* @dateTime 2022/11/28 12:07
|
||||||
|
* @param ids 数据id
|
||||||
|
* @param modelId 模块id
|
||||||
|
* @return true/false
|
||||||
|
**/
|
||||||
|
public static boolean deleteDataByIds(List<String> ids, int modelId) {
|
||||||
|
return deleteDataByIds(ids, modelId, SQL_IN_PAGE_SIZE);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* <h1>通过数据id删除数据</h1>
|
||||||
|
* @author xuanran.wang
|
||||||
|
* @dateTime 2022/11/28 12:07
|
||||||
|
* @param ids 数据集合
|
||||||
|
* @param modelId 模块id
|
||||||
|
* @param pageSize SQL in 分页大小
|
||||||
|
* @return true/false
|
||||||
|
**/
|
||||||
|
public static boolean deleteDataByIds(List<String> ids, int modelId, int pageSize) {
|
||||||
|
String tableName = commonMapper.getModelNameByModelId(String.valueOf(modelId));
|
||||||
|
if(StringUtils.isBlank(tableName)){
|
||||||
|
throw new CustomerException("模块id : " + modelId + ",表名在系统中没有找到!");
|
||||||
|
}
|
||||||
|
return deleteDataByIds(ids, tableName, pageSize);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* <h1>通过数据id删除数据</h1>
|
||||||
|
* @author xuanran.wang
|
||||||
|
* @dateTime 2022/11/28 12:08
|
||||||
|
* @param ids 数据id集合
|
||||||
|
* @param tableName 表名
|
||||||
|
* @param pageSize SQL in 分页大小
|
||||||
|
* @return true/false
|
||||||
|
**/
|
||||||
|
public static boolean deleteDataByIds(List<String> ids, String tableName,int pageSize) {
|
||||||
|
List<List<String>> lists = CommonUtil.splitList(ids, pageSize);
|
||||||
|
for (List<String> list : lists) {
|
||||||
|
boolean success = commonMapper.deleteModelDataByIds(tableName, list);
|
||||||
|
if(!success){
|
||||||
|
logger.error(Util.logStr("删除数据失败, 数据集合 : [{}] ", JSONObject.toJSONString(list)));
|
||||||
|
}
|
||||||
|
return success;
|
||||||
|
}
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* <h1>删除系统文件</h1>
|
||||||
|
* @author xuanran.wang
|
||||||
|
* @dateTime 2022/12/1 14:55
|
||||||
|
* @param path 文件路径
|
||||||
|
* @return 是否删除成功
|
||||||
|
**/
|
||||||
|
public static boolean delFile(String path) throws IOException {
|
||||||
|
File file = new File(path);
|
||||||
|
if(!file.exists()){
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
boolean deleteFlag = true;
|
||||||
|
int n = 0;
|
||||||
|
while (deleteFlag) {
|
||||||
|
try {
|
||||||
|
n++;
|
||||||
|
System.gc();
|
||||||
|
if(file.isDirectory()){
|
||||||
|
FileUtils.deleteDirectory(file);
|
||||||
|
}else {
|
||||||
|
Files.delete(Paths.get(path));
|
||||||
|
}
|
||||||
|
deleteFlag = false;
|
||||||
|
} catch (Exception e) {
|
||||||
|
try {
|
||||||
|
Thread.sleep(THREAD_SLEEP);
|
||||||
|
} catch (InterruptedException interruptedException) {
|
||||||
|
logger.info(Util.logStr("interruptedException : {}",interruptedException.getMessage()));
|
||||||
|
}
|
||||||
|
if (n > DEL_MAX_COUNT) {
|
||||||
|
deleteFlag = false;
|
||||||
|
logger.error("临时文件删除失败!路径: " + path);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* <h1>获取对象</h1>
|
||||||
|
* @author xuanran.wang
|
||||||
|
* @dateTime 2022/11/15 22:20
|
||||||
|
* @param map 查询结果集map
|
||||||
|
* @param clazz 返回类class
|
||||||
|
* @return 返回类对象
|
||||||
|
**/
|
||||||
|
public static <T> T getInstance(Map<String, Object> map, Class<T> clazz) {
|
||||||
|
if(MapUtils.isEmpty(map)){
|
||||||
|
throw new CustomerException("getInstance参数map不能为空!");
|
||||||
|
}
|
||||||
|
T res = null;
|
||||||
|
try {
|
||||||
|
res = clazz.newInstance();
|
||||||
|
Field[] fields = clazz.getDeclaredFields();
|
||||||
|
for (Field field : fields) {
|
||||||
|
// 判断字段类型
|
||||||
|
if (field.getType().isAssignableFrom(List.class) || field.getType().isAssignableFrom(Map.class)) {
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
field.setAccessible(true);
|
||||||
|
String fieldName = field.getName();
|
||||||
|
String value = Util.null2String(map.get(fieldName));
|
||||||
|
// oracle数据库大写
|
||||||
|
if(StringUtils.isBlank(value)){
|
||||||
|
value = Util.null2String(map.get(fieldName.toUpperCase()));
|
||||||
|
}
|
||||||
|
field.set(res, value);
|
||||||
|
}
|
||||||
|
} catch (Exception e) {
|
||||||
|
throw new RuntimeException("实体类生成异常");
|
||||||
|
}
|
||||||
|
return res;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* <h1>获取对象</h1>
|
||||||
|
* @author xuanran.wang
|
||||||
|
* @dateTime 2022/11/15 22:20
|
||||||
|
* @param queryRs 查询结果集
|
||||||
|
* @param clazz 返回类class
|
||||||
|
* @return 返回类对象
|
||||||
|
**/
|
||||||
|
public static <T> T getInstance(RecordSet queryRs, Class<T> clazz) {
|
||||||
|
T res = null;
|
||||||
|
try {
|
||||||
|
res = clazz.newInstance();
|
||||||
|
Field[] fields = clazz.getDeclaredFields();
|
||||||
|
for (Field field : fields) {
|
||||||
|
// 判断字段类型
|
||||||
|
if (field.getType().isAssignableFrom(List.class) || field.getType().isAssignableFrom(Map.class)) {
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
field.setAccessible(true);
|
||||||
|
String fieldName = field.getName();
|
||||||
|
if ("oracle".equals(queryRs.getDBType())) {
|
||||||
|
fieldName = fieldName.toUpperCase();
|
||||||
|
}
|
||||||
|
String value = weaver.general.Util.null2String(queryRs.getString(fieldName));
|
||||||
|
field.set(res, value);
|
||||||
|
}
|
||||||
|
} catch (Exception e) {
|
||||||
|
throw new RuntimeException("实体类生成异常");
|
||||||
|
}
|
||||||
|
return res;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* <h2>将日期字符串转换为Date对象</h2>
|
||||||
|
*
|
||||||
|
* @param dateStr 日期字符串
|
||||||
|
* @return 日期对象
|
||||||
|
*/
|
||||||
|
public static Date parseDate(String dateStr) {
|
||||||
|
ThreadLocal<SimpleDateFormat> SIMPLE_DATE_FORMAT = ThreadLocal.withInitial(() -> new SimpleDateFormat("yyyy-MM-dd"));
|
||||||
|
if (dateStr == null || dateStr.length() == 0) {
|
||||||
|
return null;
|
||||||
|
}
|
||||||
|
String regex = "\\/|\\.|年|月|日";
|
||||||
|
Date date = null;
|
||||||
|
try {
|
||||||
|
date = SIMPLE_DATE_FORMAT.get().parse(dateStr.replaceAll(regex, "-"));
|
||||||
|
return date;
|
||||||
|
} catch (ParseException e) {
|
||||||
|
throw new CustomerException("无法将" + dateStr + "转换为日期对象!", e);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* <h2>自定义格式日期</h2>
|
||||||
|
*
|
||||||
|
* @param date 日期
|
||||||
|
* @param tempStr 格式化字符串
|
||||||
|
* @return 自定义日期字符串
|
||||||
|
*/
|
||||||
|
public static String diyDateFortMat(Date date, String tempStr) {
|
||||||
|
SimpleDateFormat simpleDateFormat = new SimpleDateFormat(tempStr);
|
||||||
|
return simpleDateFormat.format(date);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* <h1>通过数据审批生成流程</h1>
|
||||||
|
* @author xuanran.wang
|
||||||
|
* @dateTime 2022/12/1 21:14
|
||||||
|
* @param modeId 模块id
|
||||||
|
* @param dataIds 模块数据id集合
|
||||||
|
**/
|
||||||
|
public static List<String> doCreateWorkFlow(int modeId, List<String> dataIds){
|
||||||
|
if(modeId < 0){
|
||||||
|
throw new CustomerException("模块id不能小于0!");
|
||||||
|
}
|
||||||
|
if(org.springframework.util.CollectionUtils.isEmpty(dataIds)){
|
||||||
|
logger.info("暂无数据要生成流程!");
|
||||||
|
return Collections.emptyList();
|
||||||
|
}
|
||||||
|
Map<String, Integer> expendConfig = commonMapper.getExpendConfigByModeId(modeId);
|
||||||
|
logger.info(Util.logStr("expendConfig :{}", JSONObject.toJSONString(expendConfig)));
|
||||||
|
int expendId = expendConfig.get("id");
|
||||||
|
int formId = expendConfig.get("formId");
|
||||||
|
int triggerWorkflowSetId = expendConfig.get("triggerWorkflowSetId");
|
||||||
|
ArrayList<String> requestIds = new ArrayList<>();
|
||||||
|
if(expendId > 0 && triggerWorkflowSetId > 0){
|
||||||
|
for (String daId : dataIds) {
|
||||||
|
ModeDataApproval modeDataApproval = new ModeDataApproval();
|
||||||
|
modeDataApproval.setUser(new User(1));
|
||||||
|
modeDataApproval.setBillid(Util.getIntValue(daId));
|
||||||
|
modeDataApproval.setFormid(formId);
|
||||||
|
modeDataApproval.setModeid(modeId);
|
||||||
|
modeDataApproval.setTriggerWorkflowSetId(triggerWorkflowSetId);
|
||||||
|
modeDataApproval.setPageexpandid(expendId);
|
||||||
|
Map<String, String> resMap = modeDataApproval.approvalDataResult();
|
||||||
|
logger.info(Util.logStr("模块数据id : {}, 创建流程结果 : {}", daId, JSONObject.toJSONString(resMap)));
|
||||||
|
requestIds.add(Util.null2String(resMap.get("requestid")));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return requestIds;
|
||||||
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -2,9 +2,11 @@ package weaver.xuanran.wang.common.util;
|
||||||
|
|
||||||
import aiyh.utils.Util;
|
import aiyh.utils.Util;
|
||||||
import aiyh.utils.excention.CustomerException;
|
import aiyh.utils.excention.CustomerException;
|
||||||
import aiyh.utils.sqlUtil.sqlResult.impl.PrepSqlResultImpl;
|
import aiyh.utils.sqlUtil.sqlResult.impl.BatchSqlResultImpl;
|
||||||
import aiyh.utils.sqlUtil.whereUtil.Where;
|
import aiyh.utils.sqlUtil.whereUtil.Where;
|
||||||
import com.alibaba.fastjson.JSONObject;
|
import com.alibaba.fastjson.JSONObject;
|
||||||
|
import org.apache.commons.collections.CollectionUtils;
|
||||||
|
import org.apache.commons.collections.MapUtils;
|
||||||
import org.apache.commons.lang3.StringUtils;
|
import org.apache.commons.lang3.StringUtils;
|
||||||
import org.apache.log4j.Logger;
|
import org.apache.log4j.Logger;
|
||||||
import weaver.conn.RecordSet;
|
import weaver.conn.RecordSet;
|
||||||
|
@ -13,8 +15,7 @@ import weaver.formmode.setup.ModeRightInfo;
|
||||||
import weaver.general.TimeUtil;
|
import weaver.general.TimeUtil;
|
||||||
import weaver.xuanran.wang.common.mapper.CommonMapper;
|
import weaver.xuanran.wang.common.mapper.CommonMapper;
|
||||||
|
|
||||||
import java.util.List;
|
import java.util.*;
|
||||||
import java.util.Map;
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @Author xuanran.wang
|
* @Author xuanran.wang
|
||||||
|
@ -25,7 +26,21 @@ public class CusInfoToOAUtil {
|
||||||
private static final ModeDataIdUpdate modeDataIdUpdate = ModeDataIdUpdate.getInstance();
|
private static final ModeDataIdUpdate modeDataIdUpdate = ModeDataIdUpdate.getInstance();
|
||||||
private static final ModeRightInfo moderightinfo = new ModeRightInfo();
|
private static final ModeRightInfo moderightinfo = new ModeRightInfo();
|
||||||
private static final Logger log = Util.getLogger();
|
private static final Logger log = Util.getLogger();
|
||||||
public static final String TABLE_NAME_PLACEHOLDER = "#\\{table}";
|
public static final String TABLE_NAME_PLACEHOLDER = "#\\{tableName}";
|
||||||
|
|
||||||
|
/**
|
||||||
|
* <h1>将自定义信息写入建模</h1>
|
||||||
|
* @author xuanran.wang
|
||||||
|
* @dateTime 2022/11/23 17:00
|
||||||
|
* @param modelId 模块id
|
||||||
|
* @param params 需要插入的数据map
|
||||||
|
* @return 建模数据id
|
||||||
|
**/
|
||||||
|
public static String getDataId(int modelId,
|
||||||
|
Map<String, Object> params) {
|
||||||
|
return getDataId(modelId, params, "", Collections.emptyList());
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* <h1>将自定义信息写入建模</h1>
|
* <h1>将自定义信息写入建模</h1>
|
||||||
* @author xuanran.wang
|
* @author xuanran.wang
|
||||||
|
@ -36,10 +51,61 @@ public class CusInfoToOAUtil {
|
||||||
* @param whereParams 重复数据参数集合
|
* @param whereParams 重复数据参数集合
|
||||||
* @return 建模数据id
|
* @return 建模数据id
|
||||||
**/
|
**/
|
||||||
public static int execute(int modelId,
|
public static String getDataId(int modelId,
|
||||||
Map<String, Object> params,
|
Map<String, Object> params,
|
||||||
String whereSql,
|
String whereSql,
|
||||||
List<String> whereParams) {
|
List<String> whereParams) {
|
||||||
|
return getDataId(modelId, params, whereSql, whereParams, true);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* <h1>将自定义信息写入建模</h1>
|
||||||
|
* @author xuanran.wang
|
||||||
|
* @dateTime 2022/11/23 17:00
|
||||||
|
* @param modelId 模块id
|
||||||
|
* @param params 需要插入的数据map
|
||||||
|
* @param whereSql 重复数据条件sql
|
||||||
|
* @param whereParams 重复数据参数集合
|
||||||
|
* @param needDel 建模数据更新失败时是否需要删除掉添加的数据
|
||||||
|
* @return 建模数据id
|
||||||
|
**/
|
||||||
|
public static String getDataId(int modelId,
|
||||||
|
Map<String, Object> params,
|
||||||
|
String whereSql,
|
||||||
|
List<String> whereParams,
|
||||||
|
boolean needDel) {
|
||||||
|
return executeBatch(modelId, Collections.singletonList(new LinkedHashMap<>(params)), whereSql, whereParams, needDel).get(0);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* <h1>将自定义信息写入建模</h1>
|
||||||
|
* @author xuanran.wang
|
||||||
|
* @dateTime 2022/11/23 17:00
|
||||||
|
* @param modelId 模块id
|
||||||
|
* @param params 需要插入的数据map
|
||||||
|
* @return 建模数据id集合
|
||||||
|
**/
|
||||||
|
public static List<String> executeBatch( int modelId,
|
||||||
|
List<LinkedHashMap<String, Object>> params) {
|
||||||
|
return executeBatch(modelId, params, "", Collections.emptyList(), true);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* <h1>将自定义信息写入建模</h1>
|
||||||
|
* @author xuanran.wang
|
||||||
|
* @dateTime 2022/11/23 17:00
|
||||||
|
* @param modelId 模块id
|
||||||
|
* @param params 需要插入的数据map
|
||||||
|
* @param whereSql 重复数据条件sql
|
||||||
|
* @param whereParams 重复数据参数集合
|
||||||
|
* @param needDel 更新失败是否需要删除已经插入的数据
|
||||||
|
* @return 建模数据id集合
|
||||||
|
**/
|
||||||
|
public static List<String> executeBatch( int modelId,
|
||||||
|
List<LinkedHashMap<String, Object>> params,
|
||||||
|
String whereSql,
|
||||||
|
List<String> whereParams,
|
||||||
|
boolean needDel) {
|
||||||
if(modelId < 0){
|
if(modelId < 0){
|
||||||
throw new RuntimeException("建模模块id不能小于0!");
|
throw new RuntimeException("建模模块id不能小于0!");
|
||||||
}
|
}
|
||||||
|
@ -47,37 +113,74 @@ public class CusInfoToOAUtil {
|
||||||
if(StringUtils.isBlank(tableName)){
|
if(StringUtils.isBlank(tableName)){
|
||||||
throw new CustomerException("模块id为 " + modelId + ", 在系统中暂没查询到对应表单!");
|
throw new CustomerException("模块id为 " + modelId + ", 在系统中暂没查询到对应表单!");
|
||||||
}
|
}
|
||||||
RecordSet rs = new RecordSet();
|
return executeBatch(modelId, tableName, params, whereSql, whereParams, needDel);
|
||||||
int mainId = -1;
|
}
|
||||||
boolean needModeRight = false;
|
|
||||||
|
/**
|
||||||
|
* <h1>将自定义信息写入建模</h1>
|
||||||
|
* @author xuanran.wang
|
||||||
|
* @dateTime 2022/11/23 17:00
|
||||||
|
* @param modelId 模块id
|
||||||
|
* @param tableName 表名
|
||||||
|
* @param params 需要插入的数据map
|
||||||
|
* @param whereSql 重复数据条件sql
|
||||||
|
* @param whereParams 重复数据参数集合
|
||||||
|
* @param needDel 更新失败是否需要删除已经插入的数据
|
||||||
|
* @return 建模数据id集合
|
||||||
|
**/
|
||||||
|
public static List<String> executeBatch( int modelId,
|
||||||
|
String tableName,
|
||||||
|
List<LinkedHashMap<String, Object>> params,
|
||||||
|
String whereSql,
|
||||||
|
List<String> whereParams,
|
||||||
|
boolean needDel) {
|
||||||
|
// 如果要对模块数据中重复的进行更新则判断待插入的集合大小和判断重复的集合大小参数长度是否一致
|
||||||
if(StringUtils.isNotBlank(whereSql)){
|
if(StringUtils.isNotBlank(whereSql)){
|
||||||
whereSql = whereSql.replaceAll(TABLE_NAME_PLACEHOLDER, tableName);
|
if(CollectionUtils.isEmpty(whereParams) || CollectionUtils.isEmpty(params) || whereParams.size() != params.size()){
|
||||||
if (rs.executeQuery(whereSql, whereParams) && rs.next()) {
|
throw new CustomerException("使用批量更新时如果需要对重复数据进行更新,参数集合和判断重复参数集合大小必须相等!");
|
||||||
mainId = Util.getIntValue(rs.getString(1),-1);
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
if(mainId < 0){
|
RecordSet rs = new RecordSet();
|
||||||
mainId = getNewIdByModelInfo(tableName, modelId);
|
List<String> dataIds = new ArrayList<>();
|
||||||
needModeRight = true;
|
List<Where> wheres = new ArrayList<>();
|
||||||
|
for (int i = 0; i < params.size(); i++) {
|
||||||
|
int mainId = -1;
|
||||||
|
if(StringUtils.isNotBlank(whereSql)){
|
||||||
|
whereSql = Util.sbc2dbcCase(whereSql);
|
||||||
|
whereSql = whereSql.replaceAll(TABLE_NAME_PLACEHOLDER, tableName);
|
||||||
|
log.info("whereSql : " + whereSql);
|
||||||
|
log.info("参数 : " + whereParams);
|
||||||
|
if (rs.executeQuery(whereSql, whereParams) && rs.next()) {
|
||||||
|
mainId = Util.getIntValue(rs.getString(1),-1);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
if(mainId < 0){
|
||||||
|
mainId = getNewIdByModelInfo(tableName, modelId);
|
||||||
|
}
|
||||||
|
dataIds.add(String.valueOf(mainId));
|
||||||
|
wheres.add(Util.createPrepWhereImpl().whereAnd("id").whereEqual(mainId));
|
||||||
}
|
}
|
||||||
Where where = Util.createPrepWhereImpl()
|
BatchSqlResultImpl batchSql = Util.createSqlBuilder().updateBatchSql(tableName, params, wheres);
|
||||||
.whereAnd("id").whereEqual(mainId);
|
String sqlStr = batchSql.getSqlStr();
|
||||||
PrepSqlResultImpl sqlResult = Util.createSqlBuilder().updateSql(
|
List<List> batchList = batchSql.getBatchList();
|
||||||
tableName,
|
if(!rs.executeBatchSql(sqlStr, batchList)){
|
||||||
params,
|
log.error(Util.logStr("batchSql:{}", sqlStr));
|
||||||
where
|
log.error(Util.logStr("batchList:{}", JSONObject.toJSONString(batchList)));
|
||||||
);
|
log.error(Util.logStr("whereList:{}", JSONObject.toJSONString(wheres)));
|
||||||
if (!rs.executeUpdate(sqlResult.getSqlStr(), sqlResult.getArgs())) {
|
if(needDel){
|
||||||
String error = Util.logStr("错误信息写入建模后置处理执行更新sql失败!" +
|
if (!deleteModelDataByIds(String.valueOf(modelId), dataIds)) {
|
||||||
" 当前sql [{}], 当前参数 [{}], where条件[{}]", sqlResult.getSqlStr(),
|
log.error(Util.logStr("删除数据失败!未删除数据集合:{}", JSONObject.toJSONString(dataIds)));
|
||||||
JSONObject.toJSONString(sqlResult.getArgs()), mainId);
|
}
|
||||||
log.error(error);
|
}
|
||||||
throw new CustomerException(error);
|
throw new CustomerException("执行批量更新sql失败!");
|
||||||
}
|
}
|
||||||
if(needModeRight){
|
if(CollectionUtils.isEmpty(dataIds)){
|
||||||
moderightinfo.rebuildModeDataShareByEdit(1, modelId, mainId);
|
throw new CustomerException("建模数据生成失败!");
|
||||||
}
|
}
|
||||||
return mainId;
|
for (String dataId : dataIds) {
|
||||||
|
moderightinfo.rebuildModeDataShareByEdit(1, modelId, Integer.parseInt(dataId));
|
||||||
|
}
|
||||||
|
return dataIds;
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
|
|
@ -0,0 +1,51 @@
|
||||||
|
package weaver.xuanran.wang.saic_travel.model_data_async.config.eneity;
|
||||||
|
|
||||||
|
import lombok.*;
|
||||||
|
|
||||||
|
import java.sql.Timestamp;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* <h1></h1>
|
||||||
|
*
|
||||||
|
* @Author xuanran.wang
|
||||||
|
* @Date 2022/12/1 14:01
|
||||||
|
*/
|
||||||
|
@Data
|
||||||
|
public class DataAsyncDetail {
|
||||||
|
/**
|
||||||
|
* <h2>同步建模字段</h2>
|
||||||
|
**/
|
||||||
|
private String asyncModelTable;
|
||||||
|
/**
|
||||||
|
* <h2>数据类型</h2>
|
||||||
|
**/
|
||||||
|
private String dataType;
|
||||||
|
/**
|
||||||
|
* <h2>数据来源建模字段</h2>
|
||||||
|
**/
|
||||||
|
private String dataSourceModelFiled;
|
||||||
|
/**
|
||||||
|
* <h2>自定义表字段</h2>
|
||||||
|
**/
|
||||||
|
private String cusTableField;
|
||||||
|
/**
|
||||||
|
* <h2>转换规则</h2>
|
||||||
|
**/
|
||||||
|
private String convertRules;
|
||||||
|
/**
|
||||||
|
* <h2>自定义文本</h2>
|
||||||
|
**/
|
||||||
|
private String cusText;
|
||||||
|
/**
|
||||||
|
* <h2>是否启用</h2>
|
||||||
|
**/
|
||||||
|
private String enable;
|
||||||
|
/**
|
||||||
|
* <h2>同步建模字段名称</h2>
|
||||||
|
**/
|
||||||
|
private String asyncModelTableField;
|
||||||
|
/**
|
||||||
|
* <h2>数据来源建模字段名称</h2>
|
||||||
|
**/
|
||||||
|
private String dataSourceModelFiledName;
|
||||||
|
}
|
|
@ -0,0 +1,26 @@
|
||||||
|
package weaver.xuanran.wang.saic_travel.model_data_async.config.eneity;
|
||||||
|
|
||||||
|
import lombok.*;
|
||||||
|
|
||||||
|
import java.util.List;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* <h1>数据同步主表实体类</h1>
|
||||||
|
*
|
||||||
|
* @Author xuanran.wang
|
||||||
|
* @Date 2022/12/1 14:00
|
||||||
|
*/
|
||||||
|
@Data
|
||||||
|
public class DataAsyncMain {
|
||||||
|
private String id;
|
||||||
|
private String uniqueCode;
|
||||||
|
private String enable;
|
||||||
|
private String dataSource;
|
||||||
|
private String modelType;
|
||||||
|
private String cusTable;
|
||||||
|
private String asyncTargetModel;
|
||||||
|
private String cusWhere;
|
||||||
|
private String modelTypeTableName;
|
||||||
|
private String asyncTargetModelTableName;
|
||||||
|
private List<DataAsyncDetail> dataAsyncDetailList;
|
||||||
|
}
|
|
@ -0,0 +1,50 @@
|
||||||
|
package weaver.xuanran.wang.saic_travel.model_data_async.config.mapper;
|
||||||
|
|
||||||
|
import aiyh.utils.annotation.recordset.ParamMapper;
|
||||||
|
import aiyh.utils.annotation.recordset.Select;
|
||||||
|
import aiyh.utils.annotation.recordset.SqlMapper;
|
||||||
|
|
||||||
|
import java.util.List;
|
||||||
|
import java.util.Map;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* <h1>数据同步配置mapper</h1>
|
||||||
|
*
|
||||||
|
* @Author xuanran.wang
|
||||||
|
* @Date 2022/12/1 14:35
|
||||||
|
*/
|
||||||
|
@SqlMapper
|
||||||
|
public interface DataAsyncConfigMapper {
|
||||||
|
|
||||||
|
/**
|
||||||
|
* <h1>获取配置表主表对象</h1>
|
||||||
|
* @author xuanran.wang
|
||||||
|
* @dateTime 2022/12/1 14:39
|
||||||
|
* @param uniqueCode 配置表唯一标识
|
||||||
|
* @return 主表配置对象
|
||||||
|
**/
|
||||||
|
@Select("select a.*,b.tablename asyncTargetModelTableName,c.tablename modelTypeTableName " +
|
||||||
|
"from uf_data_async a " +
|
||||||
|
"left join mode_bill_info_view b " +
|
||||||
|
"on a.asyncTargetModel = b.id " +
|
||||||
|
"left join mode_bill_info_view c " +
|
||||||
|
"on a.modelType = c.id " +
|
||||||
|
"where uniqueCode = #{uniqueCode} and enable = #{enable}")
|
||||||
|
Map<String, Object> getDataAsyncMainConfig(@ParamMapper("uniqueCode") String uniqueCode, @ParamMapper("enable") String enable);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* <h1>获取配置表明细对象集合</h1>
|
||||||
|
* @author xuanran.wang
|
||||||
|
* @dateTime 2022/12/1 14:40
|
||||||
|
* @param mainId 主表主数据id
|
||||||
|
* @return 明细配置集合
|
||||||
|
**/
|
||||||
|
@Select("select a.*,b.fieldname asyncModelTableField,c.fieldname dataSourceModelFiledName " +
|
||||||
|
"from uf_data_async_dt1 a " +
|
||||||
|
"left join workflow_field_table_view b " +
|
||||||
|
"on a.asyncModelTable = b.id " +
|
||||||
|
"left join workflow_field_table_view c " +
|
||||||
|
"on a.dataSourceModelFiled = c.id " +
|
||||||
|
"where mainid = #{mainId} and enable = #{enable}")
|
||||||
|
List<Map<String, Object>> getDataAsyncDetailConfig(@ParamMapper("mainId") String mainId,@ParamMapper("enable") String enable);
|
||||||
|
}
|
|
@ -0,0 +1,79 @@
|
||||||
|
package weaver.xuanran.wang.saic_travel.model_data_async.constant;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* <h1>uf_data_async配置表常量</h1>
|
||||||
|
*
|
||||||
|
* @Author xuanran.wang
|
||||||
|
* @Date 2022/12/1 14:18
|
||||||
|
*/
|
||||||
|
public class DataAsyncConstant {
|
||||||
|
public static final String MODEL_TABLE_NAME = "uf_data_async";
|
||||||
|
/**
|
||||||
|
* <h2>数据来源-建模</h2>
|
||||||
|
**/
|
||||||
|
public static final String DATA_SOURCE_MODEL = "0";
|
||||||
|
/**
|
||||||
|
* <h2>数据来源-自定义表</h2>
|
||||||
|
**/
|
||||||
|
public static final String DATA_SOURCE_CUS_TABLE = "1";
|
||||||
|
/**
|
||||||
|
* <h2>配置启用</h2>
|
||||||
|
**/
|
||||||
|
public static final String CONFIG_ENABLE = "0";
|
||||||
|
/**
|
||||||
|
* <h2>配置不启用</h2>
|
||||||
|
**/
|
||||||
|
public static final String CONFIG_NOT_ENABLE = "1";
|
||||||
|
/**
|
||||||
|
* <h2>数据类型-String</h2>
|
||||||
|
**/
|
||||||
|
public static final String DATA_TYPE_STRING = "0";
|
||||||
|
/**
|
||||||
|
* <h2>数据类型-Int</h2>
|
||||||
|
**/
|
||||||
|
public static final String DATA_TYPE_INT = "1";
|
||||||
|
/**
|
||||||
|
* <h2>数据类型-Double</h2>
|
||||||
|
**/
|
||||||
|
public static final String DATA_TYPE_DOUBLE = "2";
|
||||||
|
/**
|
||||||
|
* <h2>数据类型-Date</h2>
|
||||||
|
**/
|
||||||
|
public static final String DATA_TYPE_DATE = "3";
|
||||||
|
/**
|
||||||
|
* <h2>数据类型-DateTime</h2>
|
||||||
|
**/
|
||||||
|
public static final String DATA_TYPE_DATE_TIME = "4";
|
||||||
|
/**
|
||||||
|
* <h2>数据类型-自定义时间格式</h2>
|
||||||
|
**/
|
||||||
|
public static final String DATA_TYPE_CUS_DATE = "5";
|
||||||
|
/**
|
||||||
|
* <h2>数据类型-时间戳</h2>
|
||||||
|
**/
|
||||||
|
public static final String DATA_TYPE_TIME_TIMESTAMP = "6";
|
||||||
|
/**
|
||||||
|
* <h2>转换类型-当前表单字段</h2>
|
||||||
|
**/
|
||||||
|
public static final String CONVERT_RULES_TABLE_FIELD = "0";
|
||||||
|
/**
|
||||||
|
* <h2>转换类型-默认值</h2>
|
||||||
|
**/
|
||||||
|
public static final String CONVERT_RULES_DEFAULT = "1";
|
||||||
|
/**
|
||||||
|
* <h2>转换类型-当前时间</h2>
|
||||||
|
**/
|
||||||
|
public static final String CONVERT_RULES_NOW_TIME = "2";
|
||||||
|
/**
|
||||||
|
* <h2>转换类型-自定义SQL</h2>
|
||||||
|
**/
|
||||||
|
public static final String CONVERT_RULES_CUS_SQL = "3";
|
||||||
|
/**
|
||||||
|
* <h2>转换类型-数据id</h2>
|
||||||
|
**/
|
||||||
|
public static final String CONVERT_RULES_DATA_ID = "4";
|
||||||
|
/**
|
||||||
|
* <h2>转换类型-拆分复制</h2>
|
||||||
|
**/
|
||||||
|
public static final String CONVERT_RULES_SPLIT_COPY = "5";
|
||||||
|
}
|
|
@ -0,0 +1,41 @@
|
||||||
|
package weaver.xuanran.wang.saic_travel.model_data_async.job;
|
||||||
|
|
||||||
|
import aiyh.utils.Util;
|
||||||
|
import org.apache.log4j.Logger;
|
||||||
|
import weaver.interfaces.schedule.BaseCronJob;
|
||||||
|
import weaver.xuanran.wang.common.annocation.ParamNotNull;
|
||||||
|
import weaver.xuanran.wang.common.util.CommonUtil;
|
||||||
|
import weaver.xuanran.wang.saic_travel.model_data_async.config.eneity.DataAsyncMain;
|
||||||
|
import weaver.xuanran.wang.saic_travel.model_data_async.service.DataAsyncConfigService;
|
||||||
|
|
||||||
|
|
||||||
|
/**
|
||||||
|
* <h1>员工信息同步至建模</h1>
|
||||||
|
*
|
||||||
|
* @Author xuanran.wang
|
||||||
|
* @Date 2022/12/1 15:20
|
||||||
|
*/
|
||||||
|
public class HrmDataToModelAsync extends BaseCronJob {
|
||||||
|
|
||||||
|
private final Logger logger = Util.getLogger();
|
||||||
|
|
||||||
|
private final DataAsyncConfigService asyncConfigService = new DataAsyncConfigService();
|
||||||
|
|
||||||
|
@ParamNotNull
|
||||||
|
private String uniqueCode;
|
||||||
|
|
||||||
|
@ParamNotNull
|
||||||
|
private String modelId;
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void execute() {
|
||||||
|
try {
|
||||||
|
CommonUtil.checkParamNotNull(this);
|
||||||
|
DataAsyncMain dataAsyncConfigByUniqueCode = asyncConfigService.getDataAsyncConfigByUniqueCode(uniqueCode);
|
||||||
|
asyncConfigService.asyncModelData(dataAsyncConfigByUniqueCode, Util.getIntValue(modelId, -1));
|
||||||
|
}catch (Exception e){
|
||||||
|
logger.error(Util.logStr("执行数据同步计划任务失败!异常信息 : {}", e.getMessage()));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
|
@ -0,0 +1,23 @@
|
||||||
|
package weaver.xuanran.wang.saic_travel.model_data_async.mapper;
|
||||||
|
|
||||||
|
import aiyh.utils.annotation.recordset.*;
|
||||||
|
import weaver.conn.RecordSet;
|
||||||
|
|
||||||
|
import java.util.Map;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* <h1>数据同步mapper</h1>
|
||||||
|
*
|
||||||
|
* @Author xuanran.wang
|
||||||
|
* @Date 2022/12/1 16:55
|
||||||
|
*/
|
||||||
|
@SqlMapper
|
||||||
|
public interface DataAsyncMapper {
|
||||||
|
|
||||||
|
@Select(custom = true)
|
||||||
|
@CaseConversion(false)
|
||||||
|
RecordSet getRecordSetByCusSql(@SqlString String sql);
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
}
|
|
@ -0,0 +1,265 @@
|
||||||
|
package weaver.xuanran.wang.saic_travel.model_data_async.service;
|
||||||
|
|
||||||
|
import aiyh.utils.Util;
|
||||||
|
import aiyh.utils.excention.CustomerException;
|
||||||
|
import com.alibaba.fastjson.JSONObject;
|
||||||
|
import org.apache.commons.lang3.StringUtils;
|
||||||
|
import org.apache.log4j.Logger;
|
||||||
|
import org.springframework.util.Assert;
|
||||||
|
import org.springframework.util.CollectionUtils;
|
||||||
|
import weaver.conn.RecordSet;
|
||||||
|
import weaver.xuanran.wang.common.util.CommonUtil;
|
||||||
|
import weaver.xuanran.wang.common.util.CusInfoToOAUtil;
|
||||||
|
import weaver.xuanran.wang.saic_travel.model_data_async.config.eneity.DataAsyncDetail;
|
||||||
|
import weaver.xuanran.wang.saic_travel.model_data_async.config.eneity.DataAsyncMain;
|
||||||
|
import weaver.xuanran.wang.saic_travel.model_data_async.config.mapper.DataAsyncConfigMapper;
|
||||||
|
import weaver.xuanran.wang.saic_travel.model_data_async.constant.DataAsyncConstant;
|
||||||
|
import weaver.xuanran.wang.saic_travel.model_data_async.mapper.DataAsyncMapper;
|
||||||
|
import weaver.zwl.common.ToolUtil;
|
||||||
|
|
||||||
|
import java.util.*;
|
||||||
|
import java.util.stream.Collectors;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* <h1>上汽海外出行数据同步service</h1>
|
||||||
|
*
|
||||||
|
* @Author xuanran.wang
|
||||||
|
* @Date 2022/12/1 14:33
|
||||||
|
*/
|
||||||
|
public class DataAsyncConfigService {
|
||||||
|
private final Logger logger = Util.getLogger();
|
||||||
|
private final RecordSet tempRs = new RecordSet();
|
||||||
|
private final DataAsyncConfigMapper dataAsyncConfigMapper = Util.getMapper(DataAsyncConfigMapper.class);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* <h1>获取配置对象</h1>
|
||||||
|
* @author xuanran.wang
|
||||||
|
* @dateTime 2022/12/1 15:09
|
||||||
|
* @param uniqueCode 唯一标识
|
||||||
|
* @return 配置对象
|
||||||
|
**/
|
||||||
|
public DataAsyncMain getDataAsyncConfigByUniqueCode(String uniqueCode){
|
||||||
|
Map<String, Object> mainConfigMap = dataAsyncConfigMapper.getDataAsyncMainConfig(uniqueCode, DataAsyncConstant.CONFIG_ENABLE);
|
||||||
|
DataAsyncMain dataAsyncMain = CommonUtil.getInstance(mainConfigMap, DataAsyncMain.class);
|
||||||
|
List<Map<String, Object>> asyncDetailConfig = dataAsyncConfigMapper.getDataAsyncDetailConfig(dataAsyncMain.getId(), DataAsyncConstant.CONFIG_ENABLE);
|
||||||
|
List<DataAsyncDetail> detailList = asyncDetailConfig.stream().map(item -> CommonUtil.getInstance(item, DataAsyncDetail.class)).collect(Collectors.toList());
|
||||||
|
Assert.notEmpty(detailList, "明细表配置集合获取为空, 请检查!");
|
||||||
|
dataAsyncMain.setDataAsyncDetailList(detailList);
|
||||||
|
return dataAsyncMain;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* <h1>通过配置数据同步至建模</h1>
|
||||||
|
* @author xuanran.wang
|
||||||
|
* @dateTime 2022/12/2 13:28
|
||||||
|
* @param asyncConfig 配置表主对象
|
||||||
|
* @param modelId 模块id
|
||||||
|
**/
|
||||||
|
public List<String> asyncModelData(DataAsyncMain asyncConfig, int modelId){
|
||||||
|
String dataSource = asyncConfig.getDataSource();
|
||||||
|
String selectSql = getSelectSql(asyncConfig);
|
||||||
|
List<DataAsyncDetail> asyncDetailList = asyncConfig.getDataAsyncDetailList();
|
||||||
|
RecordSet rs = new RecordSet();
|
||||||
|
if (!rs.executeQuery(selectSql)) {
|
||||||
|
throw new CustomerException(Util.logStr("执行查询数据源sql失败! 当前sql:{}", selectSql));
|
||||||
|
}
|
||||||
|
logger.info("selectSql : " + selectSql);
|
||||||
|
List<LinkedHashMap<String, Object>> linkedHashMapList = new ArrayList<>();
|
||||||
|
int splitCopy = -1;
|
||||||
|
String splitCopyFiledName = "";
|
||||||
|
// 复制个数
|
||||||
|
List<DataAsyncDetail> splitCopyList = asyncDetailList.stream().filter(item -> DataAsyncConstant.CONVERT_RULES_SPLIT_COPY.equals(item.getConvertRules())).collect(Collectors.toList());
|
||||||
|
if(!CollectionUtils.isEmpty(splitCopyList)){
|
||||||
|
DataAsyncDetail detail = splitCopyList.get(0);
|
||||||
|
splitCopy = Util.getIntValue(detail.getCusText(),-1);
|
||||||
|
splitCopyFiledName = Util.null2DefaultStr(detail.getAsyncModelTableField(),"");
|
||||||
|
}
|
||||||
|
while (rs.next()){
|
||||||
|
LinkedHashMap<String, Object> linkedHashMap = new LinkedHashMap<>();
|
||||||
|
int tempCount = 0;
|
||||||
|
for (DataAsyncDetail dataAsyncDetail : asyncDetailList) {
|
||||||
|
String field = "";
|
||||||
|
switch (dataSource){
|
||||||
|
case DataAsyncConstant.DATA_SOURCE_MODEL:{
|
||||||
|
field = dataAsyncDetail.getDataSourceModelFiledName();
|
||||||
|
}break;
|
||||||
|
case DataAsyncConstant.DATA_SOURCE_CUS_TABLE:{
|
||||||
|
field = dataAsyncDetail.getCusTableField();
|
||||||
|
}break;
|
||||||
|
default:throw new CustomerException("暂不支持的数据来源");
|
||||||
|
}
|
||||||
|
Object value = getFieldValue(rs, field, dataAsyncDetail, tempCount);
|
||||||
|
linkedHashMap.put(dataAsyncDetail.getAsyncModelTableField(), value);
|
||||||
|
}
|
||||||
|
linkedHashMapList.add(linkedHashMap);
|
||||||
|
// 记录复制
|
||||||
|
while (++tempCount < splitCopy) {
|
||||||
|
LinkedHashMap<String, Object> copyMap = new LinkedHashMap<>(linkedHashMap);
|
||||||
|
copyMap.put(splitCopyFiledName, tempCount);
|
||||||
|
linkedHashMapList.add(copyMap);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
List<String> list = CusInfoToOAUtil.executeBatch(modelId, linkedHashMapList);
|
||||||
|
return list;
|
||||||
|
}
|
||||||
|
/**
|
||||||
|
* <h1>根据配置将值转换</h1>
|
||||||
|
* @author xuanran.wang
|
||||||
|
* @dateTime 2022/12/5 10:50
|
||||||
|
* @param recordSet 当前数据结果集
|
||||||
|
* @param field 数据来源表字段名
|
||||||
|
* @param dataAsyncDetail 明细配置对象
|
||||||
|
* @param count 复制次数
|
||||||
|
* @return 转换后的值
|
||||||
|
**/
|
||||||
|
public Object getFieldValue(RecordSet recordSet, String field, DataAsyncDetail dataAsyncDetail, int count){
|
||||||
|
String convertRules = dataAsyncDetail.getConvertRules();
|
||||||
|
String dataType = dataAsyncDetail.getDataType();
|
||||||
|
String cusText = dataAsyncDetail.getCusText();
|
||||||
|
Object value = "";
|
||||||
|
switch (convertRules) {
|
||||||
|
// 表单字段
|
||||||
|
case DataAsyncConstant.CONVERT_RULES_TABLE_FIELD: {
|
||||||
|
if(!StringUtils.isBlank(field)){
|
||||||
|
value = Util.null2String(recordSet.getString(field));
|
||||||
|
}
|
||||||
|
}break;
|
||||||
|
// 默认值
|
||||||
|
case DataAsyncConstant.CONVERT_RULES_DEFAULT: {
|
||||||
|
value = cusText;
|
||||||
|
}break;
|
||||||
|
// 当前时间
|
||||||
|
case DataAsyncConstant.CONVERT_RULES_NOW_TIME: {
|
||||||
|
value = new Date();
|
||||||
|
}break;
|
||||||
|
// 自定义sql查询
|
||||||
|
case DataAsyncConstant.CONVERT_RULES_CUS_SQL: {
|
||||||
|
if(!StringUtils.isBlank(cusText)){
|
||||||
|
String cusSql = Util.sbc2dbcCase(cusText);
|
||||||
|
String where = "";
|
||||||
|
if(StringUtils.isNotBlank(field)){
|
||||||
|
where = Util.null2DefaultStr(recordSet.getString(field),"");
|
||||||
|
}
|
||||||
|
tempRs.executeQuery(cusSql, where);
|
||||||
|
if (!tempRs.next()) {
|
||||||
|
logger.error(Util.logStr("执行自定义sql失败!当前sql:{}, 当前参数:{}", cusSql, where));
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
value = tempRs.getString(1);
|
||||||
|
}
|
||||||
|
}break;
|
||||||
|
case DataAsyncConstant.CONVERT_RULES_DATA_ID: {
|
||||||
|
value = recordSet.getString("id");
|
||||||
|
}break;
|
||||||
|
case DataAsyncConstant.CONVERT_RULES_SPLIT_COPY: {
|
||||||
|
value = count;
|
||||||
|
}break;
|
||||||
|
default: throw new CustomerException("不支持的取值方式!");
|
||||||
|
}
|
||||||
|
switch (dataType) {
|
||||||
|
// String类型
|
||||||
|
case DataAsyncConstant.DATA_TYPE_STRING: {
|
||||||
|
value = Util.null2DefaultStr(String.valueOf(value), "");
|
||||||
|
}
|
||||||
|
break;
|
||||||
|
// int类型
|
||||||
|
case DataAsyncConstant.DATA_TYPE_INT: {
|
||||||
|
value = Util.getIntValue(Util.null2DefaultStr(value, ""), 0);
|
||||||
|
}
|
||||||
|
break;
|
||||||
|
// double类型
|
||||||
|
case DataAsyncConstant.DATA_TYPE_DOUBLE: {
|
||||||
|
value = Util.getDoubleValue(Util.null2DefaultStr(value, ""), 0);
|
||||||
|
}
|
||||||
|
break;
|
||||||
|
// 日期类型
|
||||||
|
case DataAsyncConstant.DATA_TYPE_DATE: {
|
||||||
|
if (StringUtils.isBlank(Util.null2DefaultStr(value, ""))) {
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
try {
|
||||||
|
Date date = value instanceof Date ? (Date) value : CommonUtil.parseDate(String.valueOf(value));
|
||||||
|
value = CommonUtil.diyDateFortMat(date, "yyyy-MM-dd");
|
||||||
|
} catch (Exception e) {
|
||||||
|
logger.error(Util.logStr("转换日期类型异常, 当前字段:{},当前值:{}", field, value));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
break;
|
||||||
|
// 时间日期类型
|
||||||
|
case DataAsyncConstant.DATA_TYPE_DATE_TIME: {
|
||||||
|
if (StringUtils.isBlank(Util.null2DefaultStr(value, ""))) {
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
try {
|
||||||
|
Date date = value instanceof Date ? (Date) value : CommonUtil.parseDate(String.valueOf(value));
|
||||||
|
value = CommonUtil.diyDateFortMat(date, "yyyy-MM-dd HH:mm:ss");
|
||||||
|
} catch (Exception e) {
|
||||||
|
logger.error(Util.logStr("转换日期类型异常, 当前字段:{},当前值:{}", field, value));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
break;
|
||||||
|
// 自定义时间格式化类型
|
||||||
|
case DataAsyncConstant.DATA_TYPE_CUS_DATE: {
|
||||||
|
if (StringUtils.isBlank(Util.null2DefaultStr(value, "")) || StringUtils.isBlank(cusText)) {
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
try {
|
||||||
|
Date date = value instanceof Date ? (Date) value : CommonUtil.parseDate(String.valueOf(value));
|
||||||
|
value = CommonUtil.diyDateFortMat(date, cusText);
|
||||||
|
} catch (Exception e) {
|
||||||
|
logger.error(Util.logStr("转换日期类型异常, 当前字段:{},当前值:{}", field, value));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
break;
|
||||||
|
// 时间戳类型
|
||||||
|
case DataAsyncConstant.DATA_TYPE_TIME_TIMESTAMP: {
|
||||||
|
if (StringUtils.isBlank(Util.null2DefaultStr(value, "")) || StringUtils.isBlank(cusText)) {
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
try {
|
||||||
|
Date date = value instanceof Date ? (Date) value : CommonUtil.parseDate(String.valueOf(value));
|
||||||
|
value = date.getTime();
|
||||||
|
} catch (Exception e) {
|
||||||
|
logger.error(Util.logStr("转换日期类型异常, 当前字段:{},当前值:{}", field, value));
|
||||||
|
}
|
||||||
|
}break;
|
||||||
|
default: throw new CustomerException("不支持的字段类型!");
|
||||||
|
}
|
||||||
|
return value;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* <h1>根据配置对象获取查询sql</h1>
|
||||||
|
* @author xuanran.wang
|
||||||
|
* @dateTime 2022/12/2 12:56
|
||||||
|
* @param asyncConfig 主配置对象
|
||||||
|
* @return 查询数据来源sql
|
||||||
|
**/
|
||||||
|
public String getSelectSql(DataAsyncMain asyncConfig){
|
||||||
|
String dataSource = asyncConfig.getDataSource();
|
||||||
|
String cusWhere = Util.null2DefaultStr(asyncConfig.getCusWhere(), "");
|
||||||
|
String dataSourceTableName = "";
|
||||||
|
List<DataAsyncDetail> asyncDetailList = asyncConfig.getDataAsyncDetailList();
|
||||||
|
String selectSql = "select ";
|
||||||
|
List<String> modelFieldList = new ArrayList<>();
|
||||||
|
// 判断数据来源拼接查询sql
|
||||||
|
switch (dataSource) {
|
||||||
|
case DataAsyncConstant.DATA_SOURCE_MODEL:{
|
||||||
|
modelFieldList = asyncDetailList.stream().map(DataAsyncDetail::getDataSourceModelFiledName).filter(StringUtils::isNotBlank).collect(Collectors.toList());
|
||||||
|
dataSourceTableName = asyncConfig.getModelTypeTableName();
|
||||||
|
}break;
|
||||||
|
case DataAsyncConstant.DATA_SOURCE_CUS_TABLE:{
|
||||||
|
modelFieldList = asyncDetailList.stream().map(DataAsyncDetail::getCusTableField).filter(StringUtils::isNotBlank).collect(Collectors.toList());
|
||||||
|
dataSourceTableName = asyncConfig.getCusTable();
|
||||||
|
}break;
|
||||||
|
default:throw new CustomerException("暂不支持的数据来源!");
|
||||||
|
}
|
||||||
|
// 拼接数据源查询sql
|
||||||
|
selectSql += StringUtils.join(modelFieldList, ",") + " from " + dataSourceTableName;
|
||||||
|
if(StringUtils.isNotBlank(cusWhere)){
|
||||||
|
selectSql += " where " + cusWhere;
|
||||||
|
}
|
||||||
|
return selectSql;
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
|
@ -0,0 +1,53 @@
|
||||||
|
package weaver.xuanran.wang.schroeder.action;
|
||||||
|
|
||||||
|
import aiyh.utils.Util;
|
||||||
|
import aiyh.utils.action.CusBaseAction;
|
||||||
|
import aiyh.utils.annotation.RequiredMark;
|
||||||
|
import aiyh.utils.excention.CustomerException;
|
||||||
|
import weaver.conn.RecordSetTrans;
|
||||||
|
import weaver.hrm.User;
|
||||||
|
import weaver.workflow.request.RequestManager;
|
||||||
|
import weaver.xuanran.wang.schroeder.service.SchroederQRCodeService;
|
||||||
|
|
||||||
|
|
||||||
|
/**
|
||||||
|
* <h1>施罗德创建二维码action</h1>
|
||||||
|
*
|
||||||
|
* @Author xuanran.wang
|
||||||
|
* @Date 2022/11/30 16:08
|
||||||
|
*/
|
||||||
|
public class PushSealTaskAction extends CusBaseAction {
|
||||||
|
|
||||||
|
/**
|
||||||
|
* <h2>建模配置唯一标识</h2>
|
||||||
|
**/
|
||||||
|
@RequiredMark
|
||||||
|
private String onlyMark;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* <h2>二维码来源字段</h2>
|
||||||
|
**/
|
||||||
|
@RequiredMark
|
||||||
|
private String QRCodeField;
|
||||||
|
|
||||||
|
private final SchroederQRCodeService schroederQRCodeService = new SchroederQRCodeService();
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void doSubmit(String requestId, String billTable, int workflowId, User user, RequestManager requestManager) {
|
||||||
|
log.info("---------- PushSealTaskSealValue Begin " + requestId + "----------");
|
||||||
|
String scanNum = schroederQRCodeService.pushSealTask(onlyMark, billTable, requestId);
|
||||||
|
RecordSetTrans trans = requestManager.getRsTrans();
|
||||||
|
trans.setAutoCommit(false);
|
||||||
|
String updateSql = "update " + billTable + " set " + QRCodeField + " = ? where requestid = ?";
|
||||||
|
try{
|
||||||
|
if(!trans.executeUpdate(updateSql, scanNum, requestId)){
|
||||||
|
throw new CustomerException(Util.logStr("更新表单sql执行失败!sql : {}, 参数 scanNum : {}, requestId : {}", scanNum, requestId));
|
||||||
|
}
|
||||||
|
}catch (Exception e){
|
||||||
|
trans.rollback();
|
||||||
|
throw new CustomerException(Util.logStr("执行提交方法异常:{}", e.getMessage()));
|
||||||
|
}
|
||||||
|
trans.commit();
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
|
@ -0,0 +1,71 @@
|
||||||
|
package weaver.xuanran.wang.schroeder.cus_field_value;
|
||||||
|
|
||||||
|
import aiyh.utils.Util;
|
||||||
|
import aiyh.utils.excention.CustomerException;
|
||||||
|
import com.alibaba.fastjson.JSONObject;
|
||||||
|
import org.apache.commons.collections.MapUtils;
|
||||||
|
import org.apache.commons.lang3.StringUtils;
|
||||||
|
import org.apache.log4j.Logger;
|
||||||
|
import weaver.conn.RecordSet;
|
||||||
|
import weaver.xiao.commons.config.interfacies.CusInterfaceGetValue;
|
||||||
|
import weaver.zwl.common.ToolUtil;
|
||||||
|
|
||||||
|
import java.util.*;
|
||||||
|
import java.util.stream.Collectors;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* <h1></h1>
|
||||||
|
*
|
||||||
|
* @Author xuanran.wang
|
||||||
|
* @Date 2022/12/2 16:10
|
||||||
|
*/
|
||||||
|
public class PushSealTaskSealValue implements CusInterfaceGetValue {
|
||||||
|
private final ToolUtil toolUtil = new ToolUtil();
|
||||||
|
|
||||||
|
private final Logger logger = Util.getLogger();
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public Object execute(Map<String, Object> mainMap, Map<String, Object> detailMap, String currentValue, Map<String, String> pathParam) {
|
||||||
|
logger.info(Util.logStr("路径参数:[{}]", JSONObject.toJSONString(pathParam)));
|
||||||
|
// 接口字段
|
||||||
|
String sealSnField = pathParam.get("sealSnField");
|
||||||
|
String sealNumField = pathParam.get("sealNumField");
|
||||||
|
// 表单字段
|
||||||
|
String workFlowSealNumField = pathParam.get("workFlowSealNumField");
|
||||||
|
String workFlowSealSnField = pathParam.get("workFlowSealSnField");
|
||||||
|
// 自定义sql业务印章类型
|
||||||
|
String sealSnCusSql = pathParam.get("sealSnCusSql");
|
||||||
|
// 使用次数
|
||||||
|
String sealNumCusSql = pathParam.get("sealNumCusSql");
|
||||||
|
// 非空校验
|
||||||
|
if(checkBlank(sealSnField, sealNumField, sealSnCusSql, sealNumCusSql, workFlowSealNumField, workFlowSealSnField)){
|
||||||
|
throw new CustomerException(Util.logStr("自定义类路径中必要参数为空,请检查!当前pathParam : {}", JSONObject.toJSONString(pathParam)));
|
||||||
|
}
|
||||||
|
// 表单印章使用类型值
|
||||||
|
String sealSnVal = Util.null2String(String.valueOf(detailMap.get(sealSnField)),"");
|
||||||
|
// 如果为空返回空集合
|
||||||
|
if(StringUtils.isBlank(sealSnVal)){
|
||||||
|
return Collections.emptyList();
|
||||||
|
}
|
||||||
|
ArrayList<Map<String, Object>> list = new ArrayList<>();
|
||||||
|
logger.info(Util.logStr("当前值 : {}", currentValue));
|
||||||
|
int detailId = -1;
|
||||||
|
if(MapUtils.isNotEmpty(detailMap)){
|
||||||
|
detailId = Util.getIntValue(String.valueOf(detailMap.get("id")), -1);
|
||||||
|
}
|
||||||
|
for (String val : sealSnVal.split(",")) {
|
||||||
|
// 印章类型转换执行自定义sql
|
||||||
|
String inSealVal = Util.null2DefaultStr(toolUtil.getValueByChangeRule(sealSnCusSql, val, String.valueOf(mainMap.get("requestid")), detailId),"");
|
||||||
|
String inSealNumVal = Util.null2DefaultStr(toolUtil.getValueByChangeRule(sealNumCusSql, val, String.valueOf(mainMap.get("requestid")), detailId),"");
|
||||||
|
HashMap<String, Object> map = new HashMap<>();
|
||||||
|
map.put(sealSnField, inSealVal);
|
||||||
|
map.put(sealNumField, inSealNumVal);
|
||||||
|
list.add(map);
|
||||||
|
}
|
||||||
|
return list;
|
||||||
|
}
|
||||||
|
|
||||||
|
public boolean checkBlank(String ... args){
|
||||||
|
return Arrays.stream(args).anyMatch(StringUtils::isBlank);
|
||||||
|
}
|
||||||
|
}
|
|
@ -0,0 +1,114 @@
|
||||||
|
package weaver.xuanran.wang.schroeder.service;
|
||||||
|
|
||||||
|
import aiyh.utils.Util;
|
||||||
|
import aiyh.utils.excention.CustomerException;
|
||||||
|
import aiyh.utils.httpUtil.ResponeVo;
|
||||||
|
import aiyh.utils.httpUtil.util.HttpUtils;
|
||||||
|
import com.alibaba.fastjson.JSON;
|
||||||
|
import com.alibaba.fastjson.JSONObject;
|
||||||
|
import com.fasterxml.jackson.core.JsonProcessingException;
|
||||||
|
import com.google.zxing.qrcode.encoder.QRCode;
|
||||||
|
import org.apache.commons.lang3.StringUtils;
|
||||||
|
import org.apache.log4j.Logger;
|
||||||
|
import weaver.conn.RecordSet;
|
||||||
|
import weaver.mobile.plugin.ecology.QRCodeComInfo;
|
||||||
|
import weaver.xiao.commons.config.entity.RequestMappingConfig;
|
||||||
|
import weaver.xiao.commons.config.service.DealWithMapping;
|
||||||
|
|
||||||
|
import javax.ws.rs.core.MediaType;
|
||||||
|
import java.io.IOException;
|
||||||
|
import java.util.Map;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* <h1>施罗德业务方法</h1>
|
||||||
|
*
|
||||||
|
* @Author xuanran.wang
|
||||||
|
* @Date 2022/12/1 10:58
|
||||||
|
*/
|
||||||
|
public class SchroederQRCodeService {
|
||||||
|
private static final int SUCCESS_CODE = 200;
|
||||||
|
/**
|
||||||
|
* <h2>成功状态码</h2>
|
||||||
|
**/
|
||||||
|
private static final int SUCCESS_STATUS= 0;
|
||||||
|
/**
|
||||||
|
* <h2>接口响应信息</h2>
|
||||||
|
**/
|
||||||
|
private static final String MESSAGE_FIELD = "message";
|
||||||
|
/**
|
||||||
|
* <h2>扫描任务码</h2>
|
||||||
|
**/
|
||||||
|
private static final String SCAN_NUM_FIELD = "scanNum";
|
||||||
|
/**
|
||||||
|
* <h2>接口响应状态字段</h2>
|
||||||
|
**/
|
||||||
|
private static final String STATUS_FIELD = "status";
|
||||||
|
private final DealWithMapping dealWithMapping = new DealWithMapping();
|
||||||
|
private final Logger log = Util.getLogger();
|
||||||
|
private final HttpUtils httpUtils = new HttpUtils();
|
||||||
|
{
|
||||||
|
httpUtils.getGlobalCache().header.put("Content-Type", MediaType.APPLICATION_JSON);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* <h1>推送数据创建任务</h1>
|
||||||
|
* @author xuanran.wang
|
||||||
|
* @dateTime 2022/12/5 17:05
|
||||||
|
* @param onlyMark 唯一编码
|
||||||
|
* @param billTable 表名
|
||||||
|
* @param requestId 请求id
|
||||||
|
* @return 响应数据
|
||||||
|
**/
|
||||||
|
public String pushSealTask(String onlyMark, String billTable, String requestId){
|
||||||
|
String res = "";
|
||||||
|
RequestMappingConfig requestMappingConfig = dealWithMapping.treeDealWithUniqueCode(onlyMark);
|
||||||
|
String cusWhere = Util.null2DefaultStr(requestMappingConfig.getCusWhereSql(),"");
|
||||||
|
if(StringUtils.isNotBlank(cusWhere)){
|
||||||
|
cusWhere = DealWithMapping.sbc2dbcCase(cusWhere);
|
||||||
|
}
|
||||||
|
String selectMainSql = "select * from " + billTable + " where requestid = ? " + cusWhere;
|
||||||
|
log.info("查询主表数据sql { " + selectMainSql + " }, requestId { " + requestId + " }");
|
||||||
|
RecordSet recordSet = new RecordSet();
|
||||||
|
recordSet.executeQuery(selectMainSql, requestId);
|
||||||
|
if (recordSet.next()) {
|
||||||
|
dealWithMapping.setMainTable(billTable);
|
||||||
|
Map<String, Object> requestParam = dealWithMapping.getRequestParam(recordSet, requestMappingConfig);
|
||||||
|
log.info(Util.logStr("请求json : {}", JSONObject.toJSONString(requestParam)));
|
||||||
|
String url = requestMappingConfig.getRequestUrl();
|
||||||
|
ResponeVo responeVo = null;
|
||||||
|
try {
|
||||||
|
responeVo = httpUtils.apiPost(url, requestParam);
|
||||||
|
} catch (IOException e) {
|
||||||
|
throw new CustomerException(Util.logStr("发送印章请求发生异常! : {}", e.getMessage()));
|
||||||
|
}
|
||||||
|
Map<String, String> headers = httpUtils.getGlobalCache().header;
|
||||||
|
if (responeVo.getCode() != SUCCESS_CODE) {
|
||||||
|
log.error(Util.logStr("can not fetch [{}],this request params is [{}]," +
|
||||||
|
"this request heard is [{}],but response status code is [{}]," +
|
||||||
|
"this response is [{}]", url, JSON.toJSON(requestParam), JSON.toJSONString(headers), responeVo.getCode(),
|
||||||
|
responeVo.getEntityString()));
|
||||||
|
throw new CustomerException(Util.logStr("can not fetch [{}]", url));
|
||||||
|
}
|
||||||
|
Map<String, Object> response;
|
||||||
|
log.info(Util.logStr("this response is [{}]", responeVo.getEntityString()));
|
||||||
|
try {
|
||||||
|
response = responeVo.getEntityMap();
|
||||||
|
log.info(Util.logStr("接口响应:{}", JSONObject.toJSONString(response)));
|
||||||
|
} catch (JsonProcessingException e) {
|
||||||
|
log.error(Util.logStr("push data error, can not parse response to map," +
|
||||||
|
"this response is [{}], url is [{}],request params is [{}], request heard is [{}];",
|
||||||
|
responeVo.getEntityString(), url, JSON.toJSONString(requestParam), JSON.toJSONString(headers)));
|
||||||
|
throw new CustomerException(Util.logStr("push data error, can not parse response to map"));
|
||||||
|
}
|
||||||
|
int status = (int) response.get(STATUS_FIELD);
|
||||||
|
if(SUCCESS_STATUS != status){
|
||||||
|
throw new CustomerException(Util.logStr("接口响应码不为0,接口响应信息:{}", Util.null2DefaultStr(response.get(MESSAGE_FIELD),"")));
|
||||||
|
}
|
||||||
|
res = Util.null2DefaultStr(response.get(SCAN_NUM_FIELD),"");
|
||||||
|
}
|
||||||
|
if(StringUtils.isBlank(res)){
|
||||||
|
throw new CustomerException("获取接口中响应任务字段为空, 请检查!");
|
||||||
|
}
|
||||||
|
return res;
|
||||||
|
}
|
||||||
|
}
|
|
@ -0,0 +1,17 @@
|
||||||
|
package weaver.xuanran.wang.traffic_bank.waco_first.annocation;
|
||||||
|
|
||||||
|
import java.lang.annotation.ElementType;
|
||||||
|
import java.lang.annotation.Retention;
|
||||||
|
import java.lang.annotation.RetentionPolicy;
|
||||||
|
import java.lang.annotation.Target;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* <h1>威科先行附件注解</h1>
|
||||||
|
*
|
||||||
|
* @Author xuanran.wang
|
||||||
|
* @Date 2022/11/30 11:35
|
||||||
|
*/
|
||||||
|
@Target({ElementType.FIELD,ElementType.TYPE})
|
||||||
|
@Retention(RetentionPolicy.RUNTIME)
|
||||||
|
public @interface Attachments {
|
||||||
|
}
|
|
@ -0,0 +1,14 @@
|
||||||
|
package weaver.xuanran.wang.traffic_bank.waco_first.entity;
|
||||||
|
|
||||||
|
import lombok.Data;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* <h1></h1>
|
||||||
|
*
|
||||||
|
* @Author xuanran.wang
|
||||||
|
* @Date 2022/11/25 17:56
|
||||||
|
*/
|
||||||
|
@Data
|
||||||
|
public class Attachment {
|
||||||
|
private String src;
|
||||||
|
}
|
|
@ -4,6 +4,8 @@ import lombok.Data;
|
||||||
import weaver.xuanran.wang.common.annocation.CusDateFormat;
|
import weaver.xuanran.wang.common.annocation.CusDateFormat;
|
||||||
import weaver.xuanran.wang.traffic_bank.waco_first.annocation.BodyPath;
|
import weaver.xuanran.wang.traffic_bank.waco_first.annocation.BodyPath;
|
||||||
|
|
||||||
|
import java.util.List;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* <h1>威科先行信息实体类</h1>
|
* <h1>威科先行信息实体类</h1>
|
||||||
*
|
*
|
||||||
|
@ -29,4 +31,5 @@ public class Info {
|
||||||
private String punishmentAmount;
|
private String punishmentAmount;
|
||||||
@BodyPath
|
@BodyPath
|
||||||
private String bodyPath;
|
private String bodyPath;
|
||||||
|
private List<Attachment> attachments;
|
||||||
}
|
}
|
||||||
|
|
Some files were not shown because too many files have changed in this diff Show More
Loading…
Reference in New Issue