上传文件

jingwei
ic_excellent 2023-06-02 11:00:00 +08:00
parent 3b00297fef
commit 2dbea71ba0
18 changed files with 879 additions and 24 deletions

View File

@ -0,0 +1,55 @@
package com.api.bokang.xiao.sh_bigdata.controller;
import aiyh.utils.ApiResult;
import aiyh.utils.Util;
import com.api.bokang.xiao.sh_bigdata.service.ReportService;
import io.swagger.v3.oas.annotations.parameters.RequestBody;
import org.apache.log4j.Logger;
import weaver.hrm.HrmUserVarify;
import weaver.hrm.User;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import javax.ws.rs.POST;
import javax.ws.rs.Path;
import javax.ws.rs.Produces;
import javax.ws.rs.core.Context;
import javax.ws.rs.core.MediaType;
import java.util.List;
import java.util.Map;
/**
* @ClassName YearReviewController
* @Author
* @Date 2023/2/14 17:00
* @Description <h1></h1>
**/
@Path("/xbk/sh_bigdata")
public class ReportController {
private final Logger log = Util.getLogger();
ReportService reportService = new ReportService();
/**
* <h2></h2>
* @param request
* @param response
* @param param
* @return
*/
@Path("/getReportData")
@POST
@Produces(MediaType.APPLICATION_JSON)
public String getReportData(@Context HttpServletRequest request, @Context HttpServletResponse response, @RequestBody Map<String,Object> param) {
try{
log.info("into getReportData success params ==> "+param);
User loginUser = HrmUserVarify.getUser(request, response);
List<Map<String, Object>> reportData = reportService.queryReportData(param, loginUser);
return ApiResult.success(reportData);
}catch (Exception e){
log.error("getReportData error ==> "+Util.getErrString(e));
return ApiResult.error(e.getMessage());
}
}
}

View File

@ -0,0 +1,39 @@
package com.api.bokang.xiao.sh_bigdata.mapper;
import aiyh.utils.annotation.recordset.*;
import java.util.List;
import java.util.Map;
/**
* @ClassName ReviewMapper
* @Author
* @Date 2023/2/14 17:02
* @Description <h1></h1>
**/
@SqlMapper
public interface ReportMapper {
/**
* <h2></h2>
* @param uid id
* @param param
* @return
*/
@Select("select id, ysdx, hdlb, ysrq, ysclhjsy, hbcc, xcap, gzryhcl, zs, ykdhhgbs, " +
" dyjbr, (select lastname from hrmresource where id = dyjbr) dyjbr_span," +
" djr, (select lastname from hrmresource where id = djr) djr_span," +
" ldrlddw, rwzt, bz, ysjsy, ysrs, cfsj1, ddsj1, sfz, ddz, gzcl, gbs, lddw, lxr, lxrdh " +
" from $t{param.table} $t{param.whereSql} order by ysrq ")
@CaseConversion(value = false)
List<Map<String, Object>> queryReportData(@ParamMapper("param") Map<String,Object> param,@ParamMapper("uid") int uid);
@Select("select id,dlsk,yslx,hbcc,sfsj,ddsj,sfd,ddd,wdwcl,dwcljsy,wdwclqt,xcap,lxr,lxrdh,bz,gzcl,gzry,zs,dyjbr,djr,ldr,lddw,rwzt,ykdh,gbs, " +
" (select LISTAGG(wb, ',') WITHIN GROUP (ORDER BY wb) from uf_zwfwdjjmb_dt1 where mainid = main.id) ysdx, " +
" dyjbr, (select lastname from åhrmresource where id = dyjbr) dyjbr_span," +
" djr, (select lastname from hrmresource where id = djr) djr_span " +
" from uf_zwfwdjjmb main $t{param.whereSql} order by dlsk ")
@CaseConversion(value = false)
List<Map<String, Object>> queryReportData2(@ParamMapper("param") Map<String,Object> param,@ParamMapper("uid") int uid);
}

View File

@ -0,0 +1,47 @@
package com.api.bokang.xiao.sh_bigdata.service;
import aiyh.utils.Util;
import com.api.bokang.xiao.sh_bigdata.mapper.ReportMapper;
import weaver.general.TimeUtil;
import weaver.hrm.User;
import java.util.List;
import java.util.Map;
/**
* @ClassName ReviewService
* @Author
* @Date 2023/2/14 17:01
* @Description <h1></h1>
**/
public class ReportService {
private final ReportMapper reportMapper = Util.getMapper(ReportMapper.class);
/**
* <h2>top5</h2>
* @param param
* @param user
* @return
*/
public List<Map<String,Object>> queryReportData(Map<String,Object> param, User user){
String currentDate = Util.null2String(param.get("currentDate"));
String registrationPeople = Util.null2String(param.get("registrationPeople"));
String registrationPeopleSpan = Util.null2String(param.get("registrationPeopleSpan"));
param.put("whereSql","");
String whereSql = "";
if(!"".equals(currentDate)){
whereSql += " and dlsk = #{param.currentDate} ";
}else {
param.put("today", TimeUtil.getCurrentDateString());
whereSql += " and dlsk >= #{param.today} ";
}
if(!"".equals(registrationPeople)){
whereSql += " and djr = #{param.registrationPeople} ";
}
whereSql = whereSql.replaceFirst(" and "," where ");
param.put("whereSql",whereSql);
return reportMapper.queryReportData2(param,user.getUID());
}
}

View File

@ -17,6 +17,7 @@ import javax.ws.rs.Path;
import javax.ws.rs.Produces; import javax.ws.rs.Produces;
import javax.ws.rs.core.Context; import javax.ws.rs.core.Context;
import javax.ws.rs.core.MediaType; import javax.ws.rs.core.MediaType;
import java.util.List;
import java.util.Map; import java.util.Map;
/** /**
@ -30,7 +31,7 @@ public class BankController {
private final Logger log = Util.getLogger(); private final Logger log = Util.getLogger();
private final BankService reportService = new BankService(); private final BankService bankService = new BankService();
/** /**
* <h2></h2> * <h2></h2>
@ -46,11 +47,34 @@ public class BankController {
log.info("====== into getBankData success ======="); log.info("====== into getBankData success =======");
log.info("param:"+param); log.info("param:"+param);
User loginUser = HrmUserVarify.getUser(request, response); User loginUser = HrmUserVarify.getUser(request, response);
Map<String,Object> reportData = reportService.getBankData(loginUser, param); Map<String,Map<String,Object>> bankData = bankService.getBankData(loginUser, param);
return ApiResult.success(reportData); return ApiResult.success(bankData);
}catch (Exception e){ }catch (Exception e){
log.error("getBankData error ==> "+Util.getErrString(e)); log.error("getBankData error ==> "+Util.getErrString(e));
return ApiResult.error(e.getMessage()); return ApiResult.error(e.getMessage());
} }
} }
/**
* <h2></h2>
* @param request
* @param response
* @return
*/
@Path("/getCommonSelect")
@POST
@Produces(MediaType.APPLICATION_JSON)
public String getCommonSelect(@Context HttpServletRequest request, @Context HttpServletResponse response, @RequestBody Map<String,Object> param) {
try{
log.info("====== into getCommonSelect success =======");
log.info("param:"+param);
User loginUser = HrmUserVarify.getUser(request, response);
List<Map<String, Object>> bankSelectInfo = bankService.getBankSelectInfo(loginUser, param);
return ApiResult.success(bankSelectInfo);
}catch (Exception e){
log.error("getCommonSelect error ==> "+Util.getErrString(e));
return ApiResult.error(e.getMessage());
}
}
} }

View File

@ -1,10 +1,109 @@
package com.api.bokang.xiao.zhenn.mapper; package com.api.bokang.xiao.zhenn.mapper;
import aiyh.utils.annotation.recordset.Select;
import aiyh.utils.annotation.recordset.SqlMapper;
import java.util.List;
import java.util.Map;
/** /**
* @ClassName ContractMapper * @ClassName ContractMapper
* @Author * @Author
* @Date 2023/5/8 16:16 * @Date 2023/5/8 16:16
* @Description <h1></h1> * @Description <h1></h1>
**/ **/
public class BankMapper { @SqlMapper
public interface BankMapper {
/**
* <h2></h2>
* @param param
* @return
*/
@Select("SELECT t.requestid requestId,t.$t{amountField} amount,t.$t{amountField} outAmount," +
" $t{inCompany} inCompany,wb.lastoperatedate outDate," +
" (select top 1 xmlsend from workflowToFinanceUrl where wb.requestid = t.requestId and xmlsend IS NOT NULL order by id desc) xmlsend " +
"FROM $t{tableName} t " +
"INNER JOIN workflow_requestbase wb ON t.requestid = wb.requestid " +
"WHERE wb.currentnodetype = 3 " +
" AND wb.lastoperatedate BETWEEN #{beginDate} AND #{endDate} " +
" AND $t{currencyField} = #{currency}")
List<Map<String,Object>> queryOaOutList(Map<String, Object> param);
/**
* <h2></h2>
* @param param
* @return
*/
@Select("SELECT t.requestid requestId,t.$t{amountField} amount,t.$t{amountField} outAmount," +
" $t{inCompany} inCompany,wb.lastoperatedate outDate," +
" (select top 1 xmlsend from workflowToFinanceUrl where wb.requestid = t.requestId and xmlsend IS NOT NULL order by id desc) xmlsend " +
"FROM $t{tableName} t " +
"INNER JOIN workflow_requestbase wb ON t.requestid = wb.requestid " +
"WHERE wb.currentnodetype = 3 " +
" AND wb.lastoperatedate BETWEEN #{beginDate} AND #{endDate} " +
" AND $t{currencyField} = #{currency}" +
" AND t.$t{bankAccountField} = #{currentBankAccount}")
List<Map<String,Object>> queryOaOutBank(Map<String, Object> param);
/**
* <h2></h2>
* @param param
* @return
*/
@Select("SELECT t.requestid,t.$t{amountField} amount,t.$t{amountField} inAmount," +
" $t{inCompany} outCompany,wb.lastoperatedate inDate,wfu.xmlsend,t.$t{payInfoField} payInfo " +
"FROM $t{tableName} t " +
"INNER JOIN workflow_requestbase wb ON t.requestid = wb.requestid " +
"WHERE wb.currentnodetype = 3 " +
" AND wb.lastoperatedate BETWEEN #{beginDate} AND #{endDate} " +
" AND $t{currencyField} = #{currency}" +
" AND t.$t{bankAccountField} = #{currentBank}")
List<Map<String,Object>> queryOaInBank(Map<String, Object> param);
/**
* <h2></h2>
* @param param
* @return
*/
@Select("select id,txnamt amount,txnamt difAmount,txnamt outAmount,insid," +
" insid outFlowNo,txndate_time,actacn,tobank inCompany from uf_bank_trade_info " +
"where txndate_time BETWEEN #{beginDate} AND #{endDate} " +
" and trncur = #{currencySpan}" +
" and actacn = #{currentBankAccount}")
List<Map<String,Object>> queryBankOutInfo(Map<String,Object> param);
/**
* <h2></h2>
* @param param
* @return
*/
@Select("select id,id payInfo,txnamt amount,txnamt difAmount,txnamt inAmount,insid," +
" insid inFlowNo,txndate_time,actacn,ibkname outCompany from uf_bank_trade_info " +
"where txndate_time BETWEEN #{beginDate} AND #{endDate} " +
" and trncur = #{currencySpan}" +
" and actacn_receipt = #{currentBankAccount}")
List<Map<String,Object>> queryBankInInfo(Map<String,Object> param);
/**
* <h2></h2>
* @param param
* @return
*/
@Select("select sum(avabal) from uf_bank_day_balance " +
"where actacn = #{currentBankAccount} and curcde = #{currencySpan} and baldat BETWEEN #{beginDate} AND #{endDate} ")
double queryBankDayAmount(Map<String, Object> param);
/**
* <h2></h2>
* @param param
* @return
*/
@Select("select sum(EvBalance) from uf_period_balance " +
"where glAccount = #{bankSubject} " +
" and EvCurrency = #{currencySpan} " +
" and IvFiscYear = YEAR(#{beginDate}) " +
" and IvFisPeriod = MONTH(#{beginDate})")
double queryBankStatementBalance(Map<String, Object> param);
} }

View File

@ -1,8 +1,18 @@
package com.api.bokang.xiao.zhenn.service; package com.api.bokang.xiao.zhenn.service;
import aiyh.utils.Util;
import com.alibaba.fastjson.JSON;
import com.api.bokang.xiao.zhenn.mapper.BankMapper;
import org.apache.log4j.Logger;
import weaver.bokang.xiao.common.CommonUtil;
import weaver.bokang.xiao.common.mapper.WorkflowMapper;
import weaver.hrm.User; import weaver.hrm.User;
import java.util.ArrayList;
import java.util.HashMap;
import java.util.List;
import java.util.Map; import java.util.Map;
import java.util.stream.Collectors;
/** /**
* @ClassName ContractService * @ClassName ContractService
@ -12,13 +22,147 @@ import java.util.Map;
**/ **/
public class BankService { public class BankService {
private final BankMapper bankMapper = Util.getMapper(BankMapper.class);
private final WorkflowMapper workflowMapper = Util.getMapper(WorkflowMapper.class);
private final Logger log = Util.getLogger();
/** /**
* <h2></h2> * <h2></h2>
*
* <p>
* param{
* currentBank:"当前银行下拉框索引",
* currentBankAccount:"当前银行下拉框账号",
* currentBankSpan:"当前银行名称",
* outParam:[{
* table:"流程表名",
* workflowId:"流程id",
* amountField:"金额字段名",
* bankAccountField:"银行账号字段",
* queryTye:"1、付款账号固定2、付款账号不固定"
* }]:"付款参数条件",
* inParam:[{
* table:"流程表名",
* workflowId:"流程id",
* amountField:"金额字段名",
* bankAccountField:"银行账号字段",
* }]:"收款参数条件"
* }
* </p
*
* @param loginUser * @param loginUser
* @param param * @param param
* @return * @return
*/ */
public Map<String, Object> getBankData(User loginUser, Map<String, Object> param) { public Map<String,Map<String,Object>> getBankData(User loginUser, Map<String, Object> param) {
return null; Map<String,Map<String,Object>> bankData = new HashMap<>();
Map<String,Object> bankBaseInfo = new HashMap<>();
String currentBankSpan = Util.null2String(param.get("currentBankSpan"));
String bankAccount = Util.null2String(param.get("currentBankAccount"));
List<Map<String,Object>> outParam = (List<Map<String, Object>>) param.get("outParam");
List<Map<String,Object>> inParam = (List<Map<String, Object>>) param.get("inParam");
//查询数据
List<Map<String, Object>> oaOutList = outParam.stream()
.flatMap(item -> {
String queryTye = Util.null2String(item.get("queryTye"));
item.put("currentBankAccount",bankAccount);
item.put("beginDate",Util.null2String(param.get("beginDate")));
item.put("endDate",Util.null2String(param.get("endDate")));
item.put("currency",Util.null2String(param.get("currency")));
item.put("currencySpan",Util.null2String(param.get("endDate")));
item.put("bankSubject",Util.null2String(param.get("bankSubject")));
item.put("currentBank",Util.null2String(param.get("currentBank")));
List<Map<String, Object>> tempOutList = "1".equals(queryTye) ? bankMapper.queryOaOutList(item) : bankMapper.queryOaOutBank(item);
for (Map<String, Object> tempOut : tempOutList) {
String xmlSend = Util.null2String(tempOut.get("xmlsend"));
String insId = CommonUtil.getNodeValue(xmlSend, "insid");
tempOut.put("insId",insId);
}
return tempOutList.stream();
})
.collect(Collectors.toList());
List<Map<String, Object>> oaInList = inParam.stream()
.flatMap(item -> {
item.put("currentBankAccount",bankAccount);
item.put("beginDate",Util.null2String(param.get("beginDate")));
item.put("endDate",Util.null2String(param.get("endDate")));
item.put("currency",Util.null2String(param.get("currency")));
item.put("currencySpan",Util.null2String(param.get("endDate")));
item.put("bankSubject",Util.null2String(param.get("bankSubject")));
item.put("currentBank",Util.null2String(param.get("currentBank")));
return bankMapper.queryOaInBank(item).stream();
})
.collect(Collectors.toList());
List<Map<String, Object>> bankOutList = bankMapper.queryBankOutInfo(param);
List<Map<String, Object>> bankInList = bankMapper.queryBankInInfo(param);
//计算有差异的集合
List<Map<String, Object>> oaOutTable = CommonUtil.difference(oaOutList, bankOutList, map -> map.get("insid"));
List<Map<String, Object>> bankOutTable = CommonUtil.difference(bankOutList,oaOutList, map -> map.get("insid"));
List<Map<String, Object>> bankInTable = CommonUtil.difference(bankInList,oaInList, map -> map.get("payInfo"));
List<Map<String, Object>> oaInTable = new ArrayList<>();
//银行信息
bankBaseInfo.put("bankName",currentBankSpan);
bankBaseInfo.put("bankAccount",bankAccount);
//求总和
Map<String, Object> amountMap = new HashMap<>();
double bankDayAmount = this.queryBankDayAmount(param);
double bankStatementBalance = this.queryBankStatementBalance(param);
double bankInDifference = bankInTable.stream().mapToDouble(item -> Double.parseDouble(item.get("amount").toString())).sum();
double oaInDifference = 0;
double bankOutDifference = bankOutTable.stream().mapToDouble(item -> Double.parseDouble(item.get("amount").toString())).sum();
double oaOutDifference = oaOutTable.stream().mapToDouble(item -> Double.parseDouble(item.get("amount").toString())).sum();
double bankDayAmountUpdate = bankDayAmount + bankInDifference - bankOutDifference;
double bankStatementBalanceUpdate = bankStatementBalance + oaInDifference - oaOutDifference;
//返回数据组装
amountMap.put("bankInDifference",bankInDifference);
amountMap.put("oaInDifference",oaInDifference);
amountMap.put("bankOutDifference",bankOutDifference);
amountMap.put("oaOutDifference",oaOutDifference);
amountMap.put("bankDayAmount",bankDayAmount);
amountMap.put("bankStatementBalance",bankStatementBalance);
amountMap.put("bankDayAmountUpdate",bankDayAmountUpdate);
amountMap.put("bankStatementBalanceUpdate",bankStatementBalanceUpdate);
Map<String, Object> bankTableListData = new HashMap<>();
bankTableListData.put("oaOutTable",oaOutTable);
bankTableListData.put("bankOutTable",bankOutTable);
bankTableListData.put("bankInTable",bankInTable);
bankTableListData.put("oaInTable",oaInTable);
bankData.put("bankBaseData",bankBaseInfo);
bankData.put("bankAmountData",amountMap);
bankData.put("bankTableListData",bankTableListData);
log.info("getBankData bankData 对账单报表信息==>"+ JSON.toJSONString(bankData));
return bankData;
} }
/**
* <h2></h2>
* @param loginUser
* @param param
* @return
*/
public List<Map<String,Object>> getBankSelectInfo(User loginUser, Map<String, Object> param){
String fieldName = Util.null2String(param.get("fieldName"));
return workflowMapper.queryCommonSelect(fieldName);
}
/**
* <h2></h2>
* @param param
* @return <
*/
private double queryBankDayAmount(Map<String, Object> param){
return bankMapper.queryBankDayAmount(param);
}
/**
* <h2></h2>
* @param param
* @return <
*/
private double queryBankStatementBalance(Map<String, Object> param){
return bankMapper.queryBankStatementBalance(param);
}
} }

View File

@ -100,10 +100,11 @@ public class SyncAccountTradeInfoJob extends BaseCronJob {
xmlParams.put("type", "2002"); xmlParams.put("type", "2002");
xmlParams.put("ibknum", ibknum); xmlParams.put("ibknum", ibknum);
xmlParams.put("actacn", actacn); xmlParams.put("actacn", actacn);
xmlParams.put("from", "20220919"); //xmlParams.put("from", "20220919");
Calendar cal = Calendar.getInstance(); Calendar cal = Calendar.getInstance();
cal.set(Calendar.DAY_OF_MONTH, -1); cal.set(Calendar.DAY_OF_MONTH, -1);
xmlParams.put("to", ZennerUtil.parseToDateString(cal.getTime(), ZennerUtil.formatYYYYMMDD_NoSplit)); xmlParams.put("from", ZennerUtil.parseToDateString(cal.getTime(), ZennerUtil.formatYYYYMMDD_NoSplit));
xmlParams.put("to", ZennerUtil.parseToDateString(new Date(), ZennerUtil.formatYYYYMMDD_NoSplit));
xmlParams.put("amountFrom", "1"); xmlParams.put("amountFrom", "1");
xmlParams.put("amountTo", "100000"); xmlParams.put("amountTo", "100000");
xmlParams.put("begnum", start + ""); xmlParams.put("begnum", start + "");

View File

@ -1,7 +1,14 @@
package weaver.bokang.xiao.common; package weaver.bokang.xiao.common;
import java.util.Map; import org.jdom.Document;
import java.util.Set; import org.jdom.Element;
import org.jdom.input.SAXBuilder;
import java.io.StringReader;
import java.lang.reflect.Field;
import java.util.*;
import java.util.function.BiPredicate;
import java.util.function.Function;
/** /**
* @ClassName CommonUtil * @ClassName CommonUtil
@ -68,4 +75,159 @@ public class CommonUtil {
} }
return fixStr.substring(0, fixStr.length() - 1) + " "; return fixStr.substring(0, fixStr.length() - 1) + " ";
} }
/**
* XML
* @param xml XML
* @param nodeName
* @return
*/
public static String getNodeValue(String xml, String nodeName) {
try {
// 创建 SAXBuilder 对象
SAXBuilder builder = new SAXBuilder();
// 创建 StringReader 对象,并将 XML 字符串作为参数传入
StringReader reader = new StringReader(xml);
// 使用 SAXBuilder 对象解析 XML得到 Document 对象
Document doc = builder.build(reader);
// 获取根节点
Element root = doc.getRootElement();
// 调用递归方法获取节点值
String nodeValue = getNodeValue(root, nodeName);
// 如果节点值为空,则返回空字符串
return nodeValue == null ? "" : nodeValue;
} catch (Exception e) {
// 如果解析 XML 异常,则返回空字符串
return "";
}
}
/**
*
* @param element
* @param nodeName
* @return null
*/
private static String getNodeValue(Element element, String nodeName) {
// 获取当前节点的子节点
Element node = element.getChild(nodeName);
// 如果子节点中存在指定的节点,则返回节点的值
if (node != null) {
return node.getValue();
} else {
// 否则遍历子节点,递归调用 getNodeValue 方法,直到找到指定节点为止
List<Element> children = element.getChildren();
if (Objects.nonNull(children) && children.size() > 0) {
for (Element child : children) {
String value = getNodeValue(child, nodeName);
if (value != null) {
return value;
}
}
}
// 如果遍历完所有子节点都没有找到指定节点,则返回 null
return null;
}
}
/**
* List
*
* @param list1 List
* @param list2 List
* @param fieldName
* @param <T>
* @return
* @throws NoSuchFieldException
* @throws IllegalAccessException 访
*/
public static <T> List<T> intersection(List<? extends T> list1, List<? extends T> list2, String fieldName) throws NoSuchFieldException, IllegalAccessException {
return CommonUtil.intersection(list1, list2, (t1, t2) -> {
try {
Object fieldValue1 = getFieldValue(t1, fieldName);
Object fieldValue2 = getFieldValue(t2, fieldName);
return fieldValue1 != null && fieldValue1.equals(fieldValue2);
} catch (NoSuchFieldException | IllegalAccessException e) {
return false;
}
});
}
/**
* List
*
* @param list1 List
* @param list2 List
* @param matcher truefalse
* @param <T>
* @return
*/
public static <T> List<T> intersection(List<? extends T> list1, List<? extends T> list2, BiPredicate<? super T, ? super T> matcher) {
Set<T> set = new HashSet<>(list1);
List<T> result = new ArrayList<>();
for (T t2 : list2) {
if (set.contains(t2) && matcher.test(set.iterator().next(), t2)) {
result.add(t2);
}
}
return result;
}
/**
* ListListList
*
* @param list1 List
* @param list2 List
* @param matcher truefalse
* @param <T>
* @return
*/
public static <T> List<T> difference(List<? extends T> list1, List<? extends T> list2, BiPredicate<? super T, ? super T> matcher) {
Set<T> set2 = new HashSet<>(list2);
List<T> result = new ArrayList<>();
for (T t1 : list1) {
if (!set2.contains(t1) || !matcher.test(t1, set2.iterator().next())) {
result.add(t1);
}
}
return result;
}
/**
* ListListList
*
* @param list1 List
* @param list2 List
* @param keyFunc Key
* @param <T>
* @param <K> Key
* @return
*/
public static <T, K> List<T> difference(List<? extends T> list1, List<? extends T> list2, Function<? super T, ? extends K> keyFunc) {
BiPredicate<? super T, ? super T> matcher = (t1, t2) -> Objects.equals(keyFunc.apply(t1), keyFunc.apply(t2));
return difference(list1, list2, matcher);
}
private static Object getFieldValue(Object obj, String fieldName) throws NoSuchFieldException, IllegalAccessException {
if (obj instanceof Map) {
// 如果对象是Map类型则直接返回指定键的值
Map<?, ?> map = (Map<?, ?>) obj;
return map.get(fieldName);
} else {
// 如果对象是JavaBean类型则通过反射获取指定属性的值
Class<?> clazz = obj.getClass();
while (clazz != null) {
try {
Field field = clazz.getDeclaredField(fieldName);
field.setAccessible(true);
return field.get(obj);
} catch (NoSuchFieldException e) {
// 如果当前类没有指定的属性,则向上查找父类
clazz = clazz.getSuperclass();
}
}
// 如果所有父类都没有指定的属性,则抛出异常
throw new NoSuchFieldException(fieldName);
}
}
} }

View File

@ -2,6 +2,7 @@ package weaver.bokang.xiao.common.mapper;
import aiyh.utils.annotation.recordset.*; import aiyh.utils.annotation.recordset.*;
import java.util.List;
import java.util.Map; import java.util.Map;
import java.util.Set; import java.util.Set;
@ -37,6 +38,12 @@ public interface WorkflowMapper {
@ParamMapper("fieldValue") String fieldValue, @ParamMapper("fieldValue") String fieldValue,
@ParamMapper("requestId") String requestId); @ParamMapper("requestId") String requestId);
@Select("select detail.id as `key`,detail.name as showname " +
"from mode_selectitempage page " +
"inner join mode_selectitempagedetail detail on page.id = detail.mainid " +
"where page.selectitemname = #{fieldName}")
List<Map<String,Object>> queryCommonSelect(@ParamMapper("fieldName")String fieldName);
/** /**
* <h2>sql</h2> * <h2>sql</h2>
* @param cusSql sql * @param cusSql sql

View File

@ -0,0 +1,130 @@
package weaver.bokang.xiao.common.model_update.process;
import aiyh.utils.Util;
import aiyh.utils.annotation.MethodRuleNo;
import org.apache.log4j.Logger;
import weaver.bokang.xiao.common.model_update.function.ConditionFunction;
import java.lang.reflect.InvocationTargetException;
import java.lang.reflect.Method;
import java.util.HashMap;
import java.util.Map;
/**
* @ClassName ConditionWhereProcess
* @Author
* @Date 2023/5/15 14:40
* @Description <h1></h1>
**/
public class ConditionWhereProcess {
public static final Map<Integer, ConditionFunction<String,Map<String,Object>,Map<String,Object>,String>> MODE_METHOD_MAP = new HashMap<>();
public static final Logger logger = Util.getLogger();
static {
try {
Class<ConditionTargetProcess> valueRuleMethodClass = ConditionTargetProcess.class;
Method[] methods = valueRuleMethodClass.getDeclaredMethods();
for (Method method : methods) {
if (method.isAnnotationPresent(MethodRuleNo.class)) {
MethodRuleNo annotation = method.getAnnotation(MethodRuleNo.class);
int value = annotation.value();
MODE_METHOD_MAP.put(value, (whereParam,param,whereSql) -> {
try {
return (String) method.invoke(null,whereParam,param,whereSql);
} catch (IllegalAccessException | InvocationTargetException e) {
throw new RuntimeException(e);
}
});
}
}
}catch (Exception exception){
logger.error("ConditionTargetProcess init error !!! "+Util.getErrString(exception));
}
}
/**
* <h2></h2>
* @param whereParam
* @param param
* @param whereSql sql
* @return sql
*/
@MethodRuleNo(value = 0, desc = "等于")
public static String equals(Map<String,Object> whereParam,Map<String,Object> param,String whereSql) {
String conditionValue = Util.null2String(param.get("conditionValue"));
String targetFieldName = Util.null2String(param.get("targetFieldName"));
String targetStr = " and "+targetFieldName+" = #{whereParam."+targetFieldName+"}";
whereSql += targetStr;
whereParam.put(targetFieldName,conditionValue);
return whereSql;
}
/**
* <h2></h2>
* @param whereParam
* @param param
* @param whereSql sql
* @return sql
*/
@MethodRuleNo(value = 1, desc = "不等于")
public static String noEquals(Map<String,Object> whereParam,Map<String,Object> param,String whereSql) {
String conditionValue = Util.null2String(param.get("conditionValue"));
String targetFieldName = Util.null2String(param.get("targetFieldName"));
String targetStr = " and "+targetFieldName+" <> #{whereParam."+targetFieldName+"}";
whereSql += targetStr;
whereParam.put(targetFieldName,conditionValue);
return whereSql;
}
/**
* <h2></h2>
* @param whereParam
* @param param
* @param whereSql sql
* @return sql
*/
@MethodRuleNo(value = 6, desc = "in")
public static String in(Map<String,Object> whereParam,Map<String,Object> param,String whereSql) {
String conditionValue = Util.null2String(param.get("conditionValue"));
String targetFieldName = Util.null2String(param.get("targetFieldName"));
String targetStr = " and "+targetFieldName+" in ( $t{whereParam."+targetFieldName+"})";
whereSql += targetStr;
whereParam.put(targetFieldName,conditionValue);
return whereSql;
}
/**
* <h2></h2>
* @param whereParam
* @param param
* @param whereSql sql
* @return sql
*/
@MethodRuleNo(value = 7, desc = "not in")
public static String notIn(Map<String,Object> whereParam,Map<String,Object> param,String whereSql) {
String conditionValue = Util.null2String(param.get("conditionValue"));
String targetFieldName = Util.null2String(param.get("targetFieldName"));
String targetStr = " and "+targetFieldName+" not in ( $t{whereParam."+targetFieldName+"})";
whereSql += targetStr;
whereParam.put(targetFieldName,conditionValue);
return whereSql;
}
/**
* <h2></h2>
* @param whereParam
* @param param
* @param whereSql sql
* @return sql
*/
@MethodRuleNo(value = 8, desc = "自定义sql")
public static String cusSql(Map<String,Object> whereParam,Map<String,Object> param,String whereSql) {
String conditionValue = Util.null2String(param.get("conditionValue"));
String targetStr = " and "+Util.sbc2dbcCase(conditionValue);
whereSql += targetStr;
return whereSql;
}
}

View File

@ -7,6 +7,7 @@ import aiyh.utils.annotation.ActionOptionalParam;
import aiyh.utils.annotation.PrintParamMark; import aiyh.utils.annotation.PrintParamMark;
import aiyh.utils.annotation.RequiredMark; import aiyh.utils.annotation.RequiredMark;
import aiyh.utils.excention.CustomerException; import aiyh.utils.excention.CustomerException;
import com.alibaba.fastjson.JSON;
import lombok.Setter; import lombok.Setter;
import weaver.bokang.xiao.common.CommonUtil; import weaver.bokang.xiao.common.CommonUtil;
import weaver.bokang.xiao.common.mapper.WorkflowMapper; import weaver.bokang.xiao.common.mapper.WorkflowMapper;
@ -50,12 +51,14 @@ public class DateFieldUpdateAction extends SafeCusBaseAction {
if(sourceDateFieldArray.length != targetDateFieldArray.length){ if(sourceDateFieldArray.length != targetDateFieldArray.length){
throw new CustomerException("请确保需要格式化的字段数量与存储字段数量一致"); throw new CustomerException("请确保需要格式化的字段数量与存储字段数量一致");
} }
log.info("workflowData ==>"+ JSON.toJSONString(workflowData));
Map<String,Object> dateFormat = new HashMap<>(); Map<String,Object> dateFormat = new HashMap<>();
for (int i = 0; i < sourceDateFieldArray.length; i++) { for (int i = 0; i < sourceDateFieldArray.length; i++) {
String sourceDateField = sourceDateFieldArray[i]; String sourceDateField = sourceDateFieldArray[i];
String targetDateField = targetDateFieldArray[i]; String targetDateField = targetDateFieldArray[i];
String sourceDate = Util.null2String(workflowData.get(sourceDateField)); String sourceDate = Util.null2String(workflowData.get(sourceDateField));
String targetDate = formatDate(sourceDate); String targetDate = formatDate(sourceDate);
log.info(String.format("sourceDateField:[%s],targetDateField:[%s],sourceDate:[%s],targetDate:[%s]",sourceDateField,targetDateField,sourceDate,targetDate));
dateFormat.put(targetDateField,targetDate); dateFormat.put(targetDateField,targetDate);
} }
Map<String,Object> whereParam = new HashMap<>(); Map<String,Object> whereParam = new HashMap<>();

View File

@ -18,7 +18,7 @@ public interface PorscheMapper {
List<Map<String,Object>> queryCompanyInfo(@ParamMapper("statusField")String statusField); List<Map<String,Object>> queryCompanyInfo(@ParamMapper("statusField")String statusField);
@Update("update uf_zcgsxx set sfrz = #{authenticationStatus},fadadaid = #{contractId} where id = #{dataId}") @Update("update uf_zcgsxx set sfrz = #{authenticationStatus},fadadaid = #{contractId} where id = #{dataId}")
boolean updateAuthenticationStatus(@ParamMapper("authenticationField")String authenticationStatus, boolean updateAuthenticationStatus(@ParamMapper("authenticationStatus")String authenticationStatus,
@ParamMapper("authenticationStatus")String companyNo, @ParamMapper("contractId")String contractId,
@ParamMapper("dataId")int dataId); @ParamMapper("dataId")int dataId);
} }

View File

@ -59,7 +59,7 @@ public class CompanyWriteBackSchedule extends CusBaseCronJob {
Map<String,Object> certificationStatusResource = (Map<String, Object>) companyInfo.get("certificationStatusResource"); Map<String,Object> certificationStatusResource = (Map<String, Object>) companyInfo.get("certificationStatusResource");
int dataId = Util.getIntValue(String.valueOf(map.get("id"))); int dataId = Util.getIntValue(String.valueOf(map.get("id")));
String authenticationStatus = Util.null2String(certificationStatusResource.get("verifiedStatus")); String authenticationStatus = Util.null2String(certificationStatusResource.get("verifiedStatus"));
String companyNo = Util.null2String(companyInfo.get("companyInfo")); String companyNo = Util.null2String(companyInfo.get("companyNo"));
porscheMapper.updateAuthenticationStatus(authenticationStatus,companyNo,dataId); porscheMapper.updateAuthenticationStatus(authenticationStatus,companyNo,dataId);
} }
} }

View File

@ -5,6 +5,7 @@ import aiyh.utils.action.SafeCusBaseAction;
import aiyh.utils.annotation.ActionDesc; import aiyh.utils.annotation.ActionDesc;
import aiyh.utils.annotation.ActionOptionalParam; import aiyh.utils.annotation.ActionOptionalParam;
import aiyh.utils.annotation.PrintParamMark; import aiyh.utils.annotation.PrintParamMark;
import aiyh.utils.annotation.RequiredMark;
import com.alibaba.fastjson.JSON; import com.alibaba.fastjson.JSON;
import lombok.Setter; import lombok.Setter;
import weaver.bokang.xiao.common.mapper.WorkflowMapper; import weaver.bokang.xiao.common.mapper.WorkflowMapper;
@ -31,7 +32,7 @@ public class DataPushAction extends SafeCusBaseAction {
/** 数据推送接口唯一标识 */ /** 数据推送接口唯一标识 */
@PrintParamMark @PrintParamMark
@ActionOptionalParam(value = "",desc = "数据推送接口唯一标识") @RequiredMark(value = "",desc = "数据推送接口唯一标识")
private String requestUnique; private String requestUnique;
private final WorkflowMapper workflowMapper = Util.getMapper(WorkflowMapper.class); private final WorkflowMapper workflowMapper = Util.getMapper(WorkflowMapper.class);

View File

@ -26,8 +26,7 @@ import java.util.stream.Collectors;
* @Date 2023/3/17 19:58 * @Date 2023/3/17 19:58
* @Description <h1></h1> * @Description <h1></h1>
**/ **/
@Data
@ActionDesc(value = "生成报表信息", author = "bokang.xiao")
public class GenerateReportSchedule extends CusBaseCronJob { public class GenerateReportSchedule extends CusBaseCronJob {

View File

@ -71,6 +71,9 @@ public class OneNetComAction extends SafeCusBaseAction {
@ActionOptionalParam(value = "",desc = "网关调用办理接口的apiId") @ActionOptionalParam(value = "",desc = "网关调用办理接口的apiId")
private String handleApiName; private String handleApiName;
@ActionOptionalParam(value = "已办结办件不允许修改",desc = "错误信息不阻止流程")
private String continueError = "已办结办件不允许修改";
private final WorkflowMapper workflowMapper = Util.getMapper(WorkflowMapper.class); private final WorkflowMapper workflowMapper = Util.getMapper(WorkflowMapper.class);
private final DealWithMapping dealWithMapping = new DealWithMapping(); private final DealWithMapping dealWithMapping = new DealWithMapping();
@ -82,8 +85,10 @@ public class OneNetComAction extends SafeCusBaseAction {
@Override @Override
public void doSubmit(String requestId, String billTable, int workflowId, User user, RequestInfo requestInfo) { public void doSubmit(String requestId, String billTable, int workflowId, User user, RequestInfo requestInfo) {
log.info(String.format("=================== {%s} {requestId : %s} begin ======================", this.getClass().getName(),requestId)); log.info(String.format("=================== {%s} {requestId : %s} begin ======================", this.getClass().getName(),requestId));
Map<String, Object> workflowMessage = workflowMapper.queryWorkflowByRequestId(requestId, billTable); //Map<String, Object> workflowMessage = workflowMapper.queryWorkflowByRequestId(requestId, billTable);
Map<String, Object> workflowMessage = this.getObjMainTableValue(requestInfo);
dealWithMapping.setMainTable(billTable); dealWithMapping.setMainTable(billTable);
log.info("workflowMessage ==>"+JSON.toJSONString(workflowMessage));
try{ try{
if(StringUtils.isNotBlank(acceptUnique) && StringUtils.isNotBlank(acceptApiName)) { if(StringUtils.isNotBlank(acceptUnique) && StringUtils.isNotBlank(acceptApiName)) {
requestHandle(workflowMessage,acceptUnique,acceptApiName,requestId,billTable,"受理请求"); requestHandle(workflowMessage,acceptUnique,acceptApiName,requestId,billTable,"受理请求");
@ -128,6 +133,10 @@ public class OneNetComAction extends SafeCusBaseAction {
whereParam.put("requestid",requestId); whereParam.put("requestid",requestId);
sqlUtil.updateMode(billTable, updateMsg, whereParam); sqlUtil.updateMode(billTable, updateMsg, whereParam);
}else { }else {
if(continueError.equals(message)){
log.info("The error message for this request is related to whitelist content and will not block the submission of the action message:"+message );
return;
}
throw new CustomerException(desc+"请求失败 ==>"+message); throw new CustomerException(desc+"请求失败 ==>"+message);
} }
}else { }else {

View File

@ -8,8 +8,10 @@ import basetest.BaseTest;
import bokang.xiao.entity.CourseEntity; import bokang.xiao.entity.CourseEntity;
import bokang.xiao.entity.StudentEntity; import bokang.xiao.entity.StudentEntity;
import bokang.xiao.entity.TeacherEntity; import bokang.xiao.entity.TeacherEntity;
import bokang.xiao.util.XmlParser;
import cn.afterturn.easypoi.excel.ExcelExportUtil; import cn.afterturn.easypoi.excel.ExcelExportUtil;
import cn.afterturn.easypoi.excel.entity.ExportParams; import cn.afterturn.easypoi.excel.entity.ExportParams;
import com.alibaba.fastjson.JSON;
import com.api.bokang.xiao.porsche_review.mapper.ReviewMapper; import com.api.bokang.xiao.porsche_review.mapper.ReviewMapper;
import com.api.bokang.xiao.wx_report.mapper.ReportMapper; import com.api.bokang.xiao.wx_report.mapper.ReportMapper;
@ -20,10 +22,13 @@ import com.api.bokang.xiao.zscq.service.impl.ReserveServiceImpl;
import org.apache.log4j.Logger; import org.apache.log4j.Logger;
import org.apache.poi.ss.usermodel.Workbook; import org.apache.poi.ss.usermodel.Workbook;
import org.junit.Test; import org.junit.Test;
import weaver.bokang.xiao.common.CommonUtil;
import weaver.bokang.xiao.common.mapper.ModeMapper; import weaver.bokang.xiao.common.mapper.ModeMapper;
import weaver.bokang.xiao.common.mapper.WorkflowMapper;
import weaver.bokang.xiao.deg_repeat_check.action.RepeatCheckAction; import weaver.bokang.xiao.deg_repeat_check.action.RepeatCheckAction;
import weaver.bokang.xiao.porsche.action.DateFieldUpdateAction; import weaver.bokang.xiao.porsche.action.DateFieldUpdateAction;
import weaver.bokang.xiao.porsche.schedule.CompanyWriteBackSchedule; import weaver.bokang.xiao.porsche.schedule.CompanyWriteBackSchedule;
import weaver.bokang.xiao.porsche.schedule.SalaryUpdateSchedule;
import weaver.bokang.xiao.sh_bigdata.action.DataPushAction; import weaver.bokang.xiao.sh_bigdata.action.DataPushAction;
import weaver.bokang.xiao.xhny_mode.search.CustomSearchDepart; import weaver.bokang.xiao.xhny_mode.search.CustomSearchDepart;
import weaver.bokang.xiao.xhny_report.entity.SourceTrackingData; import weaver.bokang.xiao.xhny_report.entity.SourceTrackingData;
@ -33,6 +38,7 @@ import weaver.bokang.xiao.xhny_report.service.ScoreChainPattern;
import weaver.bokang.xiao.zscq.action.OneNetComAction; import weaver.bokang.xiao.zscq.action.OneNetComAction;
import weaver.bokang.xiao.zscq.action.StatusChangeAction; import weaver.bokang.xiao.zscq.action.StatusChangeAction;
import weaver.bokang.xiao.zscq.config.service.ModeChangeService; import weaver.bokang.xiao.zscq.config.service.ModeChangeService;
import weaver.bokang.xiao.zscq.store.TableNameStore;
import weaver.bokang.xiao.zxyh.RepeatSubmitAction; import weaver.bokang.xiao.zxyh.RepeatSubmitAction;
import weaver.conn.RecordSet; import weaver.conn.RecordSet;
import weaver.general.StaticObj; import weaver.general.StaticObj;
@ -61,16 +67,16 @@ public class NormalTest extends BaseTest {
@Test @Test
public void testWord(){ public void testWord(){
//GenerateFileUtil.createCronJobDocument(CompanyWriteBackSchedule.class); GenerateFileUtil.createCronJobDocument(SalaryUpdateSchedule.class);
GenerateFileUtil.createActionDocument(DataPushAction.class); //GenerateFileUtil.createActionDocument(DataPushAction.class);
//GenerateFileUtil.createActionDocument(DateFieldUpdateAction.class); //GenerateFileUtil.createActionDocument(DateFieldUpdateAction.class);
} }
@Test @Test
public void testChain(){ public void testChain(){
GenerateReportSchedule generateReportSchedule = new GenerateReportSchedule(); GenerateReportSchedule generateReportSchedule = new GenerateReportSchedule();
generateReportSchedule.setReportModelId("-2915"); //generateReportSchedule.setReportModelId("-2915");
generateReportSchedule.setDataSource("NCC"); //generateReportSchedule.setDataSource("NCC");
generateReportSchedule.runCode(); generateReportSchedule.runCode();
} }
@ -347,9 +353,9 @@ public class NormalTest extends BaseTest {
@Test @Test
public void testSub(){ public void testSub(){
String sourceStr = ",0,1,2,"; WorkflowMapper workflowMapper = Util.getMapper(WorkflowMapper.class);
String value = ",0,"; List<Map<String, Object>> maps = workflowMapper.queryCommonSelect("付款银行");
System.out.println(sourceStr.contains(value)); System.out.println(maps);
} }
@Test @Test
@ -360,4 +366,39 @@ public class NormalTest extends BaseTest {
System.out.println("Formatted date: " + formattedDate); System.out.println("Formatted date: " + formattedDate);
} }
@Test
public void testXml() throws Exception {
//Map<String, Object> stringObjectMap = XmlParser.parseXml("<?xml version=\"1.0\" encoding=\"UTF-8\"?>\n" +
// "<bocb2e version=\"120\" security=\"true\" locale=\"zh_CN\"><head><termid>E192168000104</termid><trnid>220630083401</trnid><custid>387679060</custid><cusopr>******</cusopr><trncod>b2e0009</trncod><token/></head><trans><trn-b2e0009-rq><transtype/><b2e0009-rq><insid>2206300834010001</insid><obssid/><trnamt>7220.02</trnamt><trncur>CNY</trncur><priolv>0</priolv><furinfo></furinfo><trfdate>20220630</trfdate><trftime></trftime><comacn/><fractn><fribkn/><actacn>455959225352</actacn><actnam/></fractn><toactn><toibkn>313290030097</toibkn><actacn>3101040160001226585</actacn><toname>上海昱锐科技有限公司</toname><toaddr/><tobknm>杭州银行股份有限公司上海青浦支行</tobknm></toactn></b2e0009-rq></trn-b2e0009-rq></trans></bocb2e>");
//System.out.println(JSON.toJSONString(stringObjectMap));
String insid = XmlParser.getNodeValue("<?xml version=\"1.0\" encoding=\"UTF-8\"?>" +
"<bocb2e version=\"120\" security=\"true\" locale=\"zh_CN\"><head><termid>E192168000104</termid><trnid>220630083401</trnid><custid>387679060</custid><cusopr>******</cusopr><trncod>b2e0009</trncod><token/></head><trans><trn-b2e0009-rq><transtype/><b2e0009-rq><insid>2206300834010001</insid><obssid/><trnamt>7220.02</trnamt><trncur>CNY</trncur><priolv>0</priolv><furinfo></furinfo><trfdate>20220630</trfdate><trftime></trftime><comacn/><fractn><fribkn/><actacn>455959225352</actacn><actnam/></fractn><toactn><toibkn>313290030097</toibkn><actacn>3101040160001226585</actacn><toname>上海昱锐科技有限公司</toname><toaddr/><tobknm>杭州银行股份有限公司上海青浦支行</tobknm></toactn></b2e0009-rq></trn-b2e0009-rq></trans></bocb2e>","insid");
System.out.println(insid);
}
@Test
public void testDiffrentce() throws Exception {
Map<String, Object> map1 = new HashMap<>();
map1.put("id", 1);
map1.put("name", "A");
Map<String, Object> map2 = new HashMap<>();
map2.put("id", 1);
map2.put("name", "B");
Map<String, Object> map3 = new HashMap<>();
map3.put("id", 2);
map3.put("name", "B");
List<Map<String, Object>> list1 = Arrays.asList(map1, map2);
List<Map<String, Object>> list2 = Arrays.asList(map2, map3);
List<Map<String, Object>> difference = CommonUtil.difference(list1, list2, map -> map.get("id"));
List<Map<String, Object>> difference1 = CommonUtil.difference(list2, list1, map -> map.get("id"));
System.out.println(difference); // 输出 [{id=1, name=A}]
System.out.println(difference1); // 输出 [{id=1, name=A}]
}
@Test
public void testQuery1(){
TableNameStore.getInstance().refresh();
}
} }

View File

@ -0,0 +1,94 @@
package bokang.xiao.util;
import java.io.StringReader;
import java.util.*;
import org.jdom.Document;
import org.jdom.Element;
import org.jdom.input.SAXBuilder;
public class XmlParser {
/**
* XML Map
*
* @param xml XML
* @return Map
* @throws Exception
*/
public static Map<String, Object> parseXml(String xml) throws Exception {
Map<String, Object> map = new HashMap<String, Object>();
// 创建 SAXBuilder 对象
SAXBuilder builder = new SAXBuilder();
// 解析 XML 字符串成 Document 对象
Document document = builder.build(new StringReader(xml));
// 获取根元素
Element root = document.getRootElement();
// 解析根元素
parseElement(root, map);
return map;
}
/**
* Element Map
*
* @param element Element
* @param map Map
*/
private static void parseElement(Element element, Map<String, Object> map) {
// 获取子元素列表
List<Element> childElements = element.getChildren();
if (childElements.isEmpty()) {
// 如果没有子元素,则将当前元素的名称和值存入 Map 对象中
map.put(element.getName(), element.getValue());
} else {
Map<String, Object> childMap = new HashMap<String, Object>();
for (Element childElement : childElements) {
// 如果有多个同名元素,则将这些元素解析成一个 List 对象,并将该 List 对象存入当前节点的 Map 对象中
//if (childElement.getName().equals(childElements.get(0).getName())) {
// List<Map<String, Object>> childList = new ArrayList<Map<String, Object>>();
// parseElement(childElement, childMap);
// childList.add(childMap);
// map.put(childElement.getName(), childList);
//} else {
// parseElement(childElement, childMap);
// map.put(childElement.getName(), childMap);
//}
parseElement(childElement, childMap);
map.put(childElement.getName(), childMap);
}
}
}
public static String getNodeValue(String xml, String nodeName) throws Exception {
try {
SAXBuilder builder = new SAXBuilder();
StringReader reader = new StringReader(xml);
Document doc = builder.build(reader);
Element root = doc.getRootElement();
String nodeValue = getNodeValue(root, nodeName);
return nodeValue == null ? "" : nodeValue;
}catch (Exception e){
return "";
}
}
private static String getNodeValue(Element element, String nodeName) {
Element node = element.getChild(nodeName);
if (node != null) {
return node.getValue();
} else {
List<Element> children = element.getChildren();
if(Objects.nonNull(children) && children.size() > 0){
for (Element child : children) {
String value = getNodeValue(child, nodeName);
if (value != null) {
return value;
}
}
}
return null;
}
}
}