diff --git a/src/main/java/com/api/chaoyang/he/browser/service/impl/MultiInvoiceBrowserService.java b/src/main/java/com/api/chaoyang/he/browser/service/impl/MultiInvoiceBrowserService.java new file mode 100644 index 0000000..12a2f6e --- /dev/null +++ b/src/main/java/com/api/chaoyang/he/browser/service/impl/MultiInvoiceBrowserService.java @@ -0,0 +1,206 @@ +/* + * + * Copyright (c) 2001-2018 泛微软件. + * 泛微协同商务系统,版权所有. + * + */ +package com.api.chaoyang.he.browser.service.impl; + +import com.api.browser.bean.ListHeadBean; +import com.api.browser.bean.SearchConditionItem; +import com.api.browser.bean.SplitTableBean; +import com.api.browser.bean.SplitTableColBean; +import com.api.browser.service.BrowserService; +import com.api.browser.util.*; +import com.cloudstore.dev.api.bean.SplitMobileDataBean; +import com.cloudstore.dev.api.bean.SplitMobileTemplateBean; +import com.cloudstore.dev.api.util.Util_MobileData; +import org.apache.commons.lang.StringEscapeUtils; +import weaver.conn.RecordSet; +import weaver.fna.e9.controller.base.FnaInvoiceLedgerController; +import weaver.fna.invoice.Constants; +import weaver.general.Util; +import weaver.systeminfo.SystemEnv; + +import java.util.ArrayList; +import java.util.HashMap; +import java.util.List; +import java.util.Map; + +/** + * @author zhangwj + * @Description:多发票浏览按钮 + * @version 1.0 + */ +public class MultiInvoiceBrowserService extends BrowserService { + + //移动端返回数据格式的json配置 + public static final String JSON_CONFIG="[" + + " {" + + " \"key\": \"col1\"," + + " \"configs\": [" + + " {" + + " \"key\": \"col1_row1\"," + + " \"configs\": [" + + " {" + + " \"key\": \"invoiceNumber\"" + + " }," + + " {" + + " \"key\": \"invoiceCode\"," + + " \"style\": {" + + " \"float\": \"right\"" + + " }" + + " }" + + " ]" + + " }," + + " {" + + " \"key\": \"col1_row2\"," + + " \"configs\": [" + + " {" + + " \"key\": \"taxIncludedPrice\"" + + " }," + + " {" + + " \"key\": \"invoiceTypeName\"," + + " \"style\": {" + + " \"float\": \"right\"" + + " }" + + " }" + + " ]" + + " }" + + " {" + + " \"key\": \"col1_row3\"," + + " \"configs\": [" + + " {" + + " \"key\": \"billingdate\"" + + " }," + + " ]" + + " }" + + " ]" + + " }" + + "]"; + + /** + * 多发票浏览 + * @param params + * @return + */ + @Override + public Map getBrowserData(Map params) throws Exception { + Map apidatas = new HashMap(); + if(user == null){ + apidatas.put(BrowserConstant.BROWSER_RESULT_DATA, null); + return apidatas; + } + String advQry_kprq1 = Util.null2String(params.get("createdatestart")).trim(); + String advQry_kprq2 = Util.null2String(params.get("createdateend")).trim(); + String invoiceNumber = Util.null2String(params.get("invoiceNumber")); + String seller = Util.null2String(params.get("seller")); + + //发票代码,发票类型,开票日期,金额 + FnaInvoiceLedgerController fnaInvoiceLedgerController = FnaInvoiceLedgerController.getInstance(); + String sqlAppend = fnaInvoiceLedgerController.getCaseWhenSql4InvoiceTypeList("invoiceTypeName", "a.invoiceType", user.getLanguage())+" "; + //设置好搜索条件 + String backFields =" a.*, "+ + fnaInvoiceLedgerController.getCaseWhenSql4InvoiceTypeList("invoiceTypeName", "a.invoiceType", user.getLanguage())+" "; + String fromSql = " from FnaInvoiceLedger a "; + //验票为真的发票才能选择的到 + StringBuffer sqlWhere = new StringBuffer(" where 1=1 and (checkStatus = 1 or checkStatus = 2) "); + if(!"".equals(advQry_kprq2)){ + sqlWhere.append(" and a.billingDate <= '").append(StringEscapeUtils.escapeSql(advQry_kprq2)).append("' "); + } + if(!"".equals(advQry_kprq1)){ + sqlWhere.append(" and a.billingDate >= '").append(StringEscapeUtils.escapeSql(advQry_kprq1)).append("' "); + } + if(!"".equals(invoiceNumber)){ + sqlWhere.append(" and a.invoiceNumber like '%").append(StringEscapeUtils.escapeSql(invoiceNumber.trim())).append("%'"); + } + if(!"".equals(seller)){ + sqlWhere.append(" and a.seller like '%").append(StringEscapeUtils.escapeSql(seller.trim())).append("%'"); + } + sqlWhere.append(" and (a.userid_new = ").append(user.getUID()).append(" or a.id in ( select invoiceId from fnaInvoiceSharer where sharer = ").append(user.getUID()).append(") ").append(") "); + sqlWhere.append(" and a.status = '0' "); + //AP航信过滤浏览按钮中的数据-hcy +// sqlWhere.append(" and hxjksflr is null "); + String orderBy=" a.id desc "; + + //writeLog("select "+backFields+" "+fromSql+" "+sqlWhere); + List cols = new ArrayList(); + cols.add(new SplitTableColBean("true","id")); + cols.add(new SplitTableColBean("30%",SystemEnv.getHtmlLabelName(900,user.getLanguage()),"invoiceNumber","invoiceNumber",1).setIsInputCol(BoolAttr.TRUE)); + cols.add(new SplitTableColBean("30%",SystemEnv.getHtmlLabelName(17213,user.getLanguage()),"invoiceCode","invoiceCode")); + cols.add(new SplitTableColBean("30%",SystemEnv.getHtmlLabelName(17213,user.getLanguage()),"invoiceTypeName","invoiceTypeName")); + cols.add(new SplitTableColBean("30%",SystemEnv.getHtmlLabelName(17213,user.getLanguage()),"billingdate","billingdate")); + cols.add(new SplitTableColBean("30%",SystemEnv.getHtmlLabelName(17213,user.getLanguage()),"taxIncludedPrice","taxIncludedPrice")); + SplitTableBean tableBean = new SplitTableBean(backFields,fromSql,sqlWhere.toString(),orderBy,"a.id","DESC",cols); + + + //移动端返回数据 + List mobileDataBeanList=Util_MobileData.createList(JSON_CONFIG); + SplitMobileTemplateBean bean=Util_MobileData.createJsonTemplateBean("theme_default", mobileDataBeanList); + tableBean.createMobileTemplate(bean); + + apidatas.putAll(SplitTableUtil.makeListDataResult(tableBean)); + return apidatas; + } + + /** + * 高级搜索 + * @param params + * @return + */ + @Override + public Map getBrowserConditionInfo(Map params) throws Exception { + Map apidatas = new HashMap(); + List conditions = new ArrayList(); + ConditionFactory conditionFactory = new ConditionFactory(user); + conditions.add(conditionFactory.createCondition(ConditionType.INPUT, 900, "invoiceNumber").setIsQuickSearch(true)); + apidatas.put(BrowserConstant.BROWSER_RESULT_CONDITIONS, conditions); + return apidatas; + } + + /** + * 多发票(多选界面右侧选中部分) + * @param params + * @return + */ + @Override + public Map getMultBrowserDestData(Map params) throws Exception { + Map apidatas = new HashMap(); + + String selectids = Util.null2String(params.get(BrowserConstant.BROWSER_MULT_DEST_SELECTIDS)); + + List> datas = new ArrayList>(); + + StringBuffer buffer = new StringBuffer(); + buffer.append(" select a.* from FnaInvoiceLedger a "); + buffer.append(" where a.id in (").append(selectids).append(")"); + buffer.append(" order by a.id desc "); + + RecordSet rs = new RecordSet(); + rs.execute(buffer.toString()); + while(rs.next()){ + Map item = new HashMap(); + item.put("id",Util.null2String(rs.getString("id"))); + item.put("invoiceNumber",Util.null2String(rs.getString("invoiceNumber"))); + item.put("invoiceCode",Util.null2String(rs.getString("invoiceCode"))); + item.put("invoiceTypeName", Constants.INVOICETYPE.get(Util.null2String(rs.getString("invoicetype")))); + item.put("billingdate", Util.null2String(rs.getString("billingdate"))); + item.put("taxIncludedPrice", Util.null2String(rs.getString("taxIncludedPrice"))); + datas.add(item); + } + List tableHeadColumns = new ArrayList(); + tableHeadColumns.add(new ListHeadBean("id",BoolAttr.TRUE).setIsPrimarykey(BoolAttr.TRUE)); + tableHeadColumns.add(new ListHeadBean("invoiceNumber","",1,BoolAttr.TRUE)); + tableHeadColumns.add(new ListHeadBean("invoiceCode","")); + tableHeadColumns.add(new ListHeadBean("invoiceTypeName","")); + tableHeadColumns.add(new ListHeadBean("billingdate","")); + tableHeadColumns.add(new ListHeadBean("taxIncludedPrice","")); + + apidatas.put(BrowserConstant.BROWSER_RESULT_COLUMN, tableHeadColumns); + apidatas.put(BrowserConstant.BROWSER_RESULT_DATA, BrowserBaseUtil.sortDatas(datas,selectids,"id")); + apidatas.put(BrowserConstant.BROWSER_RESULT_TYPE, BrowserDataType.LIST_ALL_DATA.getTypeid()); + + return apidatas; + } + +} diff --git a/src/main/java/com/api/chaoyang/he/hcy_aphangxin/controller/ChangeFpytController.java b/src/main/java/com/api/chaoyang/he/hcy_aphangxin/controller/ChangeFpytController.java new file mode 100644 index 0000000..64dc234 --- /dev/null +++ b/src/main/java/com/api/chaoyang/he/hcy_aphangxin/controller/ChangeFpytController.java @@ -0,0 +1,45 @@ +package com.api.chaoyang.he.hcy_aphangxin.controller; + +import aiyh.utils.ApiResult; +import aiyh.utils.Util; +import com.api.chaoyang.he.hcy_aphangxin.service.ChangeFpytService; +import com.api.chaoyang.he.hcy_aphangxin.service.impl.ChangeFpytServiceImpl; +import org.apache.log4j.Logger; + +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; + +@Path("/hcy_aphangxin") +public class ChangeFpytController { + + /** + * 用于处理修改发票用途的主要逻辑 + */ + private ChangeFpytService changeFpytService = new ChangeFpytServiceImpl(); + + /** + * 日志处理 + */ + private Logger logger = Util.getLogger(); + /** + *

AP发票库-航信台账中修改发票用途

+ * @param request,response + * @return String + * @author hcy + * @Date 2023/3/13 14:28 + */ + @POST + @Path("/change/fpyt") + @Produces(MediaType.APPLICATION_JSON) + public String checkRequestInfo(@Context HttpServletRequest request, @Context HttpServletResponse response) { + String ids = request.getParameter("ids"); + String[] split = ids.split(","); + String s = changeFpytService.changeFpytValue(split); + return ApiResult.success(s); + } +} diff --git a/src/main/java/com/api/chaoyang/he/hcy_aphangxin/deleteinvoicenotap/controller/DeleteInvoiceNotApController.java b/src/main/java/com/api/chaoyang/he/hcy_aphangxin/deleteinvoicenotap/controller/DeleteInvoiceNotApController.java new file mode 100644 index 0000000..4260690 --- /dev/null +++ b/src/main/java/com/api/chaoyang/he/hcy_aphangxin/deleteinvoicenotap/controller/DeleteInvoiceNotApController.java @@ -0,0 +1,73 @@ +package com.api.chaoyang.he.hcy_aphangxin.deleteinvoicenotap.controller; + +import aiyh.utils.ApiResult; +import aiyh.utils.Util; +import com.api.chaoyang.he.hcy_aphangxin.deleteinvoicenotap.service.DeleteInvoiceNotApService; +import com.api.chaoyang.he.hcy_aphangxin.deleteinvoicenotap.service.impl.DeleteInvoiceNotApServiceimpl; +import org.apache.log4j.Logger; + +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.stream.Collectors; +import java.util.stream.Stream; + +@Path("/hcy_aphangxin/delete") +public class DeleteInvoiceNotApController { + + /** + * 日志处理 + */ + private final Logger logger = Util.getLogger(); + + /** + * service层、用于处理主要逻辑 + */ + private final DeleteInvoiceNotApService deleteInvoiceNotApService = new DeleteInvoiceNotApServiceimpl(); + + /** + *

根据数据id删除非AP发票

+ * @param request + * @param response + * @return String + * @author hcy + * @Date 2023/3/17 15:21 + */ + @POST + @Path("/invoice/not/ap") + @Produces(MediaType.APPLICATION_JSON) + public String deleteInvoiceNotAp(@Context HttpServletRequest request, @Context HttpServletResponse response) { + //前端查询到的数据id + String ids = request.getParameter("ids"); + String[] split = ids.split(","); + //备份数据之前,首先查询要备份和要删除的数据的发票用途字段是否为非AP,若为非AP字段则删除,若不是非AP字段则不删除,并返回前端提醒用户选择ap字段进行删除 + List fpytList = deleteInvoiceNotApService.selectFpyt(split); + List fpytCollection = fpytList.stream().filter(items -> items.equals("1")).collect(Collectors.toList()); + if (fpytList.size() != fpytCollection.size()){ + logger.info("删除数据发票用途字段不为非AP,请重新选择"); + return ApiResult.success(1,"删除数据发票用途字段不为非AP,请重新选择"); + } + //删除非AP数据之前首先备份数据 + boolean backupBoolean = deleteInvoiceNotApService.backUpAfterDelete(split); + if (backupBoolean==true){ + logger.info("数据备份成功"); + }else{ + logger.info("数据备份失败"); + } + //开始删除数据 + boolean deleteBoolean = deleteInvoiceNotApService.deleteDateById(split); + if (deleteBoolean){ + logger.info("数据删除成功"); + return ApiResult.success(0,"数据删除成功!"); + }else { + logger.info("数据删除失败"); + return ApiResult.success(1,"数据删除失败!"); + } + + } +} diff --git a/src/main/java/com/api/chaoyang/he/hcy_aphangxin/deleteinvoicenotap/entity/BackupFnaDataEntity.java b/src/main/java/com/api/chaoyang/he/hcy_aphangxin/deleteinvoicenotap/entity/BackupFnaDataEntity.java new file mode 100644 index 0000000..652884b --- /dev/null +++ b/src/main/java/com/api/chaoyang/he/hcy_aphangxin/deleteinvoicenotap/entity/BackupFnaDataEntity.java @@ -0,0 +1,61 @@ +package com.api.chaoyang.he.hcy_aphangxin.deleteinvoicenotap.entity; + +import lombok.Data; + +@Data +public class BackupFnaDataEntity { + + int requestId; + + int formmodeid; + + int modedatacreater; + + int modedatacreatertype; + + String modedatacreatedate; + + String modedatacreatetime; + + String MODEUUID; + + String form_biz_id; + + double taxRate; + + String billingdate; + + String invoicenumber; + + String invoicecode; + + String invoicetype; + + double taxincludedprice; + + double pricewithouttax; + + double tax; + + String purchaser; + + String purchasertaxno; + + String seller; + + String salestaxno; + + String purp; + + String hxjksflr; + + int checkStatus; + + int status; + + int authenticity; + + int fpyt; + + int check_status; +} diff --git a/src/main/java/com/api/chaoyang/he/hcy_aphangxin/deleteinvoicenotap/mapper/DeleteInvoiceNotApMapper.java b/src/main/java/com/api/chaoyang/he/hcy_aphangxin/deleteinvoicenotap/mapper/DeleteInvoiceNotApMapper.java new file mode 100644 index 0000000..9e3ba37 --- /dev/null +++ b/src/main/java/com/api/chaoyang/he/hcy_aphangxin/deleteinvoicenotap/mapper/DeleteInvoiceNotApMapper.java @@ -0,0 +1,39 @@ +package com.api.chaoyang.he.hcy_aphangxin.deleteinvoicenotap.mapper; + +import aiyh.utils.annotation.recordset.*; + + +import java.util.List; +import java.util.Map; + +@SqlMapper +public interface DeleteInvoiceNotApMapper { + + + + @Select("select * from fnainvoiceledger where id in ($t{split})") + List> selectDate(@ParamMapper("split") String[] split); + + @Insert("insert into uf_apfpscsj (billingDate,invoiceCode,invoiceNumber," + + "invoiceType,seller,purchaser,invoiceServiceYype,priceWithoutTax,taxRate," + + "tax,taxIncludedPrice,authenticity,reimbursementDate,reimbursePerson,requestId,userid_new," + + "invoiceSource_new,checkcode,status,card_id_new,encrypt_code_new,openid_new,wechatstatus,imageID,purchaserTaxNo," + + "salesTaxNo,entryTime,company_seal,form_type,form_name,kind,ciphertext,category,imageDocId,checkStatus," + + "updateOperate,cloudId,codeConfirm,numberConfirm,receiptor,reviewer,issuer,province,city,travel_tax,fylx," + + "purp,iele,orf,hxjksflr,fpyt) " + + "values (?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?)") + boolean backupDate(@ParamMapper("backupDataLists") List backupDataLists); + + @Delete("delete from fnainvoiceledger where id = #{id}") + boolean deleteDateById(@ParamMapper("id") String id); + + /** + *

查询发票用途字段是否为非航行

+ * @param id 数据id + * @return String + * @author hcy + * @Date 2023/3/20 13:56 + */ + @Select("select fpyt from fnainvoiceledger where id = #{id}") + String selectFpyt(String id); +} diff --git a/src/main/java/com/api/chaoyang/he/hcy_aphangxin/deleteinvoicenotap/service/DeleteInvoiceNotApService.java b/src/main/java/com/api/chaoyang/he/hcy_aphangxin/deleteinvoicenotap/service/DeleteInvoiceNotApService.java new file mode 100644 index 0000000..babe51b --- /dev/null +++ b/src/main/java/com/api/chaoyang/he/hcy_aphangxin/deleteinvoicenotap/service/DeleteInvoiceNotApService.java @@ -0,0 +1,11 @@ +package com.api.chaoyang.he.hcy_aphangxin.deleteinvoicenotap.service; + +import java.util.List; + +public interface DeleteInvoiceNotApService { + boolean backUpAfterDelete(String[] split); + boolean deleteDateById(String[] split); + + List selectFpyt(String[] split); + +} diff --git a/src/main/java/com/api/chaoyang/he/hcy_aphangxin/deleteinvoicenotap/service/impl/DeleteInvoiceNotApServiceimpl.java b/src/main/java/com/api/chaoyang/he/hcy_aphangxin/deleteinvoicenotap/service/impl/DeleteInvoiceNotApServiceimpl.java new file mode 100644 index 0000000..7a1b9ed --- /dev/null +++ b/src/main/java/com/api/chaoyang/he/hcy_aphangxin/deleteinvoicenotap/service/impl/DeleteInvoiceNotApServiceimpl.java @@ -0,0 +1,94 @@ +package com.api.chaoyang.he.hcy_aphangxin.deleteinvoicenotap.service.impl; + +import aiyh.utils.Util; + +import com.api.chaoyang.he.hcy_aphangxin.deleteinvoicenotap.mapper.DeleteInvoiceNotApMapper; +import com.api.chaoyang.he.hcy_aphangxin.deleteinvoicenotap.service.DeleteInvoiceNotApService; +import org.apache.log4j.Logger; +import weaver.conn.RecordSet; + +import java.util.ArrayList; +import java.util.List; +import java.util.Map; +import java.util.stream.Collectors; + +public class DeleteInvoiceNotApServiceimpl implements DeleteInvoiceNotApService { + + /** + * 用于sql处理 + */ + private final DeleteInvoiceNotApMapper deleteInvoiceNotApMapper = Util.getMapper(DeleteInvoiceNotApMapper.class); + + /** + * 日志 + */ + private final Logger logger = Util.getLogger(); + + /** + *

用于查询数据,查询到的数据进行数据备份

+ * @param split requestid + * @return boolean 数据备份是否成功 + * @author hcy + * @Date 2023/3/17 17:48 + */ + public boolean backUpAfterDelete(String[] split) { + RecordSet recordSet = new RecordSet(); + for (String id : split) { + String backupDataSql = "INSERT INTO fnabackup (billingdate,\t\n" + + "invoicenumber,\t\n" + + "invoicecode,\n" + + "invoicetype,\t\n" + + "taxincludedprice,pricewithouttax,\t\n" + + "tax,\n" + + "purchaser,purchasertaxno,\t\n" + + "seller,salestaxno,purp,hxjksflr,checkStatus,status,authenticity,fpyt,taxrate\n" + + ") SELECT \n" + + "billingdate,\t\n" + + "invoicenumber,\t\n" + + "invoicecode,\n" + + "invoicetype,\t\n" + + "taxincludedprice,pricewithouttax,\t\n" + + "tax,\n" + + "purchaser,purchasertaxno,\t\n" + + "seller,salestaxno,purp,hxjksflr,checkStatus,status,authenticity,fpyt,taxrate\n" + + " FROM fnainvoiceledger WHERE id = ?"; + boolean backupBool = recordSet.executeUpdate(backupDataSql, id); + if (!backupBool){ + return false; + } + } + //开始备份数据 + return true; + } + + /** + *

根据数据id、删除数据

+ * @param split id + * @return boolean 数据删除是否成功 + * @author hcy + * @Date 2023/3/17 18:00 + */ + public boolean deleteDateById(String[] split) { + List booleanList = new ArrayList<>(); + + for (String s : split) { + boolean deleteBoolean = deleteInvoiceNotApMapper.deleteDateById(s); + booleanList.add(deleteBoolean); + } + List collect = booleanList.stream().distinct().collect(Collectors.toList()); + if (collect != null && collect.size()==1){ + return true; + } + return false; + } + + @Override + public List selectFpyt(String[] split) { + List fpytLists = new ArrayList<>(); + for (String s : split) { + String fpyt = deleteInvoiceNotApMapper.selectFpyt(s); + fpytLists.add(fpyt); + } + return fpytLists; + } +} diff --git a/src/main/java/com/api/chaoyang/he/hcy_aphangxin/deleteinvoicenotap/service/impl/DeleteInvoiceNotApServiceimpl_copy.java b/src/main/java/com/api/chaoyang/he/hcy_aphangxin/deleteinvoicenotap/service/impl/DeleteInvoiceNotApServiceimpl_copy.java new file mode 100644 index 0000000..a275094 --- /dev/null +++ b/src/main/java/com/api/chaoyang/he/hcy_aphangxin/deleteinvoicenotap/service/impl/DeleteInvoiceNotApServiceimpl_copy.java @@ -0,0 +1,143 @@ +package com.api.chaoyang.he.hcy_aphangxin.deleteinvoicenotap.service.impl; + +import aiyh.utils.Util; + +import com.api.chaoyang.he.hcy_aphangxin.deleteinvoicenotap.mapper.DeleteInvoiceNotApMapper; +import com.api.chaoyang.he.hcy_aphangxin.deleteinvoicenotap.service.DeleteInvoiceNotApService; +import org.apache.log4j.Logger; +import weaver.conn.RecordSet; + +import java.util.ArrayList; +import java.util.List; +import java.util.Map; +import java.util.stream.Collectors; + +public class DeleteInvoiceNotApServiceimpl_copy implements DeleteInvoiceNotApService { + + /** + * 用于sql处理 + */ + private final DeleteInvoiceNotApMapper deleteInvoiceNotApMapper = Util.getMapper(DeleteInvoiceNotApMapper.class); + + /** + * 日志 + */ + private final Logger logger = Util.getLogger(); + + /** + *

用于查询数据,查询到的数据进行数据备份

+ * @param split requestid + * @return boolean 数据备份是否成功 + * @author hcy + * @Date 2023/3/17 17:48 + */ + public boolean backUpAfterDelete(String[] split) { + //导入数据之前先查询数据 + List> backupDate = deleteInvoiceNotApMapper.selectDate(split);//拿到需要备份的数据 + //开始备份数据 + List bool = new ArrayList<>();//存放sql语句insert动作是否成功 + for (Map map : backupDate) { + List backupDataLists = new ArrayList<>(); + backupDataLists.add(map.get("billingDate")); + backupDataLists.add(map.get("invoiceCode")); + backupDataLists.add(map.get("invoiceNumber")); + backupDataLists.add(map.get("invoiceType")); + backupDataLists.add(map.get("seller")); + backupDataLists.add(map.get("purchaser")); + backupDataLists.add(map.get("invoiceServiceYype")); + backupDataLists.add(map.get("priceWithoutTax")); + backupDataLists.add(map.get("taxRate")); + backupDataLists.add(map.get("tax")); + backupDataLists.add(map.get("taxIncludedPrice")); + backupDataLists.add(map.get("authenticity")); + backupDataLists.add(map.get("reimbursementDate")); + backupDataLists.add(map.get("reimbursePerson")); + backupDataLists.add(map.get("requestId")); + backupDataLists.add(map.get("useridNew")); + backupDataLists.add(map.get("invoiceSourceNew")); + backupDataLists.add(map.get("checkcode")); + backupDataLists.add(map.get("status")); + backupDataLists.add(map.get("cardIdNew")); + backupDataLists.add(map.get("encryptCodeNew")); + backupDataLists.add(map.get("openidNew")); + backupDataLists.add(map.get("wechatstatus")); + backupDataLists.add(map.get("imageID")); + backupDataLists.add(map.get("purchaserTaxNo")); + backupDataLists.add(map.get("salesTaxNo")); + backupDataLists.add(map.get("entryTime")); + backupDataLists.add(map.get("companySeal")); + backupDataLists.add(map.get("formType")); + backupDataLists.add(map.get("formName")); + backupDataLists.add(map.get("kind")); + backupDataLists.add(map.get("ciphertext")); + backupDataLists.add(map.get("category")); + backupDataLists.add(map.get("imageDocId")); + backupDataLists.add(map.get("checkStatus")); + backupDataLists.add(map.get("updateOperate")); + backupDataLists.add(map.get("cloudId")); + backupDataLists.add(map.get("codeConfirm")); + backupDataLists.add(map.get("numberConfirm")); + backupDataLists.add(map.get("receiptor")); + backupDataLists.add(map.get("reviewer")); + backupDataLists.add(map.get("issuer")); + backupDataLists.add(map.get("province")); + backupDataLists.add(map.get("city")); + backupDataLists.add(map.get("travelTax")); +// backupDataLists.add(map.get("fylx")); + backupDataLists.add(map.get("purp")); +// backupDataLists.add(map.get("iele")); + backupDataLists.add(map.get("orf")); + backupDataLists.add(map.get("hxjksflr")); + backupDataLists.add(map.get("fpyt")); + RecordSet recordSet = new RecordSet(); + String backupdate = "insert into fnabackup (billingDate,invoiceCode,invoiceNumber," + + "invoiceType,seller,purchaser,invoiceServiceYype,priceWithoutTax,taxRate," + + "tax,taxIncludedPrice,authenticity,reimbursementDate,reimbursePerson,requestId,userid_new," + + "invoiceSource_new,checkcode,status,card_id_new,encrypt_code_new,openid_new,wechatstatus,imageID,purchaserTaxNo," + + "salesTaxNo,entryTime,company_seal,form_type,form_name,kind,ciphertext,category,imageDocId,checkStatus," + + "updateOperate,cloudId,codeConfirm,numberConfirm,receiptor,reviewer,issuer,province,city,travel_tax," + + "purp,orf,hxjksflr,fpyt) " + + "values (?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?)"; + boolean insertIntoBoolean = recordSet.executeUpdate(backupdate, backupDataLists); +// boolean insertIntoBoolean = deleteInvoiceNotApMapper.backupDate(backupDataLists); + bool.add(insertIntoBoolean); + logger.info("插入语句是否成功==="+insertIntoBoolean); + } + List collect = bool.stream().distinct().collect(Collectors.toList()); + if (collect!=null && collect.size()==1){ + return true; + } + return false; + } + + /** + *

根据数据id、删除数据

+ * @param split id + * @return boolean 数据删除是否成功 + * @author hcy + * @Date 2023/3/17 18:00 + */ + public boolean deleteDateById(String[] split) { + List booleanList = new ArrayList<>(); + + for (String s : split) { + boolean deleteBoolean = deleteInvoiceNotApMapper.deleteDateById(s); + booleanList.add(deleteBoolean); + } + List collect = booleanList.stream().distinct().collect(Collectors.toList()); + if (collect != null && collect.size()==1){ + return true; + } + return false; + } + + @Override + public List selectFpyt(String[] split) { + List fpytLists = new ArrayList<>(); + for (String s : split) { + String fpyt = deleteInvoiceNotApMapper.selectFpyt(s); + fpytLists.add(fpyt); + } + return fpytLists; + } +} diff --git a/src/main/java/com/api/chaoyang/he/hcy_aphangxin/mapper/ChangeFpytMapper.java b/src/main/java/com/api/chaoyang/he/hcy_aphangxin/mapper/ChangeFpytMapper.java new file mode 100644 index 0000000..26a2fed --- /dev/null +++ b/src/main/java/com/api/chaoyang/he/hcy_aphangxin/mapper/ChangeFpytMapper.java @@ -0,0 +1,17 @@ +package com.api.chaoyang.he.hcy_aphangxin.mapper; + +import aiyh.utils.annotation.recordset.ParamMapper; +import aiyh.utils.annotation.recordset.SqlMapper; +import aiyh.utils.annotation.recordset.Update; + +/** + *

根据数据id,修改发票用途字段值

+ * @Author hcy + * @Date 2023/3/13 14:41 + */ +@SqlMapper +public interface ChangeFpytMapper { + + @Update("update fnainvoiceledger set fpyt = 1 where id = #{id}") + boolean updateFpytValue(@ParamMapper("id") String id); +} diff --git a/src/main/java/com/api/chaoyang/he/hcy_aphangxin/service/ChangeFpytService.java b/src/main/java/com/api/chaoyang/he/hcy_aphangxin/service/ChangeFpytService.java new file mode 100644 index 0000000..b0babfc --- /dev/null +++ b/src/main/java/com/api/chaoyang/he/hcy_aphangxin/service/ChangeFpytService.java @@ -0,0 +1,12 @@ +package com.api.chaoyang.he.hcy_aphangxin.service; + +public interface ChangeFpytService { + /** + *

修改发票用途主要逻辑

+ * @param split + * @return String + * @author hcy + * @Date 2023/3/13 14:38 + */ + public String changeFpytValue(String[] split); +} diff --git a/src/main/java/com/api/chaoyang/he/hcy_aphangxin/service/impl/ChangeFpytServiceImpl.java b/src/main/java/com/api/chaoyang/he/hcy_aphangxin/service/impl/ChangeFpytServiceImpl.java new file mode 100644 index 0000000..e7be351 --- /dev/null +++ b/src/main/java/com/api/chaoyang/he/hcy_aphangxin/service/impl/ChangeFpytServiceImpl.java @@ -0,0 +1,33 @@ +package com.api.chaoyang.he.hcy_aphangxin.service.impl; + +import aiyh.utils.Util; +import com.api.chaoyang.he.hcy_aphangxin.mapper.ChangeFpytMapper; +import com.api.chaoyang.he.hcy_aphangxin.service.ChangeFpytService; + + +public class ChangeFpytServiceImpl implements ChangeFpytService { + + /** + * 用于直接操作数据库的Mapper类 + */ + private final ChangeFpytMapper changeFpytMapper = Util.getMapper(ChangeFpytMapper.class); + + @Override + public String changeFpytValue(String[] split) { + int num = 0; + for (String s : split) { + if (!s.equals("")){ + boolean b = changeFpytMapper.updateFpytValue(s); + if (b){ + num++; + } + } + } + if (num == split.length){ + return "所有数据更新成功"; + }else { + return "数据更新失败"; + } + + } +} diff --git a/src/main/java/com/api/chaoyang/he/hcy_dingxinjituan/exportpdf/controller/ExportPDFController.java b/src/main/java/com/api/chaoyang/he/hcy_dingxinjituan/exportpdf/controller/ExportPDFController.java new file mode 100644 index 0000000..6ec18de --- /dev/null +++ b/src/main/java/com/api/chaoyang/he/hcy_dingxinjituan/exportpdf/controller/ExportPDFController.java @@ -0,0 +1,92 @@ +package com.api.chaoyang.he.hcy_dingxinjituan.exportpdf.controller; + + +import aiyh.utils.Util; +import com.api.chaoyang.he.hcy_dingxinjituan.exportpdf.service.ExportPDFService; +import com.api.chaoyang.he.hcy_dingxinjituan.exportpdf.service.impl.ExportPDFServiceImpl; +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.GET; +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 javax.ws.rs.core.Response; +import javax.ws.rs.core.StreamingOutput; +import java.io.UnsupportedEncodingException; +import java.nio.charset.StandardCharsets; +import java.time.LocalDateTime; +import java.time.format.DateTimeFormatter; +import java.util.List; +import java.util.Map; + +@Path("/hcy_dingxinjituan") +public class ExportPDFController { + + private final ExportPDFService exportPDFService = new ExportPDFServiceImpl(); + + private final Logger logger = Util.getLogger(); + + @GET + @Path("/export/pdf") + @Produces(MediaType.APPLICATION_OCTET_STREAM) + public Response exportPDF(@Context HttpServletRequest request, @Context HttpServletResponse response) { + + Response build = null; + Response.ResponseBuilder header = null; + StreamingOutput output = null; + String ids = request.getParameter("ids"); + String[] split = ids.split(","); + //第二步更新导出次+1 + exportPDFService.updateDccs(split); + + //第一步查询数据封装到List>类型的集合中 + List> dataList = exportPDFService.selectDataList(split); + User user = HrmUserVarify.getUser(request, response); + String exportUser = user.getLastname(); + //第三步同步数据 + List insertBooleanLists = exportPDFService.backupData(dataList,exportUser,this.getCurrentTime()); + for (Boolean list : insertBooleanLists) { + if (list == false){ + logger.info("备份数据失败"); + } + } + //第四步根据第一步拿到的数据导出pdf + String exportTime = getCurrentDateTime();//导出时间 + + + byte[] pdfBytes = exportPDFService.exportPDF(dataList,exportUser,exportTime); + output = outputStream -> { + outputStream.write(pdfBytes); + outputStream.close(); + }; + String fileName = "顶新集团-"+ getCurrentTime() + ".pdf"; + try { + header = Response.ok(output,MediaType.APPLICATION_OCTET_STREAM) + .type("application/xlsx") + .header("Content-Disposition", + "attachment; filename=\""+ new String(fileName.getBytes("GBK"), StandardCharsets.ISO_8859_1)+"\""); + } catch (UnsupportedEncodingException e) { + e.printStackTrace(); + } + + return header.build(); + } + + public static String getCurrentDateTime() { + LocalDateTime now = LocalDateTime.now(); + DateTimeFormatter formatter = DateTimeFormatter.ofPattern("yyyy-MM-dd"); + return now.format(formatter); + } + + public static String getCurrentTime() { + LocalDateTime now = LocalDateTime.now(); + DateTimeFormatter formatter = DateTimeFormatter.ofPattern("yyyy-MM-dd HH:mm:ss"); + return now.format(formatter); + } +} diff --git a/src/main/java/com/api/chaoyang/he/hcy_dingxinjituan/exportpdf/mapper/ExportPDFMapper.java b/src/main/java/com/api/chaoyang/he/hcy_dingxinjituan/exportpdf/mapper/ExportPDFMapper.java new file mode 100644 index 0000000..31b525d --- /dev/null +++ b/src/main/java/com/api/chaoyang/he/hcy_dingxinjituan/exportpdf/mapper/ExportPDFMapper.java @@ -0,0 +1,32 @@ +package com.api.chaoyang.he.hcy_dingxinjituan.exportpdf.mapper; + +import aiyh.utils.annotation.recordset.ParamMapper; +import aiyh.utils.annotation.recordset.Select; +import aiyh.utils.annotation.recordset.SqlMapper; +import aiyh.utils.annotation.recordset.Update; +import org.directwebremoting.annotations.Param; + +import java.util.List; +import java.util.Map; + +@SqlMapper +public interface ExportPDFMapper { + + + @Select("select * from uf_sapywdj where id in ($t{split})") + List> selectDataList(String[] split); + + @Update("update uf_sapywdj set dccs = #{s} where id = #{id}") + boolean updateDccs(@ParamMapper("s") String s, @ParamMapper("id") String id); + + + @Select("select dccs from uf_sapywdj where id = #{id}") + String selectDccs(String id); + + @Select("select requestname from workflow_requestbase where requestid = #{stringXglc}") + String selectRequestName(String stringXglc); + + @Select("select gysmc from uf_sapgys where id= #{gfdw} ") + String setGfdw(String gfdw); + +} diff --git a/src/main/java/com/api/chaoyang/he/hcy_dingxinjituan/exportpdf/service/ExportPDFService.java b/src/main/java/com/api/chaoyang/he/hcy_dingxinjituan/exportpdf/service/ExportPDFService.java new file mode 100644 index 0000000..f338871 --- /dev/null +++ b/src/main/java/com/api/chaoyang/he/hcy_dingxinjituan/exportpdf/service/ExportPDFService.java @@ -0,0 +1,14 @@ +package com.api.chaoyang.he.hcy_dingxinjituan.exportpdf.service; + +import java.util.List; +import java.util.Map; + +public interface ExportPDFService { + List> selectDataList(String[] split); + + void updateDccs(String[] split); + + byte[] exportPDF(List> dataList, String exportUser, String exportTime); + + List backupData(List> dataList,String exportUser,String exportTime); +} diff --git a/src/main/java/com/api/chaoyang/he/hcy_dingxinjituan/exportpdf/service/impl/ExportPDFServiceImpl.java b/src/main/java/com/api/chaoyang/he/hcy_dingxinjituan/exportpdf/service/impl/ExportPDFServiceImpl.java new file mode 100644 index 0000000..53d103b --- /dev/null +++ b/src/main/java/com/api/chaoyang/he/hcy_dingxinjituan/exportpdf/service/impl/ExportPDFServiceImpl.java @@ -0,0 +1,275 @@ +package com.api.chaoyang.he.hcy_dingxinjituan.exportpdf.service.impl; + +import aiyh.utils.Util; + +import java.io.ByteArrayOutputStream; +import java.util.ArrayList; +import java.util.List; +import java.util.Map; + +import com.api.chaoyang.he.hcy_dingxinjituan.exportpdf.mapper.ExportPDFMapper; +import com.api.chaoyang.he.hcy_dingxinjituan.exportpdf.service.ExportPDFService; +import com.itextpdf.text.Document; +import com.itextpdf.text.*; +import com.itextpdf.text.pdf.*; +import de.schlichtherle.io.File; +import org.apache.log4j.Logger; +import weaver.conn.RecordSet; +import weaver.general.GCONST; + + +public class ExportPDFServiceImpl implements ExportPDFService { + + private final ExportPDFMapper exportPDFMapper = Util.getMapper(ExportPDFMapper.class); + + private final Logger logger = Util.getLogger(); + @Override + public List> selectDataList(String[] split) { + return exportPDFMapper.selectDataList(split); + } + + @Override + public void updateDccs(String[] split) { + for (String s : split) { + String dccs = Util.null2String(exportPDFMapper.selectDccs(s)); + if (!"".equals(dccs) && Util.getIntValue(dccs)!=-1){ + int dccsInt = Integer.parseInt(dccs); + dccsInt++; + dccs = String.valueOf(dccsInt); + boolean updateBool = exportPDFMapper.updateDccs(dccs,s); + }else if (!"".equals(dccs) && Util.getIntValue(dccs)==-1){ + boolean updateBool = exportPDFMapper.updateDccs("1",s); + } + else{ + boolean updateBool = exportPDFMapper.updateDccs("1",s); + } + } + } + + + + @Override + public byte[] exportPDF(List> dataList, String exportUser, String exportTime) { + + // 创建PDF文档 + Document document = new Document(); + ByteArrayOutputStream baos = new ByteArrayOutputStream(); + try { + PdfWriter.getInstance(document, baos); + // 打开PDF文档 + document.open(); + + // 创建页面并设置属性 +// Rectangle pageSize = PageSize.A4; +// document.setPageSize(pageSize.rotate()); // 横向页面 +// document.setMargins(36, 36, 36, 36); // 36pt边距 + + // 创建表格 + PdfPTable table = new PdfPTable(10); + table.setWidthPercentage(100f); + table.setHorizontalAlignment(Element.ALIGN_CENTER); + table.setHeaderRows(1); + //字体 + String rootPath = GCONST.getRootPath(); +// new File(GCONST.getRootPath()+"WEB-INF"+File.separatorChar+"meeting"+File.separatorChar); +// String fontPath = rootPath + "/WEB-INF/font/simfang.ttf"; + String fontPath = "/app/ecology/WEB-INF/font/simfang.ttf"; + logger.info("fontPath==="+fontPath); +// BaseFont bfChinese = BaseFont.createFont("D:\\WEAVER\\ecology\\WEB-INF\\font\\simfang.ttf", BaseFont.IDENTITY_H, BaseFont.NOT_EMBEDDED); + BaseFont bfChinese = BaseFont.createFont(fontPath, BaseFont.IDENTITY_H, BaseFont.NOT_EMBEDDED); + + + // 添加标题 + Font titleFont = new Font(bfChinese, 18, Font.BOLD); + Paragraph title = new Paragraph("SAP-业务单据数据", titleFont); + title.setAlignment(Element.ALIGN_CENTER); + document.add(title); + + + + //// 添加导出人和导出日期信息 + + Paragraph info = new Paragraph("导出人:"+exportUser+" 导出日期:"+exportTime, + new Font(bfChinese, 10f, Font.NORMAL, BaseColor.BLACK)); + info.setAlignment(Element.ALIGN_RIGHT); + document.add(info); + + // 添加表头行 + // 设置表头样式及内容 + Font headerFont = new Font(bfChinese, 10, Font.BOLD, BaseColor.WHITE); + PdfPCell headerCell = new PdfPCell(); + headerCell.setBackgroundColor(BaseColor.BLACK); + headerCell.setHorizontalAlignment(Element.ALIGN_CENTER); + headerCell.setVerticalAlignment(Element.ALIGN_MIDDLE); + headerCell.setPadding(5); + + headerCell.setPhrase(new Phrase("申请编号", headerFont)); + table.addCell(headerCell); + headerCell.setPhrase(new Phrase("相关流程", headerFont)); + table.addCell(headerCell); + headerCell.setPhrase(new Phrase("法人公司编码", headerFont)); + table.addCell(headerCell); + headerCell.setPhrase(new Phrase("地址号", headerFont)); + table.addCell(headerCell); + headerCell.setPhrase(new Phrase("给付单位", headerFont)); + table.addCell(headerCell); + headerCell.setPhrase(new Phrase("开户行", headerFont)); + table.addCell(headerCell); + headerCell.setPhrase(new Phrase("银行账号", headerFont)); + table.addCell(headerCell); + headerCell.setPhrase(new Phrase("金额", headerFont)); + table.addCell(headerCell); + headerCell.setPhrase(new Phrase("SAP凭证号", headerFont)); + table.addCell(headerCell); + headerCell.setPhrase(new Phrase("导出次数", headerFont)); + table.addCell(headerCell); + + // 添加数据行 + + Font dataFont = new Font(bfChinese, 9, Font.NORMAL, BaseColor.BLACK); + for (Map row : dataList) { + table.addCell(createCell(String.valueOf(row.get("sqbh")), dataFont, Element.ALIGN_CENTER)); + String stringXglc = Util.null2String(row.get("xglc")); + String requstName = exportPDFMapper.selectRequestName(stringXglc); + table.addCell(createCell(requstName, dataFont, Element.ALIGN_CENTER)); + table.addCell(createCell(String.valueOf(row.get("frgsbm")), dataFont, Element.ALIGN_CENTER)); + table.addCell(createCell(String.valueOf(row.get("dzh")), dataFont, Element.ALIGN_CENTER)); + String gfdw = Util.null2String(row.get("gfdw")); + String gfdwString = exportPDFMapper.setGfdw(gfdw); + table.addCell(createCell(gfdwString, dataFont, Element.ALIGN_CENTER)); + table.addCell(createCell(String.valueOf(row.get("khh")), dataFont, Element.ALIGN_CENTER)); + table.addCell(createCell(String.valueOf(row.get("yhzh")), dataFont, Element.ALIGN_CENTER)); + table.addCell(createCell(String.valueOf(row.get("je")), dataFont, Element.ALIGN_CENTER)); + table.addCell(createCell(String.valueOf(row.get("sappzh")), dataFont, Element.ALIGN_CENTER)); + table.addCell(createCell(String.valueOf(row.get("dccs")), dataFont, Element.ALIGN_CENTER)); + } + + // 设置表格样式和行样式 + table.setSpacingBefore(8f); + table.setSpacingAfter(8f); + table.getDefaultCell().setVerticalAlignment(Element.ALIGN_MIDDLE); + table.getDefaultCell().setPadding(4f); + + // 添加表格到页面 + document.add(table); + + // 添加导出人和导出日期信息 + + +// 关闭PDF文档 + document.close(); + +// 将PDF文档写入输出流 + return baos.toByteArray(); + } catch (Exception e) { + e.printStackTrace(); + logger.info("导出PDF文档异常原因==="+e); + } + + + return new byte[0]; + } + + + public List backupData(List> dataList,String exportuser,String exporttime) { + RecordSet recordSet = new RecordSet(); + List insertBooleanLists = new ArrayList(); + try { + for (Map map : dataList) { + //toDo: + String insertSql = "insert into uf_sapywdj_backup (requestId,formmodeid,modedatacreater,modedatacreatertype," + + "modedatacreatedate,modedatacreatetime,MODEUUID,lclx,sfmdfy,qklx,fkfs,yfklx,dx,xglc,sqr,cgbs,fhxx,sappzh,sqbm," + + "khh,yhzh,ytsm,je,frgsbm,dpmc,dpbh,qwfkrq,dzh,szgs,sqbh,cwgzrq,ph,cwjb,paystatus,completetime,fygz,jybgse,jybgwsje,jybghsje," + + "jybgfhxx1,jybgfhxx2,jybgfhxx3,jybgfhzt1,jybgfhzt2,jybgfhzt3,jybgpzh1,jybgpzh2,jybgpzh3,dh,jybglshjl,gtddh,frgs,gfdw,cbzx,ywlx,mdcwjb," + + "mdcwkzg,cwkzg,zbchbzg,zbchbzg1,mdcwkzg1,dpmc1,zhcyr,modedatamodifier,modedatamodifydatetime,dccs,exportuser,exporttime) values (?,?,?,?,?,?,?,?,?,?," + + "?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?)"; + logger.info("sql==="+insertSql); + boolean insertBool = recordSet.executeUpdate(insertSql, + Util.null2String(map.get("requestId")), + Util.null2String(map.get("formmodeid")), + Util.null2String(map.get("formmodeid")), + Util.null2String(map.get("modedatacreatertype")), + Util.null2String(map.get("modedatacreatedate")), + Util.null2String(map.get("modedatacreatetime")), + Util.null2String(map.get("MODEUUID")), + Util.null2String(map.get("lclx")), + Util.null2String(map.get("sfmdfy")), + Util.null2String(map.get("qklx")), + Util.null2String(map.get("fkfs")), + Util.null2String(map.get("yfklx")), + Util.null2String(map.get("dx")), + Util.null2String(map.get("xglc")), + Util.null2String(map.get("sqr")), + Util.null2String(map.get("cgbs")), + Util.null2String(map.get("fhxx")), + Util.null2String(map.get("sappzh")), + Util.null2String(map.get("sqbm")), + Util.null2String(map.get("khh")), + Util.null2String(map.get("yhzh")), + Util.null2String(map.get("ytsm")), + Util.null2String(map.get("je")), + Util.null2String(map.get("frgsbm")), + Util.null2String(map.get("dpmc")), + Util.null2String(map.get("dpbh")), + Util.null2String(map.get("qwfkrq")), + Util.null2String(map.get("dzh")), + Util.null2String(map.get("szgs")), + Util.null2String(map.get("sqbh")), + Util.null2String(map.get("cwgzrq")), + Util.null2String(map.get("ph")), + Util.null2String(map.get("cwjb")), + Util.null2String(map.get("paystatus")), + Util.null2String(map.get("completetime")), + Util.null2String(map.get("fygz")), + Util.null2String(map.get("jybgse")), + Util.null2String(map.get("jybgwsje")), + Util.null2String(map.get("jybghsje")), + Util.null2String(map.get("jybgfhxx1")), + Util.null2String(map.get("jybgfhxx2")), + Util.null2String(map.get("jybgfhxx3")), + Util.null2String(map.get("jybgfhzt1")), + Util.null2String(map.get("jybgfhzt2")), + Util.null2String(map.get("jybgfhzt3")), + Util.null2String(map.get("jybgpzh1")), + Util.null2String(map.get("jybgpzh2")), + Util.null2String(map.get("jybgpzh3")), + Util.null2String(map.get("dh")), + Util.null2String(map.get("jybglshjl")), + Util.null2String(map.get("gtddh")), + Util.null2String(map.get("frgs")), + Util.null2String(map.get("gfdw")), + Util.null2String(map.get("cbzx")), + Util.null2String(map.get("ywlx")), + Util.null2String(map.get("mdcwjb")), + Util.null2String(map.get("mdcwkzg")), + Util.null2String(map.get("cwkzg")), + Util.null2String(map.get("zbchbzg")), + Util.null2String(map.get("zbchbzg1")), + Util.null2String(map.get("mdcwkzg1")), + Util.null2String(map.get("dpmc1")), + Util.null2String(map.get("zhcyr")), + Util.null2String(map.get("modedatamodifier")), + Util.null2String(map.get("modedatamodifydatetime")), + Util.null2String(map.get("dccs")), + exportuser, + exporttime + ); + insertBooleanLists.add(insertBool); + } + } catch (Exception e) { + e.printStackTrace(); + logger.error("错误原因==="+e.getMessage()); + } + + + return insertBooleanLists; + } + + private PdfPCell createCell(String text, Font font, int align) { + PdfPCell cell = new PdfPCell(new Phrase(text, font)); + cell.setHorizontalAlignment(align); + cell.setVerticalAlignment(Element.ALIGN_MIDDLE); + cell.setPadding(4f); + return cell; + } +} diff --git a/src/main/java/com/api/chaoyang/he/hcy_fengtianfangzhi/controller/DetailDataExportExcelController.java b/src/main/java/com/api/chaoyang/he/hcy_fengtianfangzhi/controller/DetailDataExportExcelController.java new file mode 100644 index 0000000..69ca6e4 --- /dev/null +++ b/src/main/java/com/api/chaoyang/he/hcy_fengtianfangzhi/controller/DetailDataExportExcelController.java @@ -0,0 +1,49 @@ +package com.api.chaoyang.he.hcy_fengtianfangzhi.controller; + +import aiyh.utils.Util; + +import com.api.chaoyang.he.hcy_fengtianfangzhi.service.DetailDataExportExcelApi; +import com.api.chaoyang.he.hcy_fengtianfangzhi.service.impl.DetailDataExportExcelService; +import org.apache.log4j.Logger; + +import javax.servlet.http.HttpServletRequest; +import javax.servlet.http.HttpServletResponse; +import javax.ws.rs.GET; +import javax.ws.rs.Path; +import javax.ws.rs.Produces; +import javax.ws.rs.core.Context; +import javax.ws.rs.core.MediaType; +import javax.ws.rs.core.Response; + +@Path("/hcy_fengtianfangzhi") +public class DetailDataExportExcelController { + + + private DetailDataExportExcelApi detailDataExportExcelService = new DetailDataExportExcelService(); + + + private Logger logger = Util.getLogger(); + + /** + *导出AVPN Excel表格 + * @param request + * @param response + * @return + */ + @GET + @Path("/detailDataExportExcel") + @Produces(MediaType.APPLICATION_OCTET_STREAM) + public Response checkRequestInfo(@Context HttpServletRequest request, @Context HttpServletResponse response) { + + String requestid = request.getParameter("requestid"); + logger.info("requestid=="+requestid); + String lsxjd = request.getParameter("lsxjd"); + logger.info("lsxjd=="+lsxjd);//lsxjd + Response response1 = detailDataExportExcelService.exportExcel(requestid,lsxjd); + return response1; + } + + + + +} diff --git a/src/main/java/com/api/chaoyang/he/hcy_fengtianfangzhi/controller/TbSheetChangeDownloadStatusController.java b/src/main/java/com/api/chaoyang/he/hcy_fengtianfangzhi/controller/TbSheetChangeDownloadStatusController.java new file mode 100644 index 0000000..b029f70 --- /dev/null +++ b/src/main/java/com/api/chaoyang/he/hcy_fengtianfangzhi/controller/TbSheetChangeDownloadStatusController.java @@ -0,0 +1,280 @@ +package com.api.chaoyang.he.hcy_fengtianfangzhi.controller; + +import aiyh.utils.ApiResult; +import aiyh.utils.Util; +import com.engine.workflow.biz.requestForm.WfToDocBiz; +import com.engine.workflow.biz.requestForm.WfWaterMark4WfToDocBiz; +import org.apache.log4j.Logger; +import weaver.conn.RecordSet; +import weaver.file.FileUpload; +import weaver.file.ImageFileManager; +import weaver.hrm.HrmUserVarify; +import weaver.hrm.User; +import weaver.interfaces.workflow.action.WorkflowToDoc; +import weaver.system.SystemComInfo; + +import javax.servlet.http.HttpServletRequest; +import javax.servlet.http.HttpServletResponse; +import javax.ws.rs.GET; +import javax.ws.rs.Path; +import javax.ws.rs.Produces; +import javax.ws.rs.core.Context; +import javax.ws.rs.core.MediaType; +import javax.ws.rs.core.Response; +import javax.ws.rs.core.StreamingOutput; +import java.io.InputStream; +import java.util.LinkedHashMap; +import java.util.UUID; + + +/** + *

导出状态修改

+ * @Author jiacheng.deng + * @Date 2023/1/18 14:50 + */ +//"tb/djc/changeStatus/download/requestid=" + requestId + "&workflowid=" + workflowId + "&nodeid=" + nodeId +@Path("/tb") +public class TbSheetChangeDownloadStatusController { + + + //流程保存文档源码 + private WorkflowToDoc workflowToDoc = new WorkflowToDoc(); + //流程保存文档源码 + private WfToDocBiz wfToDocBiz = new WfToDocBiz(); + //数据库链接驱动 + private RecordSet recordSet = new RecordSet(); + //日志 + private final Logger log = Util.getLogger(); + //底部签字意见列表显示数量 + private int pageSize =100; + //下载的输入流 + private ImageFileManager imageFileManager = new ImageFileManager(); + + /** + *

修改导出状态

+ * @param request,response + * @return String + * @author jiacheng.deng + */ + @GET + @Path("/changeStatus/download") + @Produces(MediaType.APPLICATION_OCTET_STREAM) + public Response changeStatus(@Context HttpServletRequest request, + @Context HttpServletResponse response + ) { + + try { + User logInUser = HrmUserVarify.getUser(request, response); + String uid = String.valueOf(logInUser.getUID()); + log.info("用户的id===>" + uid); + String findUserRole = "select * from HrmRoleMembers where resourceid = " + uid; + boolean b = recordSet.execute(findUserRole); + log.info("查询用户数据sql===> " + findUserRole + " ===>是否执行 :" + b); + recordSet.next(); + String roleid = recordSet.getString("roleid"); + log.info("用户角色roleid===>" + roleid); + +// log.info("requsetid===>" + requestid + "workflowid===>" + workflowid + "nodeid===>" + nodeid); + + + if ("1031".equals(roleid)) { + + try { +// StreamingOutput downloadStream = download2changeStatus(uid,request,response,requestid,workflowid,nodeid); + +// InputStream is = imageFileManager.getInputStreamById(this.getImageFileId(requestid)); + + String updateDownloadStatusSQl = "update formtable_main_368 set dczt = ?" ; + + int flag = 1; + boolean b1 = recordSet.executeUpdate(updateDownloadStatusSQl, flag); + log.info("执行修改导出状态代码===>" + b1); + + +// return Response.ok(downloadStream, MediaType.APPLICATION_OCTET_STREAM).type("application/") +// .header("Content-Disposition", "attachment;filename=workflow.pdf").build(); + + } catch (Exception e) { + log.error("转换失败:" + e.toString()); + return Response.ok(ApiResult.error("出现错误,错误原因: " + e), MediaType.APPLICATION_JSON).build(); + } + + } else { + try { +// StreamingOutput downloadStream = download2changeStatus(uid,request,response,requestid,workflowid,nodeid); +// return Response.ok(downloadStream, MediaType.APPLICATION_OCTET_STREAM).type("application/pdf") +// .header("Content-Disposition", "attachment;filename=contracts.zip").build(); + } catch (Exception e) { + log.error("转换失败:" + e.toString()); + + return Response.ok(ApiResult.error("出现错误,错误原因: " + e), MediaType.APPLICATION_JSON).build(); + } + } + + }catch(Exception e){ + + } + return null; + } + + /** + *

修改导出状态

+ * @param + * @return + * @author jiacheng.deng + */ + public StreamingOutput download2changeStatus(String uid,HttpServletRequest request,HttpServletResponse response,String requestid,String workflowid,String nodeid){ + + LinkedHashMap fileids = new LinkedHashMap (); + + User user = new User(weaver.general.Util.getIntValue(uid)); + + String docFiles = getDocFiles(workflowid); + //是否签名 + int keepSign = getKeepSign(workflowid); + String filename = UUID.randomUUID().toString(); + String temppath = getFileSavePath(); + + //是否开启水印 + boolean isOpenWaterMark = WfWaterMark4WfToDocBiz.isOpenWaterMark(weaver.general.Util.getIntValue(workflowid)); + //在这里先获取到modeid 线程中获取时流程可能已经到了下个节点导致模板获取的不对 + String modeid = wfToDocBiz.getModeid(Util.getIntValue(requestid), Util.getIntValue(workflowid), Util.getIntValue(nodeid)); + + WfToDocBiz wfToDocBiz = new WfToDocBiz(user,pageSize,keepSign,docFiles,modeid,isOpenWaterMark); + wfToDocBiz.generatepdfandhtml(requestid,filename,temppath,"1"); + fileids.putAll(wfToDocBiz.getfileids("",filename,temppath)); + + StreamingOutput output = outputStream -> { + + String docID; + if (recordSet.next()){ + + docID = wfToDocBiz.getWfDocPath(workflowid, requestid); + log.info("文档生成路径=="+docID); + ImageFileManager imageFileManager = new ImageFileManager(); + int imageFileId = this.getImageFileId(requestid); + log.info("imageFileId ==" + imageFileId); + InputStream is = imageFileManager.getInputStreamById(this.getImageFileId(requestid)); + + String fileName = this.getImageFileName(requestid); + + }; + + //关闭流 + outputStream.flush(); + outputStream.close(); + }; + + return null; + } + + private String getImageFileName(String requestid) { + + return null; + } + + /** + *

获得文件保存目录

+ * @param + * @return String + * @author jiacheng.deng + */ + public String getFileSavePath() { + SystemComInfo syscominfo = new SystemComInfo(); + String createdir = FileUpload.getCreateDir(syscominfo.getFilesystem()); + return createdir; + } + + + /** + *

根据requestId返回docimagefile表中imagefileId

+ * @param requestid + * @return int + * @author jiacheng.deng + */ + public int getImageFileId(String requestid){ + RecordSet recordSet = new RecordSet(); + String get_imagefileid_sql = "select tablename \n" + + "from workflow_bill \n" + + "where id = (select formid from workflow_base where id = \n" + + "(select workflowid from workflow_requestbase where requestid = ?)\n" + + ")"; + boolean b = recordSet.executeQuery(get_imagefileid_sql, requestid); + log.info("b是否执行"+b); + boolean next = recordSet.next(); + String tablename = recordSet.getString("tablename"); + String docid_key = this.getWfDocRelateFieldName(requestid);//每一流程表单中用来存放docid的字段名称 + + String get_docid_sql = "select "+docid_key+" from "+tablename+" where requestid = ?"; + boolean b1 = recordSet.executeQuery(get_docid_sql, requestid); + log.info("b1是否执行=="+b1); + recordSet.next(); + String docid = recordSet.getString(docid_key); + if (Util.null2String(docid).equals("")){ + return -1; + } + String get_imagefileid = "select imagefileid from DocImageFile where docid = ? order by versionId"; + boolean b2 = recordSet.executeQuery(get_imagefileid, docid); + log.info("b2是否执行=="+b2); + recordSet.next(); + String imagefileid = recordSet.getString("imagefileid"); + return Integer.parseInt(imagefileid); + } + + /** + * 根据requestId反查 文档关联到的表单字段 + * @param requestid + * @return + */ + public String getWfDocRelateFieldName(String requestid){ + String get_wfdocrelatefilename_sql = "select fieldname from workflow_billfield \n" + + "where id =(select wfdocrelatefieldid from workflow_base \n" + + "where id = (select workflowid from workflow_requestbase where requestid = ?))"; + RecordSet recordSet = new RecordSet(); + boolean b = recordSet.executeQuery(get_wfdocrelatefilename_sql, requestid); + log.info("getWfDocRelateFieldName---b是否执行=="+b); + boolean next = recordSet.next(); + String fieldname = recordSet.getString("fieldname"); + return Util.null2String(fieldname); + } + + /** + *

得到docfiles 文档附件 在线表单/离线表单(HTML)/离线表单(PDF)

+ * @param workflowid + * @return String + * @author jiacheng.deng + */ + public String getDocFiles(String workflowid){ + RecordSet rs = new RecordSet(); + String docfiles = ""; + String wfdocpath = ""; + rs.executeQuery("select docfiles,wfdocpath from workflow_base where id = ?",workflowid); + if (rs.next()){ + docfiles = weaver.general.Util.null2String(rs.getString("docfiles")); + wfdocpath = weaver.general.Util.null2String(rs.getString("wfdocpath")); + } + if ("".equals(docfiles)&&!"".equals(wfdocpath)){ + docfiles="1"; + rs.executeUpdate("update workflow_base set docfiles ='1' where id = ?",workflowid); + } + return docfiles; + } + + /** + *

得到keepsign 是否保留签字意见

+ * @param workflowid + * @return int + * @author jiacheng.deng + */ + public int getKeepSign(String workflowid){ + RecordSet rs = new RecordSet(); + int keepsign = 0; + rs.executeQuery("select keepsign from workflow_base where id = ?",workflowid); + if (rs.next()){ + keepsign = rs.getInt("keepsign"); + } + return keepsign; + } + + +} diff --git a/src/main/java/com/api/chaoyang/he/hcy_fengtianfangzhi/mapper/DetailDataExportExcelMapper.java b/src/main/java/com/api/chaoyang/he/hcy_fengtianfangzhi/mapper/DetailDataExportExcelMapper.java new file mode 100644 index 0000000..d8e1652 --- /dev/null +++ b/src/main/java/com/api/chaoyang/he/hcy_fengtianfangzhi/mapper/DetailDataExportExcelMapper.java @@ -0,0 +1,22 @@ +package com.api.chaoyang.he.hcy_fengtianfangzhi.mapper; + +import aiyh.utils.annotation.recordset.Select; +import aiyh.utils.annotation.recordset.SqlMapper; + +import java.util.List; +import java.util.Map; + +@SqlMapper +public interface DetailDataExportExcelMapper{ + + @Select("select * from formtable_main_378 fm " + + "inner join formtable_main_378_dt1 fmdt " + + "on fm.id = fmdt.mainid where fm.requestid = #{requestid}") + List> selectTotalData(String requestId); + +// @Select("select * from formtable_main_35 fm " + +// "inner join formtable_main_35_dt1 fmdt " + +// "on fm.id = fmdt.mainid where fm.requestid = #{requestid}") +// List> selectTotalData(String requestId); + +} diff --git a/src/main/java/com/api/chaoyang/he/hcy_fengtianfangzhi/service/DetailDataExportExcelApi.java b/src/main/java/com/api/chaoyang/he/hcy_fengtianfangzhi/service/DetailDataExportExcelApi.java new file mode 100644 index 0000000..8398f64 --- /dev/null +++ b/src/main/java/com/api/chaoyang/he/hcy_fengtianfangzhi/service/DetailDataExportExcelApi.java @@ -0,0 +1,17 @@ +package com.api.chaoyang.he.hcy_fengtianfangzhi.service; + +import javax.ws.rs.core.Response; + +/** + * 生成excel接口文档 + */ +public interface DetailDataExportExcelApi { + + + /** + * 用于生成最终的excel表格 + */ + public Response exportExcel(String requestId,String lsxjd); + + +} diff --git a/src/main/java/com/api/chaoyang/he/hcy_fengtianfangzhi/service/impl/DetailDataExportExcelService.java b/src/main/java/com/api/chaoyang/he/hcy_fengtianfangzhi/service/impl/DetailDataExportExcelService.java new file mode 100644 index 0000000..44a7119 --- /dev/null +++ b/src/main/java/com/api/chaoyang/he/hcy_fengtianfangzhi/service/impl/DetailDataExportExcelService.java @@ -0,0 +1,403 @@ +package com.api.chaoyang.he.hcy_fengtianfangzhi.service.impl; + +import aiyh.utils.Util; + +import com.api.chaoyang.he.hcy_fengtianfangzhi.mapper.DetailDataExportExcelMapper; +import com.api.chaoyang.he.hcy_fengtianfangzhi.service.DetailDataExportExcelApi; +import org.apache.commons.io.IOUtils; +import org.apache.log4j.Logger; +import org.apache.poi.ss.usermodel.CellStyle; +import org.apache.poi.ss.usermodel.CellType; +import org.apache.poi.ss.usermodel.Font; +import org.apache.poi.ss.usermodel.Workbook; +import org.apache.poi.xssf.usermodel.XSSFCell; +import org.apache.poi.xssf.usermodel.XSSFRow; +import org.apache.poi.xssf.usermodel.XSSFSheet; +import org.apache.poi.xssf.usermodel.XSSFWorkbook; +import weaver.conn.RecordSet; + +import javax.ws.rs.core.MediaType; +import javax.ws.rs.core.Response; +import javax.ws.rs.core.StreamingOutput; +import java.io.ByteArrayInputStream; +import java.io.ByteArrayOutputStream; +import java.io.InputStream; +import java.nio.charset.StandardCharsets; +import java.util.ArrayList; +import java.util.HashMap; +import java.util.List; +import java.util.Map; + +public class DetailDataExportExcelService implements DetailDataExportExcelApi { + + /** + * 日志 + */ + public Logger logger = Util.getLogger(); + + + /** + * sql + */ + private DetailDataExportExcelMapper detailDataExportExcelMapper = Util.getMapper(DetailDataExportExcelMapper.class); + + + + /** + * 用来返回生成的excel流对象 + * @param requestId requestid + */ + public Response exportExcel(String requestId,String lsxjd) { + + //创建一个工作簿 + XSSFWorkbook workbook = new XSSFWorkbook(); + //创建一个工作表sheet + XSSFSheet sheet = workbook.createSheet(); + //设置sheet表名称 + workbook.setSheetName(0, "询价单明细表单"); + //设置表单列宽 + sheet.autoSizeColumn(1, true); + + RecordSet recordSet = new RecordSet();//创建sql执行对象 + + List> totalDataList = detailDataExportExcelMapper.selectTotalData(requestId); + for (Map map : totalDataList) { + for (Map.Entry entry : map.entrySet()) { + String key = entry.getKey(); + Object v = entry.getValue(); + if (key.equals("sqrxm")){//申请人姓名 + String get_sqrxm_sql = "select lastname from hrmresource where id=?"; + recordSet.executeQuery(get_sqrxm_sql,Util.null2String(v)); + recordSet.next(); + map.put("sqrxm",recordSet.getString("lastname")); + } + if (key.equals("gys")){//供应商 + String get_gys_sql = "select gysqm from uf_gyszsjxx where id=?"; + recordSet.executeQuery(get_gys_sql, Util.null2String(v)); + recordSet.next(); + map.put("gys",recordSet.getString("gysqm")); + } + if("xjr".equals(key)){//询价人 + String get_sqrxm_sql = "select lastname from hrmresource where id=?"; + recordSet.executeQuery(get_sqrxm_sql,Util.null2String(v)); + recordSet.next(); + map.put("xjr",recordSet.getString("lastname")); + } + if ("ylbm".equals(key) ||"sqrbm".equals(key) || "sqrfb".equals(key) || "xjbm".equals(key)){//依赖部门 //申请人部门 //申请人分部 //询价部门 + String getYlbm = "select departmentname from HrmDepartment where id = ? "; + recordSet.executeQuery(getYlbm,Util.null2String(v)); + recordSet.next(); + map.put(key,recordSet.getString("departmentname")); + } + + if ("lsxjd".equals(key)){//历史询价单 + String getLsxjd = "select requestname from workflow_requestbase where requestid = ? "; + recordSet.executeQuery(getLsxjd,Util.null2String(v)); + recordSet.next(); + map.put(key,recordSet.getString("requestname")); + } + +// if("sqrbm".equals(key)){//申请人部门 +// String getYlbm = "select departmentname from HrmDepartment where id = ? "; +// recordSet.executeQuery(getYlbm,Util.null2String(v)); +// recordSet.next(); +// map.put(key,recordSet.getString("departmentname")); +// } +// if ("sqrfb".equals(key)){//申请人分部 +// String getYlbm = "select departmentname from HrmDepartment where id = ? "; +// recordSet.executeQuery(getYlbm,Util.null2String(v)); +// recordSet.next(); +// map.put(key,recordSet.getString("departmentname")); +// } +// if("xjbm".equals(key)){//询价部门 +// String getYlbm = "select departmentname from HrmDepartment where id = ? "; +// recordSet.executeQuery(getYlbm,Util.null2String(v)); +// recordSet.next(); +// map.put(key,recordSet.getString("departmentname")); +// } + + } + } + + + + String getMainTableValueSql = "select id from uf_xjdmxbdczdpzbd where wybs = 'ftfz_exportExcel' "; + boolean b = recordSet.executeQuery(getMainTableValueSql); + logger.info("getMainTableValueSql是否执行=="+b); + String mainId = ""; + if (recordSet.next()){ + mainId = recordSet.getString("id"); + } + String getDetailTableValueSql = "select * from uf_xjdmxbdczdpzbd_dt1 where mainId = ?"; + boolean b1 = recordSet.executeQuery(getDetailTableValueSql, mainId); + logger.info("getDetailTableValueSql是否执行==="+b1); + List fieldNamesList = new ArrayList<>();//用于存放excel第一个行的明细表显示名 + List dBNamesList = new ArrayList<>();//用于存放明细表数据库名 + + while (recordSet.next()){ + String mxzdxsm = recordSet.getString("mxzdxsm");//字段显示名 + String mxzdsjkm = recordSet.getString("mxzdsjkm");//字段数据库名 + fieldNamesList.add(mxzdxsm); + dBNamesList.add(mxzdsjkm); + } + logger.info("fieldNamesList=="+fieldNamesList); + + + XSSFRow row = sheet.createRow(0); + + for (int colNum=0;colNum map1 = totalDataList.get(cowNum-1); + + for (int colNum=0;colNum { + outputStream.write(bytes); + outputStream.close(); + }; + + header = Response.ok(output,MediaType.APPLICATION_OCTET_STREAM) + .type("application/xlsx") + .header("Content-Disposition", + "attachment; filename=\""+ new String("询价单明细表单.xlsx".getBytes("GBK"), StandardCharsets.ISO_8859_1)+"\""); + } catch (Exception e) { + e.printStackTrace(); + logger.error("导出excel错误:" + Util.getErrString(e)); + } + build = header.build(); + logger.info("走到导出excel这一步"); + return build; + } + + + /** + * 设置字体样式,并设置字体加粗 + * + * @param workbook workbook对象 + * @return CellStyle对象 + */ + public static CellStyle setNolyWordStyle(Workbook workbook, Boolean setBold) { + // 设置字体 + CellStyle cellStyle = workbook.createCellStyle(); + Font font = workbook.createFont(); + //颜色 + font.setColor(Font.COLOR_NORMAL); + //设置字体大小 + font.setFontHeightInPoints((short) 10); + //字体 + font.setFontName("微软雅黑"); + font.setBold(setBold); + cellStyle.setFont(font); + return cellStyle; + } + + /** + * 只设置字体样式 + * + * @param workbook worKbook对象 + * @return CellStyle 字体样式 + */ + public static CellStyle setNolyWordStyle(Workbook workbook) { + // 设置字体 + CellStyle cellStyle = workbook.createCellStyle(); + Font font = workbook.createFont(); + //颜色 + font.setColor(Font.COLOR_NORMAL); + //设置字体大小 + font.setFontHeightInPoints((short) 10); + //字体 + font.setFontName("微软雅黑"); + cellStyle.setFont(font); + return cellStyle; + } + + + /** + * SXSSFWorkbook 转 InputStream + * @param workbook workbook对象 + * @return inputStream流 + */ + public static InputStream workbookConvertorStream(Workbook workbook) { + InputStream in = null; + try{ + //临时缓冲区 + ByteArrayOutputStream out = new ByteArrayOutputStream(); + //创建临时文件 + workbook.write(out); + byte [] bookByteAry = out.toByteArray(); + in = new ByteArrayInputStream(bookByteAry); + } + catch (Exception e){ + e.printStackTrace(); + } + return in; + } + + +} diff --git a/src/main/java/com/api/chaoyang/he/hcy_fengtianfangzhi/service/impl/DetailDataExportExcelService_copy.java b/src/main/java/com/api/chaoyang/he/hcy_fengtianfangzhi/service/impl/DetailDataExportExcelService_copy.java new file mode 100644 index 0000000..268b02a --- /dev/null +++ b/src/main/java/com/api/chaoyang/he/hcy_fengtianfangzhi/service/impl/DetailDataExportExcelService_copy.java @@ -0,0 +1,497 @@ +package com.api.chaoyang.he.hcy_fengtianfangzhi.service.impl; + +import aiyh.utils.Util; + +import com.api.chaoyang.he.hcy_fengtianfangzhi.service.DetailDataExportExcelApi; +import org.apache.commons.io.IOUtils; +import org.apache.log4j.Logger; +import org.apache.poi.ss.usermodel.CellStyle; +import org.apache.poi.ss.usermodel.CellType; +import org.apache.poi.ss.usermodel.Font; +import org.apache.poi.ss.usermodel.Workbook; +import org.apache.poi.xssf.usermodel.XSSFCell; +import org.apache.poi.xssf.usermodel.XSSFRow; +import org.apache.poi.xssf.usermodel.XSSFSheet; +import org.apache.poi.xssf.usermodel.XSSFWorkbook; +import weaver.conn.RecordSet; + +import javax.ws.rs.core.MediaType; +import javax.ws.rs.core.Response; +import javax.ws.rs.core.StreamingOutput; +import java.io.ByteArrayInputStream; +import java.io.ByteArrayOutputStream; +import java.io.InputStream; +import java.nio.charset.StandardCharsets; +import java.util.ArrayList; +import java.util.HashMap; +import java.util.List; +import java.util.Map; + +public class DetailDataExportExcelService_copy implements DetailDataExportExcelApi { + + + public Logger logger = Util.getLogger(); + + /** + * 用来返回生成的excel流对象 + * @param requestId requestid + */ + public Response exportExcel(String requestId,String lsxjd) { + + //创建一个工作簿 + XSSFWorkbook workbook = new XSSFWorkbook(); + //创建一个工作表sheet + XSSFSheet sheet = workbook.createSheet(); + //设置sheet表名称 + workbook.setSheetName(0, "询价单明细表单"); + //设置表单列宽 + sheet.autoSizeColumn(1, true); + + RecordSet recordSet = new RecordSet();//创建sql执行对象 + String getMainIdSql = "select * from formtable_main_378 where requestId = ?"; +// String getMainIdSql = "select * from formtable_main_35 where requestId = ?"; + + boolean b2 = recordSet.executeQuery(getMainIdSql, requestId); + logger.info("getMainIdSql语句是否执行==="+b2); + String formtable_main_35_id="";//询价单流程表单id,作为明细表的mianId使用 + Map mainDataMap = new HashMap<>();//用于存放主表的数据 + if (recordSet.next()){ + formtable_main_35_id = recordSet.getString("id"); + String sqdh = recordSet.getString("sqdh");//申请单号 + mainDataMap.put("sqdh",sqdh); + String sqrxmID = recordSet.getString("sqrxm");//申请人姓名 + String get_sqrxm_sql = "select lastname from hrmresource where id=?"; + RecordSet recordSet1 = new RecordSet(); + recordSet1.executeQuery(get_sqrxm_sql, sqrxmID); + if (recordSet1.next()){ + String lastname = recordSet1.getString("lastname"); + mainDataMap.put("sqrxm",lastname); + } + String sqrbm = recordSet.getString("sqrbm");//申请人部门 + mainDataMap.put("sqrbm",sqrbm); + String sqrfb = recordSet.getString("sqrfb");//申请人分部 + mainDataMap.put("sqrfb",sqrfb); + String sqrq = recordSet.getString("sqrq");//申请日期 + mainDataMap.put("sqrq",sqrq); +// String lsxjd = recordSet.getString("lsxjd");//历史询价单 + mainDataMap.put("lsxjd",lsxjd); + String xjbm = recordSet.getString("xjbm");//询价部门 + mainDataMap.put("xjbm",xjbm); + String bz = recordSet.getString("bz");//备注 + mainDataMap.put("bz",bz); + String bjfj = recordSet.getString("bjfj");//报价附件 + mainDataMap.put("bjfj",bjfj); + String yafj = recordSet.getString("yafj");//议案附件 + mainDataMap.put("yafj",yafj); + String sysfj = recordSet.getString("sysfj");//式样书附件 + mainDataMap.put("sysfj",sysfj); + String hszje = recordSet.getString("hszje");//含税总金额 + mainDataMap.put("hszje",hszje); + String wszje = recordSet.getString("wszje");//未税总金额 + mainDataMap.put("wszje",wszje); + String fkblhj = recordSet.getString("fkblhj");//付款比例(合计) + mainDataMap.put("fkblhj",fkblhj); + String ylbmId = recordSet.getString("ylbm");//依赖部门 + String getYlbm = "select departmentname from HrmDepartment where id = ? "; + recordSet1.executeQuery(getYlbm,ylbmId); + recordSet1.next(); + String departmentname = recordSet1.getString("departmentname"); + mainDataMap.put("ylbm",departmentname); + String xjrid = recordSet.getString("xjr");//询价人 + recordSet1.executeQuery(get_sqrxm_sql,xjrid); + recordSet1.next(); + String xjr = recordSet1.getString("lastname"); + mainDataMap.put("xjr",xjr); + String gysId = recordSet.getString("gys");//供应商 + String get_gys_sql = "select gysqm from uf_gyszsjxx where id=?"; + recordSet1.executeQuery(get_gys_sql, gysId); + if (recordSet1.next()){ + String gysqm = recordSet1.getString("gysqm"); + mainDataMap.put("gys",gysqm); + } + + } + logger.info("mainDataMap主表数据==="+mainDataMap); + String getDetailDataSql = "select * from formtable_main_378_dt1 where mainId = ?"; +// String getDetailDataSql = "select * from formtable_main_35_dt1 where mainId = ?"; + boolean b3 = recordSet.executeQuery(getDetailDataSql, formtable_main_35_id); + logger.info("getDetailDataSql语句是否执行==="+b3); + List> listMap = new ArrayList<>();//用于存放明细表数据 + while (recordSet.next()){ + Map map = new HashMap<>(); + String id = recordSet.getString("id"); + map.put("id",id); + String mainId1 = recordSet.getString("mainId"); + map.put("mainId",mainId1); + String pl = Util.null2String(recordSet.getString("pl")); + String plValue = ""; + if (!"".equals(pl)){ + //消耗品 设备工事 劳保用品 IT + switch(pl){ + case "0": + plValue = "消耗品"; + break; + case "1" : + plValue = "设备工事"; + break; + case "2" : + plValue = "劳保用品"; + break; + case "3": + break; + default : + plValue = ""; + break; + } + }else{ + map.put("pl", ""); + } + map.put("pl", plValue); + String pm = recordSet.getString("pm"); + map.put("pm",pm); + String pp = recordSet.getString("pp"); + map.put("pp",pp); + String ggxh = recordSet.getString("ggxh"); + map.put("ggxh",ggxh); + String jldw = recordSet.getString("jldw"); + map.put("jldw",jldw); + String sqsl = recordSet.getString("sqsl"); + map.put("sqsl",sqsl); + String bz = recordSet.getString("bz"); + map.put("bz",bz); + String wsdj = recordSet.getString("wsdj"); + map.put("wsdj",wsdj); + String wszj = recordSet.getString("wszj"); + map.put("wszj",wszj); + String sl = recordSet.getString("sl"); + map.put("sl",sl); + String se = recordSet.getString("se"); + map.put("se",se); + String hsdj = recordSet.getString("hsdj"); + map.put("hsdj",hsdj); + String hszj = recordSet.getString("hszj"); + map.put("hszj",hszj); + String qwnq = recordSet.getString("qwnq"); + map.put("qwnq",qwnq); + String ddhfqwnqt = recordSet.getString("ddhfqwnqt"); + map.put("ddhfqwnqt",ddhfqwnqt); + String gys = recordSet.getString("gys"); + map.put("gys",gys); + String cx = recordSet.getString("cx"); + map.put("cx",cx); + String jd = recordSet.getString("jd"); + map.put("jd",jd); + String bz1 = recordSet.getString("bz1"); + map.put("bz1",bz1); + String fj = recordSet.getString("fj"); + map.put("fj",fj); + String chzx = recordSet.getString("chzx"); + map.put("chzx",chzx); + String chbm = recordSet.getString("chbm"); + map.put("chbm",chbm); + listMap.add(map); + } + logger.info("listMap明细表数据==="+listMap); + String getMainTableValueSql = "select id from uf_xjdmxbdczdpzbd where wybs = 'ftfz_exportExcel' "; + boolean b = recordSet.executeQuery(getMainTableValueSql); + logger.info("getMainTableValueSql是否执行=="+b); + String mainId = ""; + if (recordSet.next()){ + mainId = recordSet.getString("id"); + } + String getDetailTableValueSql = "select * from uf_xjdmxbdczdpzbd_dt1 where mainId = ?"; + boolean b1 = recordSet.executeQuery(getDetailTableValueSql, mainId); + logger.info("getDetailTableValueSql是否执行==="+b1); + List fieldNamesList = new ArrayList<>();//用于存放excel第一个行的明细表显示名 + List mainFieldNamesList = new ArrayList<>();//用于存放excel第一个行的主表显示名 + List detalsDBName = new ArrayList<>();//用于存放明细表数据库名 + List mainDBName = new ArrayList<>();//用于存放主表数据库字段名 + while (recordSet.next()){ + String sjly = recordSet.getString("sjly");//数据来源 + String mxzdxsm = recordSet.getString("mxzdxsm");//字段显示名 +// String mxzdlx = recordSet.getString("mxzdlx");//字段类型 + String mxzdsjkm = recordSet.getString("mxzdsjkm");//字段数据库名 + if (!"".equals(sjly)&&sjly.equals("0")){ + mainFieldNamesList.add(mxzdxsm); + mainDBName.add(mxzdsjkm); + }else if (!"".equals(sjly)&&sjly.equals("1")){ + fieldNamesList.add(mxzdxsm); + detalsDBName.add(mxzdsjkm); + } + + } + logger.info("fieldNamesList=="+fieldNamesList); + logger.info("mainFieldNamesList=="+mainFieldNamesList); + logger.info("detalsDBName=="+detalsDBName); + logger.info("mainDBName=="+mainDBName); + + XSSFRow row = sheet.createRow(0); + for (int colNum=0;colNum map1 = listMap.get(cowNum-1); + for (int colMainDataNum=0;colMainDataNum { + outputStream.write(bytes); + outputStream.close(); + }; + + header = Response.ok(output,MediaType.APPLICATION_OCTET_STREAM) + .type("application/xlsx") + .header("Content-Disposition", + "attachment; filename=\""+ new String("询价单明细表单.xlsx".getBytes("GBK"), StandardCharsets.ISO_8859_1)+"\""); + } catch (Exception e) { + e.printStackTrace(); + logger.error("导出excel错误:" + Util.getErrString(e)); + } + build = header.build(); + logger.info("走到导出excel这一步"); + return build; + } + + + /** + * 设置字体样式,并设置字体加粗 + * + * @param workbook workbook对象 + * @return CellStyle对象 + */ + public static CellStyle setNolyWordStyle(Workbook workbook, Boolean setBold) { + // 设置字体 + CellStyle cellStyle = workbook.createCellStyle(); + Font font = workbook.createFont(); + //颜色 + font.setColor(Font.COLOR_NORMAL); + //设置字体大小 + font.setFontHeightInPoints((short) 10); + //字体 + font.setFontName("微软雅黑"); + font.setBold(setBold); + cellStyle.setFont(font); + return cellStyle; + } + + /** + * 只设置字体样式 + * + * @param workbook worKbook对象 + * @return CellStyle 字体样式 + */ + public static CellStyle setNolyWordStyle(Workbook workbook) { + // 设置字体 + CellStyle cellStyle = workbook.createCellStyle(); + Font font = workbook.createFont(); + //颜色 + font.setColor(Font.COLOR_NORMAL); + //设置字体大小 + font.setFontHeightInPoints((short) 10); + //字体 + font.setFontName("微软雅黑"); + cellStyle.setFont(font); + return cellStyle; + } + + + /** + * SXSSFWorkbook 转 InputStream + * @param workbook workbook对象 + * @return inputStream流 + */ + public static InputStream workbookConvertorStream(Workbook workbook) { + InputStream in = null; + try{ + //临时缓冲区 + ByteArrayOutputStream out = new ByteArrayOutputStream(); + //创建临时文件 + workbook.write(out); + byte [] bookByteAry = out.toByteArray(); + in = new ByteArrayInputStream(bookByteAry); + } + catch (Exception e){ + e.printStackTrace(); + } + return in; + } + + +} diff --git a/src/main/java/com/api/chaoyang/he/hcy_fengtianfangzhi/wflistdonestore/ExportPDF.java b/src/main/java/com/api/chaoyang/he/hcy_fengtianfangzhi/wflistdonestore/ExportPDF.java new file mode 100644 index 0000000..f3f8655 --- /dev/null +++ b/src/main/java/com/api/chaoyang/he/hcy_fengtianfangzhi/wflistdonestore/ExportPDF.java @@ -0,0 +1,257 @@ +package com.api.chaoyang.he.hcy_fengtianfangzhi.wflistdonestore; + +import aiyh.utils.ApiResult; +import aiyh.utils.Util; +import com.engine.workflow.biz.requestForm.WfToDocBiz; +import org.apache.log4j.Logger; +import org.apache.tools.zip.ZipEntry; +import org.apache.tools.zip.ZipOutputStream; +import weaver.conn.RecordSet; +import weaver.file.ImageFileManager; +import weaver.hrm.HrmUserVarify; + +import javax.servlet.http.HttpServletRequest; +import javax.servlet.http.HttpServletResponse; +import javax.ws.rs.GET; +import javax.ws.rs.Path; +import javax.ws.rs.Produces; +import javax.ws.rs.core.Context; +import javax.ws.rs.core.MediaType; +import javax.ws.rs.core.Response; +import javax.ws.rs.core.StreamingOutput; +import java.io.InputStream; +import java.nio.charset.StandardCharsets; +import java.time.LocalDateTime; +import java.time.format.DateTimeFormatter; + +@Path("/hcy_fengtianfangzhi/wflistdonestore") +public class ExportPDF { + + private final Logger logger = Util.getLogger(); + + /** + * 源码内容 + */ + private final WfToDocBiz wfToDocBiz = new WfToDocBiz(); + + /** + *已办流程批量导出pdf + * @param request 请求 + * @param response 响应 + * @return Response 包含所有勾选的压缩包 + */ + @GET + @Path("/ExportPDF") + @Produces(MediaType.APPLICATION_OCTET_STREAM) + public Response exportPDF(@Context HttpServletRequest request, @Context HttpServletResponse response) { + + try { + String ids = request.getParameter("ids"); + String[] split = ids.split(","); + String getWorkflowId_sql = "select workflowid from workflow_requestbase where requestid = ?"; + RecordSet recordSet = new RecordSet(); + int amountWorkflowToDoc = this.getAmountWorkflowToDoc(split);//用来统计流程转文档的流程的数量,如果数量为0,返回文件为空 + StreamingOutput output = outputStream -> { + ZipOutputStream zipOut = new ZipOutputStream(outputStream); + for (String requestId : split) { + boolean b = recordSet.executeQuery(getWorkflowId_sql, requestId); + logger.info("b是否执行"+b); + String docID; + if (recordSet.next()){ + String workflowid = recordSet.getString("workflowid"); + docID = wfToDocBiz.getWfDocPath(workflowid, requestId); + logger.info("文档生成路径=="+docID); + int imageFileId = this.getImageFileId(requestId); + if (imageFileId==-1){ + continue; + } + InputStream is = ImageFileManager.getInputStreamById(this.getImageFileId(requestId)); + String fileName = this.getImageFileName(requestId); + if (Util.null2String(fileName).equals("")){ + break; + } + this.addToZip(is,zipOut,fileName);//向zipout对象中插入每个pdf文件 + } + } + //关闭流 + zipOut.flush(); + zipOut.close(); + outputStream.flush(); + outputStream.close(); + }; + + if (amountWorkflowToDoc == 0){ + return Response.ok(ApiResult.error("文件为空"),MediaType.TEXT_PLAIN).build(); + } + String lastname = HrmUserVarify.getUser(request, response).getLastname(); + String pdfName = lastname + "_" +getCurrentTime() + "_" + split.length; + return Response.ok(output, MediaType.APPLICATION_OCTET_STREAM).type("application/zip") + .header("Content-Disposition", "attachment;filename=\"" + + new String(pdfName.getBytes("GBK"), StandardCharsets.ISO_8859_1) + ".zip" + "\"").build(); + } catch (Exception e) { + e.printStackTrace(); + return Response.ok(ApiResult.error("出现错误,错误原因:"+e),MediaType.TEXT_PLAIN).build(); + } + } + + /** + * 当某个流程成功导出pdf时,更新导出状态字段为已导出 + * @param requestId requestid + */ + public void updateValue(String requestId){ + RecordSet recordSet = new RecordSet(); + String get_imagefileid_sql = "select tablename \n" + + "from workflow_bill \n" + + "where id = (select formid from workflow_base where id = \n" + + "(select workflowid from workflow_requestbase where requestid = ?)\n" + + ")"; + boolean b = recordSet.executeQuery(get_imagefileid_sql, requestId); + logger.info("updateValue()----b是否执行"+b); + recordSet.next(); + String tablename = recordSet.getString("tablename"); + boolean b1 = recordSet.executeUpdate("update " + tablename + " set dczt = 0,dcsj = ? where requestid = ?",getCurrentTime(), requestId); + logger.info("updatevalue()----b1是否执行==="+b1); + } + + /** + * 用来统计流程转文档的流程的数量,如果数量为0,返回文件为空, + * 并将已经流程转流程并且导出pdf的流程字段更新相关流程的导出字段为已导出 + * @param split requestid组成的数组集合 + * @return int 返回一个整型数字用于判断 + */ + public int getAmountWorkflowToDoc(String[] split){ + int amount = 0; + String getWorkflowId_sql = "select workflowid from workflow_requestbase where requestid = ?"; + RecordSet recordSet = new RecordSet(); + for (String requestId : split) { + boolean b = recordSet.executeQuery(getWorkflowId_sql, requestId); + logger.info("getAmountWorkflowToDoc----b是否执行==="+b); + if (recordSet.next()){ + int imageFileId = this.getImageFileId(requestId); + if (imageFileId==-1){ + continue; + }else { + amount++; + //用来更新更新具体哪个流程表单的导出状态为已导出 + this.updateValue(requestId); + } + } + } + return amount; + } + + /** + * 根据requestId返回docimagefile表中imagefileId + * @param requestId requestid + * @return int + */ + public int getImageFileId(String requestId){ + RecordSet recordSet = new RecordSet(); + String get_imagefileid_sql = "select tablename \n" + + "from workflow_bill \n" + + "where id = (select formid from workflow_base where id = \n" + + "(select workflowid from workflow_requestbase where requestid = ?)\n" + + ")"; + boolean b = recordSet.executeQuery(get_imagefileid_sql, requestId); + logger.info("b是否执行"+b); + recordSet.next(); + String tablename = recordSet.getString("tablename"); + String docid_key = this.getWfDocRelateFieldName(requestId);//每一流程表单中用来存放docid的字段名称 + + String get_docid_sql = "select "+docid_key+" from "+tablename+" where requestid = ?"; + boolean b1 = recordSet.executeQuery(get_docid_sql, requestId); + logger.info("b1是否执行=="+b1); + recordSet.next(); + String docid = recordSet.getString(docid_key); + if (Util.null2String(docid).equals("")){ + return -1; + } + String get_imagefileid = "select imagefileid from DocImageFile where docid = ? order by versionId"; + boolean b2 = recordSet.executeQuery(get_imagefileid, docid); + logger.info("b2是否执行=="+b2); + recordSet.next(); + String imagefileid = recordSet.getString("imagefileid"); + return Integer.parseInt(imagefileid); + } + + + /** + * 根据requestId返回docimagefile表中imagefilename + * @param requestId requestid + * @return String 返回imagefilename + */ + public String getImageFileName(String requestId){ + RecordSet recordSet = new RecordSet(); + String get_tablename_sql = "select tablename \n" + + "from workflow_bill \n" + + "where id = (select formid from workflow_base where id = \n" + + "(select workflowid from workflow_requestbase where requestid = ?)\n" + + ")"; + boolean b = recordSet.executeQuery(get_tablename_sql, requestId); + logger.info("b是否执行"+b); + recordSet.next(); + String tablename = recordSet.getString("tablename"); + String docid_key = this.getWfDocRelateFieldName(requestId);//每一流程表单中用来存放docid的字段名称 + + String get_docid_sql = "select "+docid_key+" from "+tablename+" where requestid = ?"; + boolean b1 = recordSet.executeQuery(get_docid_sql, requestId); + logger.info("b1是否执行=="+b1); + recordSet.next(); + String docid = recordSet.getString(docid_key); + String get_imagefilename = "select imagefilename from DocImageFile where docid = ? order by versionId"; + boolean b2 = recordSet.executeQuery(get_imagefilename, docid); + logger.info("b2是否执行=="+b2); + recordSet.next(); + return recordSet.getString("imagefilename"); + } + + /** + * 根据requestId反查 文档关联到的表单字段 + * @param requestid requestid + * @return String 返回filename + */ + public String getWfDocRelateFieldName(String requestid){ + String get_wfdocrelatefilename_sql = "select fieldname from workflow_billfield \n" + + "where id =(select wfdocrelatefieldid from workflow_base \n" + + "where id = (select workflowid from workflow_requestbase where requestid = ?))"; + RecordSet recordSet = new RecordSet(); + boolean b = recordSet.executeQuery(get_wfdocrelatefilename_sql, requestid); + recordSet.next(); + logger.info("getWfDocRelateFieldName---b是否执行=="+b); + String fieldname = recordSet.getString("fieldname"); + return Util.null2String(fieldname); + } + /** + * 添加压缩文件 + * @param is 文件输入流 + * @param zipOut zipOUtPutStream + * @param fileName 文件名称 + */ + private void addToZip(InputStream is, ZipOutputStream zipOut, String fileName) { + try{ + ZipEntry entry = new ZipEntry(fileName); + zipOut.putNextEntry(entry); + int len; + byte[] buffer = new byte[1024]; + while ((len = is.read(buffer)) > 0) { + zipOut.write(buffer, 0, len); + } + zipOut.closeEntry(); + is.close(); + }catch (Exception e){ + e.printStackTrace(); + } + } + + /** + *

获取系统当前日期时间

+ * @return String + * @author hcy + * 2023/4/4 17:31 + */ + public String getCurrentTime() { + LocalDateTime now = LocalDateTime.now(); + DateTimeFormatter formatter = DateTimeFormatter.ofPattern("yyyy-MM-dd"); + return now.format(formatter); + } +} diff --git a/src/main/java/com/api/chaoyang/he/hcy_xintiantongxin/ExportExcelAVPNApi.java b/src/main/java/com/api/chaoyang/he/hcy_xintiantongxin/ExportExcelAVPNApi.java new file mode 100644 index 0000000..24d2714 --- /dev/null +++ b/src/main/java/com/api/chaoyang/he/hcy_xintiantongxin/ExportExcelAVPNApi.java @@ -0,0 +1,683 @@ +package com.api.chaoyang.he.hcy_xintiantongxin; + + +import aiyh.utils.Util; +import org.apache.commons.io.IOUtils; +import org.apache.log4j.Logger; +import org.apache.poi.ss.usermodel.*; +import org.apache.poi.ss.util.CellRangeAddress; +import org.apache.poi.xssf.usermodel.XSSFWorkbook; +import weaver.conn.RecordSet; + +import javax.servlet.http.HttpServletRequest; +import javax.servlet.http.HttpServletResponse; +import javax.ws.rs.GET; +import javax.ws.rs.Path; +import javax.ws.rs.Produces; +import javax.ws.rs.core.Context; +import javax.ws.rs.core.MediaType; +import javax.ws.rs.core.Response; +import javax.ws.rs.core.StreamingOutput; +import java.io.ByteArrayInputStream; +import java.io.ByteArrayOutputStream; +import java.io.InputStream; +import java.nio.charset.StandardCharsets; +import java.util.*; + +@Path("/hcy_xintiantongxin") +public class ExportExcelAVPNApi { + + private Logger logger = Util.getLogger(); + + /** + *导出AVPN Excel表格 + * @param request + * @param response + * @return + */ + @GET + @Path("/ExportExcelAVPNApi") + @Produces(MediaType.APPLICATION_OCTET_STREAM) + public Response checkRequestInfo(@Context HttpServletRequest request, @Context HttpServletResponse response) { + + Response build = null; + Response.ResponseBuilder header = null; + try { + //查询到 uf_avpn_export AVPN导出表中的一条数据的ids + String ids = request.getParameter("ids"); + RecordSet rs = new RecordSet(); + StreamingOutput output = null; + + String sql_AVPN_db = "select * from uf_avpn_export where id = ?"; + rs.executeQuery(sql_AVPN_db, ids); + + //创建一个工作簿 + Workbook workbook = new XSSFWorkbook(); + String[] dbFiled = new String[10]; + String mainId = ""; + + while (rs.next()) { + //查询到uf_avpn_export表的id作为查询明细表的mainid + mainId = rs.getString("id"); + String pd_nameId = rs.getString("pd_name");//uf_pd_base_inf 得到的pd_name是字段的id + RecordSet recordSet = new RecordSet(); + String getPd_nameByIdSql = "select pd_name from uf_pd_base_inf where id =?"; + boolean b1 = recordSet.executeQuery(getPd_nameByIdSql, pd_nameId); + + logger.info("查询pd_namesql语句是否成功==" + b1); + if (recordSet.next()) { + String pd_name = recordSet.getString("pd_name");//查询到pd_name的值 + dbFiled[0] = pd_name; + } + String billing_model = rs.getString("billing_model"); + if (billing_model.equals("0")){ + billing_model = "Assignment Model Billing in China"; + } + dbFiled[1] = billing_model; + String customer_name = rs.getString("customer_name"); + dbFiled[2] = customer_name; + String ecrm_opportunity = rs.getString("ecrm_opportunity"); + dbFiled[3] = ecrm_opportunity; + String igloo = rs.getString("igloo"); + dbFiled[4] = igloo; + String terms = rs.getString("terms"); + dbFiled[5] = terms; + String att_lead_pricer = rs.getString("att_lead_pricer"); + dbFiled[6] = att_lead_pricer; + String requestjustificationoptional = rs.getString("requestjustificationoptional"); + dbFiled[7] = requestjustificationoptional; + String specialrequesttosstoptional = rs.getString("specialrequesttosstoptional"); + dbFiled[8] = specialrequesttosstoptional; + String sst_contact = rs.getString("sst_contact"); + dbFiled[9] = sst_contact; + } + //表单字段 + String[] tableFiled = new String[]{"Service Type", "Billing Model", "Customer Name", "ECRM Opportunity#", "Igloo #", "Contract Term (in months)", "AT&T Lead Pricer", "Request Justification (optional)", "Special Request to SST (Optional)", "SST Contact"}; + //明细表字段 + String[] mergerDetailTableFiled = new String[]{"Site ID", "Description", "Bandwidth", "OTC in RMB", "MRC in RMB"}; + + //创建一个工作表sheet + Sheet sheet = workbook.createSheet(); + workbook.setSheetName(0, "AVPN表单"); + sheet.autoSizeColumn(1, true); + //写入数据 //写入1-11行第一列 第二列数据 + for (int rowNum = 1; rowNum < 11; rowNum++) { + Row row = sheet.createRow(rowNum); + Cell cell0 = row.createCell(0); + cell0.setCellStyle(this.setWordStyle(workbook, true)); + cell0.setCellValue(tableFiled[rowNum - 1]); + Cell cell1 = row.createCell(1); + cell1.setCellStyle(setWordStyle(workbook, true)); + cell1.setCellValue(dbFiled[rowNum - 1]); + } + Row row12 = sheet.createRow(12);//第13行 + Cell cell12_11 = row12.createCell(11); + cell12_11.setCellStyle(setWordStyle(workbook, true)); + cell12_11.setCellValue("Default Assignment Model-Billing in China in RMB"); + Cell cell12_12 = row12.createCell(12); + cell12_12.setCellStyle(setNolyBorderStyle(workbook)); + sheet.addMergedRegion(new CellRangeAddress(12, 12, 11, 12)); + + //设置14行到15行前5列内容 + Row row13 = sheet.createRow(13); + Row row14 = sheet.createRow(14); + for (int colNum = 0; colNum < 5; colNum++) { + Cell cell = row13.createCell(colNum); + cell.setCellStyle(setWordStyle(workbook, true)); + cell.setCellValue(mergerDetailTableFiled[colNum]); + Cell cell1 = row14.createCell(colNum); + cell1.setCellStyle(setWordStyle(workbook, true)); + cell1.setCellValue(mergerDetailTableFiled[colNum]); + sheet.addMergedRegion(new CellRangeAddress(13, 14, colNum, colNum)); + } + + + + //设置14行第六列到第13列的内容 + String[] mergerDetailTableFiled02 = new String[]{"Discount Requested (%)", "Discount SST approved (%)", "Net Price to AT&T Customer", "Royalty to SST without Tax(contra-revenue)"}; + Cell cell13_5 = row13.createCell(5); + cell13_5.setCellStyle(setWordStyle(workbook, true)); + cell13_5.setCellValue(mergerDetailTableFiled02[0]); + Cell cell113_6 = row13.createCell(6); + cell113_6.setCellStyle(setWordStyle(workbook, true)); + cell113_6.setCellValue(mergerDetailTableFiled02[0]); + sheet.addMergedRegion(new CellRangeAddress(13, 13, 5, 6)); + + + Cell cell13_7 = row13.createCell(7); + cell13_7.setCellStyle(setWordStyle(workbook, true)); + cell13_7.setCellValue(mergerDetailTableFiled02[1]); + Cell cell13_8 = row13.createCell(8); + cell13_8.setCellStyle(setWordStyle(workbook, true)); + cell13_8.setCellValue(mergerDetailTableFiled02[1]); + sheet.addMergedRegion(new CellRangeAddress(13, 13, 7, 8)); + + Cell cell13_9 = row13.createCell(9); + cell13_9.setCellStyle(setWordStyle(workbook, true)); + cell13_9.setCellValue(mergerDetailTableFiled02[2]); + Cell cell13_10 = row13.createCell(10); + cell13_10.setCellStyle(setWordStyle(workbook, true)); + cell13_10.setCellValue(mergerDetailTableFiled02[2]); + sheet.addMergedRegion(new CellRangeAddress(13, 13, 9, 10)); + + Cell cell13_11 = row13.createCell(11); + cell13_11.setCellStyle(setWordStyle(workbook, true)); + cell13_11.setCellValue(mergerDetailTableFiled02[3]); + Cell cell13_12 = row13.createCell(12); + cell13_12.setCellStyle(setWordStyle(workbook, true)); + cell13_12.setCellValue(mergerDetailTableFiled02[3]); + sheet.addMergedRegion(new CellRangeAddress(13, 13, 11, 12)); + + + //设置15行第六列到第13列的内容 + String[] mergerDetailTableFiled03 = new String[]{"OTC", "MRC", "OTC", "MRC", "OTC in RMB", "MRC in RMB", "OTC in RMB", "MRC in RMB"}; + for (int colNum = 5; colNum < 13; colNum++) { + Cell cell = row14.createCell(colNum); + for (int num = 0; num < 8; num++) { + cell.setCellStyle(setWordStyle(workbook, true)); + cell.setCellValue(mergerDetailTableFiled03[num]); + } + } + + + List> siteMap = new ArrayList<>();//用来存放site的类型和每个site的状态 + + String getSiteSql = "select site ,count(site) siteNum from uf_avpn_export_dt1 where mainId =? group by site ;"; + RecordSet rs02 = new RecordSet(); + boolean b = rs02.executeQuery(getSiteSql, mainId); + logger.info("查询site,以及site的数量的sql语句===" + b); + + while (rs02.next()) { + HashMap map = new HashMap<>(); + String site = rs02.getString("site"); + String siteNum = rs02.getString("siteNum"); + map.put(site, siteNum); + siteMap.add(map);//将site的类型和每个site的类型的个数放到siteList数组中,用来循环遍历再放入单元格中 + } + int firstCow = 15;//从第15行开始写入明细表,固定死 + int finalyCow = 0; + + + Double sum9 = 0D; + Double sum10 = 0D; + Double sum11 = 0D; + Double sum12 = 0D; + for (Map map : siteMap) { + Set siteKeySet = map.keySet(); + List> detailDateList = new ArrayList(); + int cowLength = 0;//每一个site类型的数据的长度 + for (String s1 : siteKeySet) { + cowLength = Integer.parseInt(map.get(s1));//每一个site类型的数据的长度 + String getDetailDataSql = "select * from uf_avpn_export_dt1 where mainId =? and site = ?"; + rs02.executeQuery(getDetailDataSql, mainId, s1); + while (rs02.next()) { + String site = rs02.getString("site");//Site ID + String itemId = rs02.getString("Item");//Description + String getItemValueSql = "select item from uf_pd_item_inf where id =?"; + RecordSet recordSet1 = new RecordSet(); + boolean b2 = recordSet1.executeQuery(getItemValueSql, itemId); + logger.info("查询item值sql是否执行成功=" + b2); + String item = "";//从数据库中查询到item的值 + if (recordSet1.next()) { + item = recordSet1.getString("Item"); + } + + String categoryId = rs02.getString("Category");//Bandwidth + String getCategoryByIdSql = "select category from uf_pd_category_inf where id = ?"; + boolean b3 = recordSet1.executeQuery(getCategoryByIdSql, categoryId); + logger.info("查询categorySql是否执行成功==" + b3); + String category = ""; + if (recordSet1.next()) { + category = recordSet1.getString("category"); + } + String otc_price = rs02.getString("otc_price");//OTC in RMB + String mrc_price = rs02.getString("mrc_price");//MRC in RMB + String otcdiscountrequest = rs02.getString("otcdiscountrequest");//Discount Requested (%) OTC + String mrcdiscountrequest = rs02.getString("mrcdiscountrequest");//Discount Requested (%) MRC + String otcdiscountapproved = rs02.getString("otcdiscountapproved");//Discount SST approved (%) OTC + String mrcdiscountapproved = rs02.getString("mrcdiscountapproved");//Discount SST approved (%)MRC + String otc_tariff = rs02.getString("otc_tariff");//Net Price to AT&T Customer(OTC in RMB) + String mrc_tariff = rs02.getString("mrc_tariff");//Net Price to AT&T Customer(MRC in RMB) + String otc_scale = rs02.getString("otc_scale");//Royalty to SST without Tax (contra-revenue)(OTC in RMB) + String mrc_scale = rs02.getString("mrc_scale");//Royalty to SST without Tax (contra-revenue)(MRC in RMB) + ArrayList list = new ArrayList<>(); + list.add(site);//list.add(site); + list.add(item); + list.add(category); + list.add(otc_price); + list.add(mrc_price); + list.add(otcdiscountrequest); + list.add(mrcdiscountrequest); + list.add(otcdiscountapproved); + list.add(mrcdiscountapproved); + list.add(otc_tariff); + list.add(mrc_tariff); + list.add(otc_scale); + list.add(mrc_scale); + detailDateList.add(list); + } + } + Double amount9 = 0D;//用来统计每一个site种类的 Grand-Total(RMB) + Double amount10 = 0D; + Double amount11 = 0D; + Double amount12 = 0D; + //得到list类型的数据、有得到每种site类型的数据长度 + //开始向excel中导入明细表中的数据 + int i = 0;//用它来增加detailDateList的下标 + for (int cowNum = firstCow; cowNum < firstCow + cowLength; cowNum++) { + Row row = sheet.createRow(cowNum); + for (int colNum = 0; colNum < 13; colNum++) { + if (colNum == 9) { + String s = String.valueOf(detailDateList.get(i).get(colNum)); + if (s!=""){ + Double value = Double.valueOf(s); + amount9 = Double.valueOf(amount9) + value; + sum9 += value; + Cell cell = row.createCell(colNum); + cell.setCellType(CellType.NUMERIC); + cell.setCellStyle(setCellToNumber(workbook)); + cell.setCellValue(value); + }else{ + Cell cell = row.createCell(colNum); + cell.setCellStyle(setNolyBorderStyle(workbook)); + } + } else if (colNum == 10) { + String s = String.valueOf(detailDateList.get(i).get(colNum)); + if (s!=""){ + Double value = Double.valueOf(s); + amount10 = amount10 + value; + sum10 += value; + + Cell cell = row.createCell(colNum); + cell.setCellType(CellType.NUMERIC); + cell.setCellStyle(setCellToNumber(workbook)); + cell.setCellValue(value); + }else { + Cell cell = row.createCell(colNum); + cell.setCellType(CellType.NUMERIC); + cell.setCellStyle(setCellToNumber(workbook)); + } + } else if (colNum == 11) { + String s = String.valueOf(detailDateList.get(i).get(colNum)); + if (s!=""){ + Double value = Double.valueOf(s); + amount11 = amount11 + value; + sum11 += value; + + Cell cell = row.createCell(colNum); + cell.setCellType(CellType.NUMERIC); + cell.setCellStyle(setCellToNumber(workbook)); + cell.setCellValue(value); + }else { + Cell cell = row.createCell(colNum); + cell.setCellStyle(setNolyBorderStyle(workbook)); + } + } else if (colNum == 12) { + String s = String.valueOf(detailDateList.get(i).get(colNum)); + if (s!=""){ + Double value = Double.valueOf(s); + amount12 = amount12 + value; + sum12 += value; + Cell cell = row.createCell(colNum); + cell.setCellType(CellType.NUMERIC); + cell.setCellStyle(setCellToNumber(workbook)); + cell.setCellValue(value); + }else { + Cell cell = row.createCell(colNum); + cell.setCellStyle(setNolyBorderStyle(workbook)); + } + } + + if (colNum == 5 || colNum == 6 || colNum == 7 || colNum == 8) { + Cell cell = row.createCell(colNum); + String s = String.valueOf(detailDateList.get(i).get(colNum)); + if (s!=""){ + Double value = Double.valueOf(s); + cell.setCellStyle(setWordStyle(workbook)); + cell.setCellValue( (int)(value*100) + "%"); + }else { + cell.setCellStyle(setNolyBorderStyle(workbook)); + } + } + else if (colNum == 0||colNum==1||colNum==2){ + Cell cell = row.createCell(colNum); + String value = String.valueOf(detailDateList.get(i).get(colNum)); + if (value!=""){ + cell.setCellStyle(setWordStyle(workbook)); + cell.setCellValue(value); + }else { + cell.setCellStyle(setNolyBorderStyle(workbook)); + } + + }else if (colNum == 3||colNum==4){ + String s = String.valueOf(detailDateList.get(i).get(colNum)); + if (s!=""){ + Double value = Double.valueOf(s); + Cell cell = row.createCell(colNum); + cell.setCellType(CellType.NUMERIC); + cell.setCellStyle(setCellToNumber(workbook)); + cell.setCellValue(value); + }else { + Cell cell = row.createCell(colNum); + cell.setCellStyle(setNolyBorderStyle(workbook)); + } + } + } + i++; + } + //合并单元格 + int lastCow = firstCow + cowLength; + + if (cowLength > 1) { + sheet.addMergedRegion(new CellRangeAddress(firstCow, lastCow - 1, 0, 0)); + } + //开始写入Sub-Total(RMB) + Row rowSubTotal = sheet.createRow(lastCow); + for (int colNum = 8; colNum < 13; colNum++) { + if (colNum == 8) { + Cell cellSubToTal = rowSubTotal.createCell(colNum); + cellSubToTal.setCellStyle(setNolyWordStyle(workbook, true)); + cellSubToTal.setCellValue("Sub-Total(RMB)"); + } else if (colNum == 9) { + Cell cellSubToTal = rowSubTotal.createCell(colNum); + cellSubToTal.setCellStyle(setNolyWordStyle(workbook, true)); + cellSubToTal.setCellValue(amount9); + } else if (colNum == 10) { + Cell cellSubToTal = rowSubTotal.createCell(colNum); + cellSubToTal.setCellStyle(setNolyWordStyle(workbook, true)); + cellSubToTal.setCellValue(amount10); + } else if (colNum == 11) { + Cell cellSubToTal = rowSubTotal.createCell(colNum); + cellSubToTal.setCellStyle(setNolyWordStyle(workbook, true)); + cellSubToTal.setCellValue(amount11); + } else if (colNum == 12) { + Cell cellSubToTal = rowSubTotal.createCell(colNum); + cellSubToTal.setCellStyle(setNolyWordStyle(workbook, true)); + cellSubToTal.setCellValue(amount12); + } + } + + firstCow = firstCow + cowLength + 1; + finalyCow = firstCow; + }//处理插入数据以及合并单元格 + //处理明细表最后一行的统计情况 + Row row_Grand_Total_RMB = sheet.createRow(finalyCow); + for (int colNum = 8; colNum < 13; colNum++) { + if (colNum == 8) { + Cell cell = row_Grand_Total_RMB.createCell(colNum); + cell.setCellStyle(setNolyWordStyle(workbook,true)); + cell.setCellValue("Grand-Total(RMB)"); + } else if (colNum == 9) { + Cell cell = row_Grand_Total_RMB.createCell(colNum); + cell.setCellStyle(setNolyWordStyle(workbook,true)); + cell.setCellValue(sum9); + } else if (colNum == 10) { + Cell cell = row_Grand_Total_RMB.createCell(colNum); + cell.setCellStyle(setNolyWordStyle(workbook,true)); + cell.setCellValue(sum10); + } else if (colNum == 11) { + Cell cell = row_Grand_Total_RMB.createCell(colNum); + cell.setCellStyle(setNolyWordStyle(workbook,true)); + cell.setCellValue(sum11); + } else if (colNum == 12) { + Cell cell = row_Grand_Total_RMB.createCell(colNum); + cell.setCellStyle(setNolyWordStyle(workbook,true)); + cell.setCellValue(sum12); + } + } + + //输入最下面的固定值 + String[] lastStringLeft = new String[]{ + "Notes:", + "1.This is NOT AT&T Pricing Approval. Forward this SST quote to your Lead ICB Pricer to issue the official Rate Letter", + "2.Access price must be quoted by SST, request SST as \"access provider\" in Igloo. Do NOT use quote from other access providers", + "3.Discount is only applicable to the demand set listed below, any changes in bandwidth/design/billing model, need to re-submit to SST and AT&T Pricer for approval", "" + + "4.Under in-country billing, AT&T must follow the discount% offered by SST. Do NOT deviate from the SST quoted discount.", + "5.SST can support repeatable discount for the same solution design(port/CDR/CPE) of same contract term which was approved already. Local Loop part are non-repeatable.", + "6.For ICB only - Royalty in columns L and M are contra-revenue,ICB to verify if BCRL captured these amount.", + "7.Save this SST approved quote to eCRM (without release) for record.", + "8.The quotation shall be exclusive of any applicable taxes and Customer shall pay all the taxes and charges relating to the payment if any. The VAT rate for CPE and related modules and license are 16%, the rest is 6%.", + "9.Thank you for considering SST, this engagement may be subject to a credit check, we appreciate your cooperation and look forward to doing business in the near future." + }; + int lastLineTag = finalyCow + 2;//固定值Note所在的行 + int k = 0;//用来增加lastStringLeft的下标 + for (int rowNum = lastLineTag; rowNum < lastLineTag + 10; rowNum++) { + Row row = sheet.createRow(rowNum); + Cell cell = row.createCell(0); + cell.setCellStyle(setNolyWordStyle(workbook,true)); + sheet.addMergedRegion(new CellRangeAddress(rowNum, rowNum, 0, 11)); + cell.setCellStyle(setTotalStyle(workbook,"微软雅黑",true,false,HorizontalAlignment.LEFT, VerticalAlignment.CENTER,false)); + cell.setCellValue(lastStringLeft[k]); + k++; + } + sheet.autoSizeColumn(0,true); + sheet.setColumnWidth(0,sheet.getColumnWidth(0)*5/10); + // 设置自动列宽 + for (int num = 1; num < 13; num++) { + sheet.autoSizeColumn(num,true); + sheet.setColumnWidth(num, (sheet.getColumnWidth(num))); + } + + + InputStream inputStream = workbookConvertorStream(workbook); + byte[] bytes = IOUtils.toByteArray(inputStream); + output = outputStream -> { + outputStream.write(bytes); + outputStream.close(); + }; + + header = Response.ok(output,MediaType.APPLICATION_OCTET_STREAM) + .type("application/xlsx") + .header("Content-Disposition", + "attachment; filename=\""+ new String("AVPN表单.xlsx".getBytes("GBK"), StandardCharsets.ISO_8859_1)+"\""); + + } catch (Exception e) { + e.printStackTrace(); + logger.error("导出excel错误:" + Util.getErrString(e)); + } + build = header.build(); + return build; + } + /** + *

设置每个单元格样式:包含字体类型,字体是否加粗,是否包含边框,元素水平方向的位置,元素垂直方向的位置,是否设置元素的数据格式,

+ * @param + * @return + * @author hcy + * @Date 2023/2/13 18:08 + */ + public static CellStyle setTotalStyle(Workbook workbook,String type,boolean setBold,boolean setBorder,HorizontalAlignment horizontalDirection,VerticalAlignment verticalAlignmentDirection ,boolean setDataFormat){ + //new一个cellStyle用于设置每一个单元格样式 + CellStyle cellStyle = workbook.createCellStyle(); + Font font = workbook.createFont(); + //颜色 + font.setColor(Font.COLOR_NORMAL); + //设置字体大小 + font.setFontHeightInPoints((short) 10); + //字体 + font.setFontName(type); + //设置字体是否加粗 + font.setBold(setBold); + //将字体样式渲染cellStyle对象中 + cellStyle.setFont(font); + if (setBorder == true){ + //设置样式对象,这里仅设置了边框属性 + cellStyle.setBorderBottom(BorderStyle.THIN); //下边框 + cellStyle.setBorderLeft(BorderStyle.THIN);//左边框 + cellStyle.setBorderTop(BorderStyle.THIN);//上边框 + cellStyle.setBorderRight(BorderStyle.THIN);//右边框 + } + + //水平居中 + cellStyle.setAlignment(horizontalDirection); + //垂直居中 + cellStyle.setVerticalAlignment(verticalAlignmentDirection); + + //此处设置数据格式 + if(setDataFormat == true){ + DataFormat dataFormat = workbook.createDataFormat(); + cellStyle.setDataFormat(dataFormat.getFormat("0.00_ ")); + } + + return cellStyle; + } + /** + * 设置每个单元格的样式,并且加粗字体,设置边框 + * + * @param workbook + * @return + */ + public static CellStyle setWordStyle(Workbook workbook, Boolean setBold) { + // 设置字体 + CellStyle cellStyle = workbook.createCellStyle(); + + //设置样式对象,这里仅设置了边框属性 + + cellStyle.setBorderBottom(BorderStyle.THIN); //下边框 + + cellStyle.setBorderLeft(BorderStyle.THIN);//左边框 + + cellStyle.setBorderTop(BorderStyle.THIN);//上边框 + + cellStyle.setBorderRight(BorderStyle.THIN);//右边框 + + Font font = workbook.createFont(); + //颜色 + font.setColor(Font.COLOR_NORMAL); + //设置字体大小 + font.setFontHeightInPoints((short) 10); + //字体 + font.setFontName("微软雅黑"); + font.setBold(setBold); + cellStyle.setFont(font); + + return cellStyle; + } + + /** + * 只设置字体样式 + * + * @param workbook + * @return + */ + public static CellStyle setWordStyle(Workbook workbook) { + // 设置字体 + CellStyle cellStyle = workbook.createCellStyle(); + //设置样式对象,这里仅设置了边框属性 + cellStyle.setBorderBottom(BorderStyle.THIN); //下边框 + + cellStyle.setBorderLeft(BorderStyle.THIN);//左边框 + + cellStyle.setBorderTop(BorderStyle.THIN);//上边框 + + cellStyle.setBorderRight(BorderStyle.THIN);//右边框 + Font font = workbook.createFont(); + //颜色 + font.setColor(Font.COLOR_NORMAL); + //设置字体大小 + font.setFontHeightInPoints((short) 10); + //字体 + font.setFontName("微软雅黑"); + cellStyle.setFont(font); + return cellStyle; + } + + + /** + * 只设置边框样式 + * + * @param workbook + * @return + */ + public static CellStyle setNolyBorderStyle(Workbook workbook) { + // 设置字体 + CellStyle cellStyle = workbook.createCellStyle(); + //设置样式对象,这里仅设置了边框属性 + cellStyle.setBorderBottom(BorderStyle.THIN); //下边框 + + cellStyle.setBorderLeft(BorderStyle.THIN);//左边框 + + cellStyle.setBorderTop(BorderStyle.THIN);//上边框 + + cellStyle.setBorderRight(BorderStyle.THIN);//右边框 + + return cellStyle; + } + + /** + * 只设置字体样式 + * + * @param workbook + * @return + */ + public static CellStyle setNolyWordStyle(Workbook workbook,Boolean setBold) { + // 设置字体 + CellStyle cellStyle = workbook.createCellStyle(); + Font font = workbook.createFont(); + //颜色 + font.setColor(Font.COLOR_NORMAL); + //设置字体大小 + font.setFontHeightInPoints((short) 10); + //字体 + font.setFontName("微软雅黑"); + font.setBold(setBold); + cellStyle.setFont(font); + DataFormat dataFormat = workbook.createDataFormat();//此处设置数据格式 + cellStyle.setDataFormat(dataFormat.getFormat("0.00_ ")); + return cellStyle; + } + + /** + * SXSSFWorkbook 转 InputStream + * @param workbook + * @return + */ + public static InputStream workbookConvertorStream(Workbook workbook) { + InputStream in = null; + try{ + //临时缓冲区 + ByteArrayOutputStream out = new ByteArrayOutputStream(); + //创建临时文件 + workbook.write(out); + byte [] bookByteAry = out.toByteArray(); + in = new ByteArrayInputStream(bookByteAry); + } + catch (Exception e){ + e.printStackTrace(); + } + return in; + } + + + /** + * 设置单元格格式为数值型 + * @param workbook + * @return + */ + public static CellStyle setCellToNumber(Workbook workbook){ + // 设置字体 + CellStyle cellStyle = workbook.createCellStyle(); + //设置样式对象,这里仅设置了边框属性 + cellStyle.setBorderBottom(BorderStyle.THIN); //下边框 + + cellStyle.setBorderLeft(BorderStyle.THIN);//左边框 + + cellStyle.setBorderTop(BorderStyle.THIN);//上边框 + + cellStyle.setBorderRight(BorderStyle.THIN);//右边框 + Font font = workbook.createFont(); + //颜色 + font.setColor(Font.COLOR_NORMAL); + //设置字体大小 + font.setFontHeightInPoints((short) 10); + //字体 + font.setFontName("微软雅黑"); + cellStyle.setFont(font); + DataFormat dataFormat = workbook.createDataFormat();//此处设置数据格式 + cellStyle.setDataFormat(dataFormat.getFormat("0.00_ ")); + return cellStyle; + } + + + + +} diff --git a/src/main/java/com/api/chaoyang/he/hcy_xintiantongxin/ExportExcelL3NSApi.java b/src/main/java/com/api/chaoyang/he/hcy_xintiantongxin/ExportExcelL3NSApi.java new file mode 100644 index 0000000..8dec253 --- /dev/null +++ b/src/main/java/com/api/chaoyang/he/hcy_xintiantongxin/ExportExcelL3NSApi.java @@ -0,0 +1,581 @@ +package com.api.chaoyang.he.hcy_xintiantongxin; + +import aiyh.utils.Util; +import org.apache.commons.io.IOUtils; +import org.apache.log4j.Logger; +import org.apache.poi.ss.usermodel.*; +import org.apache.poi.ss.util.CellRangeAddress; +import org.apache.poi.xssf.usermodel.XSSFWorkbook; +import weaver.conn.RecordSet; + +import javax.servlet.http.HttpServletRequest; +import javax.servlet.http.HttpServletResponse; +import javax.ws.rs.GET; +import javax.ws.rs.Path; +import javax.ws.rs.Produces; +import javax.ws.rs.core.Context; +import javax.ws.rs.core.MediaType; +import javax.ws.rs.core.Response; +import javax.ws.rs.core.StreamingOutput; +import java.io.ByteArrayInputStream; +import java.io.ByteArrayOutputStream; +import java.io.IOException; +import java.io.InputStream; +import java.nio.charset.StandardCharsets; +import java.util.*; + +@Path("/hcy_xintiantongxin2") +public class ExportExcelL3NSApi { + + + + private Logger logger = Util.getLogger(); + + /** + * 校验 + * @param request + * @param response + * @return + */ + @GET + @Path("/ExportExcelL3NSApi") + @Produces(MediaType.APPLICATION_OCTET_STREAM) + public Response checkRequestInfo(@Context HttpServletRequest request, @Context HttpServletResponse response){ + Response build = null; + Response.ResponseBuilder header = null; + try { + + + //查询到 uf_L3NS_exportt AVPN导出表中的一条数据的ids + String ids = request.getParameter("ids"); + RecordSet rs = new RecordSet(); + StreamingOutput output = null; + + + String sql_L3NS_db = "select * from uf_L3NS_exportt where id = ?"; + boolean b = rs.executeQuery(sql_L3NS_db, ids); + logger.info("是否查询uf_L3NS_exportt=="+b); + + //创建一个工作簿 + XSSFWorkbook workbook = new XSSFWorkbook(); + String[] dbFiled = new String[13]; + String[] tableFiled = new String[]{"Service Type", "Billing Model", "Customer Name", "ROME Opportunity #", "ROME WR#", "Request Type", "Original SST Order NO", "Request Justification", "Special Request to SST", "Target Service Provision date","ATT Order number:","SST Pre-Sales Contact","Date of SST Approval"}; + + String mainId = ""; + + //得到主表数据,用来写入excel中的固定值 + while (rs.next()) { + //查询到uf_avpn_export表的id作为查询明细表的mainid + mainId = rs.getString("id"); + + + String pd_nameId = rs.getString("pd_name");//uf_pd_base_inf 得到的pd_name是字段的id + RecordSet recordSet = new RecordSet(); + String getPd_nameByIdSql = "select pd_name from uf_pd_base_inf where id =?"; + boolean b1 = recordSet.executeQuery(getPd_nameByIdSql, pd_nameId); + + logger.info("查询pd_namesql语句是否成功==" + b1); + if (recordSet.next()) { + String pd_name = recordSet.getString("pd_name");//查询到pd_name的值 + dbFiled[0] = pd_name; + } + String billingmodel = rs.getString("billingmodel");//Billing Model===billingmodel + if (billingmodel.equals("0")){ + billingmodel = "Custom Subcontract"; + }else if (billingmodel == null){ + billingmodel = ""; + } + dbFiled[1] = billingmodel; + String customer_name = rs.getString("customer_name");//Customer Name===customer_name + dbFiled[2] = customer_name; + String rome_opportunity = rs.getString("rome_opportunity");//ROME Opportunity #====rome_opportunity + dbFiled[3] = rome_opportunity; + String rome_wr = rs.getString("rome_wr");//ROME WR#====rome_wr + dbFiled[4] = rome_wr; + String request_type = rs.getString("request_type");//Request Type====request_type + dbFiled[5] = request_type; + String original_sst_order_no = rs.getString("original_sst_order_no");//Original SST Order NO====original_sst_order_no + dbFiled[6] = original_sst_order_no; + String requestjustificationoptional = rs.getString("requestjustificationoptional");//Request Justification====requestjustificationoptional + dbFiled[7] = requestjustificationoptional; + String specialrequesttosstoptional = rs.getString("specialrequesttosstoptional");//Special Request to SST====specialrequesttosstoptional + dbFiled[8] = specialrequesttosstoptional; + String targetserviceprovisiondate = rs.getString("targetserviceprovisiondate");//Target Service Provision date====targetserviceprovisiondate + dbFiled[9] = targetserviceprovisiondate; + String attordernumber = rs.getString("attordernumber");//ATT Order number:====attordernumber + dbFiled[10] = attordernumber; + String sstpresalescontact = rs.getString("sstpresalescontact");//SST Pre-Sales Contact====sstpresalescontact + dbFiled[11] = sstpresalescontact; + String dateofsstapproval = rs.getString("dateofsstapproval");//Date of SST Approval====dateofsstapproval + dbFiled[12] = dateofsstapproval; + } + + //开始写入固定值 + Sheet sheet = workbook.createSheet(); + workbook.setSheetName(0, "L3NS表单"); + sheet.autoSizeColumn(1, true); + + for (int cowNum=1;cowNum<14;cowNum++){ + Row row = sheet.createRow(cowNum); + Cell cell0 = row.createCell(0); + cell0.setCellStyle(setWordStyle(workbook,true)); + cell0.setCellValue(tableFiled[cowNum-1]); + Cell cell1 = row.createCell(1); + cell1.setCellStyle(setWordStyle(workbook,true)); + cell1.setCellValue(dbFiled[cowNum-1]); + } + + Row row14 = sheet.createRow(14);//写入15行数据 + Cell cell14_0 = row14.createCell(0); + Cell cell114_1 = row14.createCell(1); + cell14_0.setCellStyle(setWordStyle(workbook,true)); + cell14_0.setCellValue("This Quote is valid for 180 days from \"Date of SST approval\""); + cell114_1.setCellStyle(setWordStyle(workbook,true)); + cell114_1.setCellValue("This Quote is valid for 180 days from \"Date of SST approval\""); + sheet.addMergedRegion(new CellRangeAddress(14, 14, 0, 1)); + + +// 写入18行,19行数据 +// Site ID Description Bandwidth OTC in RMB MRC in RMB + String[] detailFileds = new String[]{"Site ID", "Description","Bandwidth", "OTC in RMB", "MRC in RMB"}; + Row row17 = sheet.createRow(17); + Row row18 = sheet.createRow(18); + for (int colNum =0;colNum<5;colNum++){ + Cell cell = row17.createCell(colNum); + cell.setCellStyle(setWordStyle(workbook)); + cell.setCellStyle(setWordStyle(workbook,true)); + cell.setCellValue(detailFileds[colNum]); + } + for (int colNum =0;colNum<5;colNum++){ + Cell cell = row18.createCell(colNum); + cell.setCellStyle(setWordStyle(workbook)); + cell.setCellStyle(setWordStyle(workbook,true)); + cell.setCellValue(detailFileds[colNum]); + } + sheet.addMergedRegion(new CellRangeAddress(17, 18, 0, 0)); + sheet.addMergedRegion(new CellRangeAddress(17, 18, 1, 1)); + sheet.addMergedRegion(new CellRangeAddress(17, 18, 2, 2)); + sheet.addMergedRegion(new CellRangeAddress(17, 18, 3, 3)); + sheet.addMergedRegion(new CellRangeAddress(17, 18, 4, 4)); + +// Relief Requested (%) Relief SST approved (%) Tariff to SST (include VAT) 6-11列 +// OTC MRC OTC MRC OTC in RMB MRC in RMB + String[] detailFileds01 = new String[]{"Relief Requested (%)","Relief Requested (%)","Relief SST approved (%)","Relief SST approved (%)","Tariff to SST (include VAT)","Tariff to SST (include VAT)",""}; + String[] detailFileds02 = new String[]{"OTC","MRC","OTC","MRC","OTC in RMB","MRC in RMB"}; + int i=0; + int j = 0; + for(int colNum=5;colNum<11;colNum++){ + Cell cell17 = row17.createCell(colNum); + Cell cell18 = row18.createCell(colNum); + cell17.setCellValue(detailFileds01[i]); + cell17.setCellStyle(setWordStyle(workbook,true)); +// cell17.setCellStyle(setCellStyleFrame(workbook)); + + cell18.setCellValue(detailFileds02[j]); + cell18.setCellStyle(setWordStyle(workbook,true)); +// cell18.setCellStyle(setCellStyleFrame(workbook)); + i++; + j++; + } + //合并18行,19行 + sheet.addMergedRegion(new CellRangeAddress(17, 17, 5, 6)); + sheet.addMergedRegion(new CellRangeAddress(17, 17, 7, 8)); + sheet.addMergedRegion(new CellRangeAddress(17, 17, 9, 10)); + + + //开始写入20开始一直往下的动态表格中的内容 +// + + List> siteMap = new ArrayList<>();//用来存放site的类型和每个site的状态 + String getSiteSql = "select site ,count(site) siteNum from uf_L3NS_exportt_dt1 where mainId =? group by site ;"; + RecordSet rs02 = new RecordSet(); + boolean b1 = rs02.executeQuery(getSiteSql, mainId); + logger.info("查询site,以及site的数量的sql语句===" + b1); + while (rs02.next()) { + HashMap map = new HashMap<>(); + String site = rs02.getString("site"); + String siteNum = rs02.getString("siteNum"); + map.put(site, siteNum); + siteMap.add(map);//将site的类型和每个site的类型的个数放到siteList数组中,用来循环遍历再放入单元格中 + } + + int firstCow = 19;//从第15行开始写入明细表,固定死 + int finalyCow = 0; + Double sum10 = 0D;//用来统计所有site种类的Grand-Total (RMB) #REF! + Double sum9 = 0D; + for (Map map : siteMap) { + + Set siteKeySet = map.keySet(); + List> detailDateList = new ArrayList(); + int cowLength = 0;//每一个site类型的数据的长度 + for (String s1 : siteKeySet) { + cowLength = Integer.parseInt(map.get(s1));//每一个site类型的数据的长度 + String getDetailDataSql = "select * from uf_L3NS_exportt_dt1 where mainId =? and site = ?"; + rs02.executeQuery(getDetailDataSql,mainId,s1); + while(rs02.next()){ + //明细表数据 + String site = rs02.getString("site");//Site ID + String itemId = rs02.getString("Item");//Description + String getItemValueSql = "select item from uf_pd_item_inf where id =?";//uf_pd_item_inf + RecordSet recordSet1 = new RecordSet(); + boolean b2 = recordSet1.executeQuery(getItemValueSql, itemId); + logger.info("查询item值sql是否执行成功=" + b2); + String item = "";//从数据库中查询到item的值 + if (recordSet1.next()) { + item = recordSet1.getString("Item"); + } + String categoryId = rs02.getString("Category");//Bandwidth + String getCategoryByIdSql = "select category from uf_pd_category_inf where id = ?";//uf_pd_category_inf + boolean b3 = recordSet1.executeQuery(getCategoryByIdSql, categoryId); + logger.info("查询categorySql是否执行成功==" + b3); + String category = ""; + if (recordSet1.next()) { + category = recordSet1.getString("category"); + } + String otc_price = rs02.getString("otc_price");//OTC in RMB + String mrc_price = rs02.getString("mrc_price");//MRC in RMB + String otc_relief_requested = rs02.getString("otc_relief_requested");//Relief Requested (%)OTC + String mrc_relief_requested = rs02.getString("mrc_relief_requested");//Relief Requested (%)MRC + String otc_relief_approved = rs02.getString("otc_relief_approved");//Relief SST approved (%)OTC + String mrc_relief_approved = rs02.getString("mrc_relief_approved");//Relief SST approved (%)MRC + String otc_tariff = rs02.getString("otc_tariff");//Tariff to SST (include VAT)(OTC in RMB) + String mrc_tariff = rs02.getString("mrc_tariff");//Tariff to SST (include VAT)(MRC in RMB) + + ArrayList list = new ArrayList<>(); + list.add(site); + list.add(item); + list.add(category); + list.add(otc_price); + list.add(mrc_price); + list.add(otc_relief_requested); + list.add(mrc_relief_requested); + list.add(otc_relief_approved); + list.add(mrc_relief_approved); + list.add(otc_tariff); + list.add(mrc_tariff); + detailDateList.add(list); + } + } + Double amount10 = 0D;//用来统计每一个site种类的 Sub-Total + Double amount9 = 0D; + + //得到list类型的数据、有得到每种site类型的数据长度 + //开始向excel中导入明细表中的数据 + int k = 0;//用它来增加detailDateList的下标 + for (int cowNum = firstCow; cowNum < firstCow + cowLength; cowNum++) { + Row row = sheet.createRow(cowNum); + for (int colNum = 0; colNum < 11; colNum++) { + if (colNum == 10) { + String s = String.valueOf(detailDateList.get(k).get(colNum)); + if (s != ""){ + Double value = Double.valueOf(s); + amount10 = amount10 + value; + sum10 += value; + Cell cell = row.createCell(colNum); + cell.setCellStyle(setCellToNumber(workbook)); + cell.setCellValue(value); + }else { + Cell cell = row.createCell(colNum); + cell.setCellStyle(setNolyBorderStyle(workbook)); + } + }else if (colNum == 9){ + String s = String.valueOf(detailDateList.get(k).get(colNum)); + if (s != "") { + Double value = Double.valueOf(s); + amount9 = amount9 + value; + sum9 += value; + Cell cell = row.createCell(colNum); + cell.setCellStyle(setCellToNumber(workbook)); + cell.setCellValue(value); + }else { + Cell cell = row.createCell(colNum); + cell.setCellStyle(setNolyBorderStyle(workbook)); + } + } + if (colNum == 5 || colNum == 6 || colNum == 7 || colNum == 8) { + Cell cell = row.createCell(colNum); + String s = String.valueOf(detailDateList.get(k).get(colNum)); + if (s!=""){ + Double value = Double.valueOf(s); + cell.setCellStyle(setWordStyle(workbook)); + cell.setCellValue((int)(value * 100) + "%"); + }else { + cell.setCellStyle(setNolyBorderStyle(workbook)); + } + } else if (colNum == 3 || colNum==4){ + String s = String.valueOf(detailDateList.get(k).get(colNum)); + if (s != ""){ + Double value = Double.valueOf(s); + Cell cell = row.createCell(colNum); + cell.setCellStyle(setCellToNumber(workbook)); + cell.setCellValue(value); + }else { + Cell cell = row.createCell(colNum); + cell.setCellStyle(setNolyBorderStyle(workbook)); + } + } + else if (colNum == 0||colNum==1||colNum==2){ + Cell cell = row.createCell(colNum); + String value = String.valueOf(detailDateList.get(k).get(colNum)); + if (value!=""){ + cell.setCellStyle(setWordStyle(workbook)); + cell.setCellValue(value); + }else { + cell.setCellStyle(setNolyBorderStyle(workbook)); + } + + } + } + k++; + } + //合并单元格 + int lastCow = firstCow + cowLength; + + if (cowLength > 1) { + sheet.addMergedRegion(new CellRangeAddress(firstCow, lastCow - 1, 0, 0)); + } + //开始写入Sub-Total(RMB) + Row rowSubTotal = sheet.createRow(lastCow); + Cell cellSubToTal10 = rowSubTotal.createCell(10); + cellSubToTal10.setCellStyle(setNolyWordStyle(workbook,true)); + cellSubToTal10.setCellValue(amount10); + + Cell cellSubToTal9 = rowSubTotal.createCell(9); + cellSubToTal9.setCellStyle(setNolyWordStyle(workbook,true)); + cellSubToTal9.setCellValue(amount9); + + Cell cellSubToTal8 = rowSubTotal.createCell(8); + cellSubToTal8.setCellStyle(setNolyWordStyle(workbook,true)); + cellSubToTal8.setCellValue("Sub-Total"); + + + firstCow = firstCow + cowLength + 1; + finalyCow = firstCow; + + } + Row rowFinalyCow = sheet.createRow(finalyCow); + Cell cellFinalyCow_10 = rowFinalyCow.createCell(10); + cellFinalyCow_10.setCellStyle(setNolyWordStyle(workbook,true)); + cellFinalyCow_10.setCellValue(sum10); + Cell cellFinalyCow_9 = rowFinalyCow.createCell(9); + cellFinalyCow_9.setCellStyle(setNolyWordStyle(workbook,true)); + cellFinalyCow_9.setCellValue(sum9); + Cell cellFinalyCow_8 = rowFinalyCow.createCell(8); + cellFinalyCow_8.setCellStyle(setNolyWordStyle(workbook,true)); + cellFinalyCow_8.setCellValue("Grand-Total (RMB)"); + + + //输入最下面的固定值 + String[] lastStringright = new String[]{ + "Notes:", + "1.This form should be submitted by Lead ICB via a ROME WR to \"AP Pricing Team\". Do NOT send this direct to SST.", + "2.Fill in full Site Address or at least provide Name of City.", + "3.Tariff relief requested should be calculated by lead ICB. Do not fill in target AVPN discount as \"Relief Requested\".", + "4.VPN Tariff is port base pricing, no charges on COS or COS profile.", + "5.AT&T GAM will place order to SST on no longer than 12 months term for Custom Subcontract, regardless of the commitment term between end customer and AT&T.", + "6.China VAT is irrecoverable cost to AT&T under custom subcontracting billing. Ttariff and Access price listed below is VAT inclusive. ICB has to cater for this cost in deal financials.", + "7.Tariff Relief is only applicable to the demand set listed below, any changes in bandwidth/design/billing model, need to re-submit to SST for approval;", + }; + int lastLineTag = finalyCow + 2;//固定值Note所在的行 + int h=0; + for (int rowNum=lastLineTag;rowNum { + outputStream.write(bytes); + outputStream.close(); + }; + + header = Response.ok(output,MediaType.APPLICATION_OCTET_STREAM) + .type("application/xlsx") + .header("Content-Disposition", + "attachment; filename=\""+ new String("L3NS表单.xlsx".getBytes("GBK"), StandardCharsets.ISO_8859_1)+"\""); + } catch (IOException e) { + logger.error("导出excel错误:" + Util.getErrString(e)); + e.printStackTrace(); + } + + + + + + build = header.build(); + return build; + } + + + + + /** + * 设置每个单元格的样式,并且加粗字体,设置边框 + * + * @param workbook + * @return + */ + public static CellStyle setWordStyle(Workbook workbook, Boolean setBold) { + // 设置字体 + CellStyle cellStyle = workbook.createCellStyle(); + + //设置样式对象,这里仅设置了边框属性 + + cellStyle.setBorderBottom(BorderStyle.THIN); //下边框 + + cellStyle.setBorderLeft(BorderStyle.THIN);//左边框 + + cellStyle.setBorderTop(BorderStyle.THIN);//上边框 + + cellStyle.setBorderRight(BorderStyle.THIN);//右边框 + + Font font = workbook.createFont(); + //颜色 + font.setColor(Font.COLOR_NORMAL); + //设置字体大小 + font.setFontHeightInPoints((short) 10); + //字体 + font.setFontName("微软雅黑"); + font.setBold(setBold); + cellStyle.setFont(font); + + return cellStyle; + } + + /** + * 只设置字体样式 + * + * @param workbook + * @return + */ + public static CellStyle setWordStyle(Workbook workbook) { + // 设置字体 + CellStyle cellStyle = workbook.createCellStyle(); + //设置样式对象,这里仅设置了边框属性 + cellStyle.setBorderBottom(BorderStyle.THIN); //下边框 + + cellStyle.setBorderLeft(BorderStyle.THIN);//左边框 + + cellStyle.setBorderTop(BorderStyle.THIN);//上边框 + + cellStyle.setBorderRight(BorderStyle.THIN);//右边框 + Font font = workbook.createFont(); + //颜色 + font.setColor(Font.COLOR_NORMAL); + //设置字体大小 + font.setFontHeightInPoints((short) 10); + //字体 + font.setFontName("微软雅黑"); + cellStyle.setFont(font); + return cellStyle; + } + + + /** + * 只设置字体样式 + * + * @param workbook + * @return + */ + public static CellStyle setNolyWordStyle(Workbook workbook,Boolean setBold) { + // 设置字体 + CellStyle cellStyle = workbook.createCellStyle(); + Font font = workbook.createFont(); + //颜色 + font.setColor(Font.COLOR_NORMAL); + //设置字体大小 + font.setFontHeightInPoints((short) 10); + //字体 + font.setFontName("微软雅黑"); + font.setBold(setBold); + cellStyle.setFont(font); + DataFormat dataFormat = workbook.createDataFormat();//此处设置数据格式 + cellStyle.setDataFormat(dataFormat.getFormat("0.00_ ")); + return cellStyle; + } + + /** + * 只设置字体样式 + * + * @param workbook + * @return + */ + public static CellStyle setNolyBorderStyle(Workbook workbook) { + // 设置字体 + CellStyle cellStyle = workbook.createCellStyle(); + //设置样式对象,这里仅设置了边框属性 + cellStyle.setBorderBottom(BorderStyle.THIN); //下边框 + + cellStyle.setBorderLeft(BorderStyle.THIN);//左边框 + + cellStyle.setBorderTop(BorderStyle.THIN);//上边框 + + cellStyle.setBorderRight(BorderStyle.THIN);//右边框 + + return cellStyle; + } + + + + /** + * SXSSFWorkbook 转 InputStream + * @param workbook + * @return + */ + public static InputStream workbookConvertorStream(Workbook workbook) { + InputStream in = null; + try{ + //临时缓冲区 + ByteArrayOutputStream out = new ByteArrayOutputStream(); + //创建临时文件 + workbook.write(out); + byte [] bookByteAry = out.toByteArray(); + in = new ByteArrayInputStream(bookByteAry); + } + catch (Exception e){ + e.printStackTrace(); + } + return in; + } + + /** + * 设置单元格格式为数值型 + * @param workbook + * @return + */ + public static CellStyle setCellToNumber(Workbook workbook){ + // 设置字体 + CellStyle cellStyle = workbook.createCellStyle(); + //设置样式对象,这里仅设置了边框属性 + cellStyle.setBorderBottom(BorderStyle.THIN); //下边框 + + cellStyle.setBorderLeft(BorderStyle.THIN);//左边框 + + cellStyle.setBorderTop(BorderStyle.THIN);//上边框 + + cellStyle.setBorderRight(BorderStyle.THIN);//右边框 + Font font = workbook.createFont(); + //颜色 + font.setColor(Font.COLOR_NORMAL); + //设置字体大小 + font.setFontHeightInPoints((short) 10); + //字体 + font.setFontName("微软雅黑"); + cellStyle.setFont(font); + DataFormat dataFormat = workbook.createDataFormat();//此处设置数据格式 + cellStyle.setDataFormat(dataFormat.getFormat("0.00_ ")); + return cellStyle; + } + +} diff --git a/src/main/java/com/api/chaoyang/he/hcy_xintiantongxin/exportotherexcel/CheckRequestInfo.java b/src/main/java/com/api/chaoyang/he/hcy_xintiantongxin/exportotherexcel/CheckRequestInfo.java new file mode 100644 index 0000000..cc463ff --- /dev/null +++ b/src/main/java/com/api/chaoyang/he/hcy_xintiantongxin/exportotherexcel/CheckRequestInfo.java @@ -0,0 +1,90 @@ +package com.api.chaoyang.he.hcy_xintiantongxin.exportotherexcel; + +import aiyh.utils.ApiResult; +import aiyh.utils.Util; +import org.apache.log4j.Logger; +import weaver.conn.RecordSet; + +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.ArrayList; +import java.util.HashMap; +import java.util.List; +import java.util.Map; +import java.util.stream.Collectors; + +@Path("/hcy_xintiantongxin4") +public class CheckRequestInfo { + + Logger logger = Util.getLogger(); + + /** + * 校验 + * + * @param request + * @param response + * @return + */ + @POST + @Path("/checkRequestInfo") + @Produces(MediaType.APPLICATION_JSON) + public String checkRequestInfo(@Context HttpServletRequest request, @Context HttpServletResponse response) { + + + String ids = request.getParameter("ids"); + String[] split = ids.split(","); + + RecordSet recordSet = new RecordSet(); + + List> lists = new ArrayList<>(); + for (String s : split) { + String getCheckData = "select customername,currencyused,contractterminmonths,contractmodel from uf_other_export where id =?"; + boolean b = recordSet.executeQuery(getCheckData, s); + logger.info("查询验证信息sql是否执行"+b); + Map map = new HashMap<>(); + if (recordSet.next()){ + String customername = recordSet.getString("customername");//系统-客户名 + String currencyused = recordSet.getString("currencyused"); + String contractterminmonths = recordSet.getString("contractterminmonths"); + String contractmodel = recordSet.getString("contractmodel"); + map.put("customername",customername); + map.put("currencyused",currencyused); + map.put("contractterminmonths",contractterminmonths); + map.put("contractmodel",contractmodel); + lists.add(map); + } + } + + String checkTag = "0"; + List> collect = lists.stream().distinct().collect(Collectors.toList());//用stream流处理相同数据,如果得到的是一条数据,那么证明满足客户条件 + if (collect.size() == 1){ + checkTag = "1"; + }else { + checkTag = "0"; + } +// Map firstMap = lists.get(0); +// String first_customername = firstMap.get("customername"); +// String first_currencyused = firstMap.get("currencyused"); +// String first_contractterminmonths = firstMap.get("contractterminmonths"); +// String first_contractmodel = firstMap.get("contractmodel"); +// +// for (Map list : lists) { +// if (first_customername.equals(list.get("customername")) & first_currencyused.equals(list.get("currencyused")) & first_contractterminmonths.equals(list.get("contractterminmonths")) & first_contractmodel.equals(list.get("contractmodel")) ){ +// checkTag = "1"; +// }else { +// checkTag = "0"; +// return ApiResult.success(checkTag); +// } +// } + String getMsgSql = "select * from uf_cus_dev_config where only_mark = ?"; + recordSet.executeQuery(getMsgSql,"prompt_after_fail"); + recordSet.next(); + String msg = recordSet.getString("param_value"); + return ApiResult.success(checkTag,msg); + } +} diff --git a/src/main/java/com/api/chaoyang/he/hcy_xintiantongxin/exportotherexcel/DemoMapper.java b/src/main/java/com/api/chaoyang/he/hcy_xintiantongxin/exportotherexcel/DemoMapper.java new file mode 100644 index 0000000..26bcea8 --- /dev/null +++ b/src/main/java/com/api/chaoyang/he/hcy_xintiantongxin/exportotherexcel/DemoMapper.java @@ -0,0 +1,74 @@ +package com.api.chaoyang.he.hcy_xintiantongxin.exportotherexcel; + +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; + +/** + *

mapper--sql映射类,用于查找数据库中的数据

+ * @Author hcy + * @Date 2023/2/9 13:26 + */ +@SqlMapper +public interface DemoMapper { + + /** + *

根据前端返回的id内连接查询其他产品中主表和明细表中所有的数据

+ * @param ids + * @return List> + * @author hcy + * @Date 2023/2/9 13:25 + */ + @Select("select * from \n" + + "uf_other_export main \n" + + "inner join uf_other_export_dt1 dt \n" + + "on dt.mainid = main.id where main.id in (${ids})") + List> selectAll(@ParamMapper("ids") List ids); + + + /** + *

根据前端返回的id内连接查询其他产品中主表和明细表中所有的数据

+ * @param ids + * @return List> + * @author hcy + * @Date 2023/2/9 13:25 + */ + @Select("select * from \n" + + "uf_other_export main \n" + + "inner join uf_other_export_dt1 dt \n" + + "on dt.mainid = main.id where main.id in (${ids})\n") + List> selectCMRData(@ParamMapper("ids") List ids); + + + /** + *

根据人员id在hrmresource中查询到人员姓名

+ * @param id + * @return String + * @author hcy + * @Date 2023/2/9 13:23 + */ + @Select("select lastname from hrmresource where id = #{id}") + String selectLastName(@ParamMapper("id") String id); + + /** + *

根据id向uf_pd_base表中查找pd_name

+ * @param id + * @return String + * @author hcy + * @Date 2023/2/9 13:22 + */ + @Select("select pd_name from uf_pd_base_inf where id = #{id} ") + public String getServiceTypeSql(@ParamMapper("id") String id); + + + + + + + + + +} diff --git a/src/main/java/com/api/chaoyang/he/hcy_xintiantongxin/exportotherexcel/DemoMapper_copy.java b/src/main/java/com/api/chaoyang/he/hcy_xintiantongxin/exportotherexcel/DemoMapper_copy.java new file mode 100644 index 0000000..14e31c0 --- /dev/null +++ b/src/main/java/com/api/chaoyang/he/hcy_xintiantongxin/exportotherexcel/DemoMapper_copy.java @@ -0,0 +1,76 @@ +package com.api.chaoyang.he.hcy_xintiantongxin.exportotherexcel; + +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; + +/** + *

mapper--sql映射类,用于查找数据库中的数据

+ * @Author hcy + * @Date 2023/2/9 13:26 + */ +@SqlMapper +public interface DemoMapper_copy { + + /** + *

根据前端返回的id内连接查询其他产品中主表和明细表中所有的数据

+ * @param ids + * @return List> + * @author hcy + * @Date 2023/2/9 13:25 + */ + @Select("select main.id mainid,main.servicetype,main.contractterminmonths,\n" + + "dt.*\n" + + " from uf_other_export main\n" + + "inner join uf_other_export_dt1 dt on dt.mainid = main.id\n" + + "where main.id in (${ids})\n") + List> selectAll(@ParamMapper("ids") List ids); + + + /** + *

根据前端返回的id内连接查询其他产品中主表和明细表中所有的数据

+ * @param ids + * @return List> + * @author hcy + * @Date 2023/2/9 13:25 + */ + @Select("select main.id mainid,main.servicetype,main.contractterminmonths,main.channel_fee_per,main.channel_fee_type,\n" + + "dt.*\n" + + " from uf_other_export main\n" + + "inner join uf_other_export_dt1 dt on dt.mainid = main.id\n" + + "where main.id in (${ids})\n") + List> selectCMRData(@ParamMapper("ids") List ids); + + + /** + *

根据人员id在hrmresource中查询到人员姓名

+ * @param id + * @return String + * @author hcy + * @Date 2023/2/9 13:23 + */ + @Select("select lastname from hrmresource where id = #{id}") + String selectLastName(@ParamMapper("id") String id); + + /** + *

根据id向uf_pd_base表中查找pd_name

+ * @param id + * @return String + * @author hcy + * @Date 2023/2/9 13:22 + */ + @Select("select pd_name from uf_pd_base_inf where id = #{id} ") + public String getServiceTypeSql(@ParamMapper("id") String id); + + + + + + + + + +} diff --git a/src/main/java/com/api/chaoyang/he/hcy_xintiantongxin/exportotherexcel/ExportExcelOtherApi.java b/src/main/java/com/api/chaoyang/he/hcy_xintiantongxin/exportotherexcel/ExportExcelOtherApi.java new file mode 100644 index 0000000..6b5dc67 --- /dev/null +++ b/src/main/java/com/api/chaoyang/he/hcy_xintiantongxin/exportotherexcel/ExportExcelOtherApi.java @@ -0,0 +1,110 @@ +package com.api.chaoyang.he.hcy_xintiantongxin.exportotherexcel; + +import aiyh.utils.Util; +import org.apache.commons.io.IOUtils; +import org.apache.log4j.Logger; +import org.apache.poi.ss.usermodel.*; +import org.apache.poi.xssf.usermodel.XSSFWorkbook; + +import javax.servlet.http.HttpServletRequest; +import javax.servlet.http.HttpServletResponse; +import javax.ws.rs.GET; +import javax.ws.rs.Path; +import javax.ws.rs.Produces; +import javax.ws.rs.core.Context; +import javax.ws.rs.core.MediaType; +import javax.ws.rs.core.Response; +import javax.ws.rs.core.StreamingOutput; +import java.io.ByteArrayInputStream; +import java.io.ByteArrayOutputStream; +import java.io.IOException; +import java.io.InputStream; +import java.nio.charset.StandardCharsets; + +@Path("/hcy_xintiantongxin1") +public class ExportExcelOtherApi { + + Logger logger = Util.getLogger(); + + /** + *获取其他产品uf_other_export表中的数据,渲染到sheet1---CMR中 + */ + private SheetCMRPOI sheetCMRPOI = new SheetCMRPOI(); + /** + * 获取其他产品uf_other_export表中的数据,渲染到sheet2---Quotation中 + */ + private SheetQuotationPOI sheetQuotationPOI = new SheetQuotationPOI(); + /** + * 获取其他产品uf_other_export表中的数据,渲染到sheet3---Cost中 + */ + private SheetCostPOI sheetCostPOI = new SheetCostPOI(); + + + /** + *

将数据库中的数据放入sheet1---Quotation中

+ * @param request,response + * @return Response + * @author hcy + * @Date 2023/2/9 14:21 + */ + @GET + @Path("/ExportExcelOtherApi") + @Produces(MediaType.APPLICATION_OCTET_STREAM) + public Response exportExcel(@Context HttpServletRequest request, @Context HttpServletResponse response) { + + Response build = null; + Response.ResponseBuilder header = null; + StreamingOutput output = null; + String ids = request.getParameter("ids"); + String[] split = ids.split(","); + + //创建一个工作簿 + Workbook workbook = new XSSFWorkbook(); + //创建一个工作表sheet + + sheetCMRPOI.setSheetCMR(workbook,split);//创建第一个sheet1---sheet_CMR,并向sheet中渲染内容 + sheetQuotationPOI.setQuotationSheet(workbook,split);//创建第二个sheet2---sheet_Quotation,并向sheet中渲染内容 + sheetCostPOI.getSheetCost(workbook,split);//创建第三个sheet3---sheet_Cost,并向sheet中渲染内容 + try { + InputStream inputStream = workbookConvertorStream(workbook); + byte[] bytes = IOUtils.toByteArray(inputStream); + output = outputStream -> { + outputStream.write(bytes); + outputStream.close(); + }; + + header = Response.ok(output,MediaType.APPLICATION_OCTET_STREAM) + .type("application/xlsx") + .header("Content-Disposition", + "attachment; filename=\""+ new String("其他产品表.xlsx".getBytes("GBK"), StandardCharsets.ISO_8859_1)+"\""); + + } catch (IOException e) { + e.printStackTrace(); + } + + build = header.build(); + return build; + } + + /** + * SXSSFWorkbook 转 InputStream + * @param workbook + * @return + */ + public static InputStream workbookConvertorStream(Workbook workbook) { + InputStream in = null; + try{ + //临时缓冲区 + ByteArrayOutputStream out = new ByteArrayOutputStream(); + //创建临时文件 + workbook.write(out); + byte [] bookByteAry = out.toByteArray(); + in = new ByteArrayInputStream(bookByteAry); + } + catch (Exception e){ + e.printStackTrace(); + } + return in; + } + +} diff --git a/src/main/java/com/api/chaoyang/he/hcy_xintiantongxin/exportotherexcel/SetCellStylePOI.java b/src/main/java/com/api/chaoyang/he/hcy_xintiantongxin/exportotherexcel/SetCellStylePOI.java new file mode 100644 index 0000000..d773dc5 --- /dev/null +++ b/src/main/java/com/api/chaoyang/he/hcy_xintiantongxin/exportotherexcel/SetCellStylePOI.java @@ -0,0 +1,419 @@ +package com.api.chaoyang.he.hcy_xintiantongxin.exportotherexcel; + +import org.apache.poi.ss.usermodel.*; + +import java.io.ByteArrayInputStream; +import java.io.ByteArrayOutputStream; +import java.io.InputStream; + +/** + *

poi设置单元格样式

+ * @Author hcy + * @Date 2023/2/9 14:34 + */ +public class SetCellStylePOI { + /** + *

设置每个单元格样式:包含字体类型,字体是否加粗,是否包含边框,元素水平方向的位置,元素垂直方向的位置,是否设置元素的数据格式,是否自动换行

+ * @param + * @return + * @author hcy + * @Date 2023/2/13 18:08 + */ + public static CellStyle setTotalStyle(Workbook workbook,String type,boolean setBold,boolean setBorder,HorizontalAlignment horizontalDirection,VerticalAlignment verticalAlignmentDirection ,boolean setDataFormat,boolean setWrapText){ + //new一个cellStyle用于设置每一个单元格样式 + CellStyle cellStyle = workbook.createCellStyle(); + Font font = workbook.createFont(); + //颜色 + font.setColor(Font.COLOR_NORMAL); + //设置字体大小 + font.setFontHeightInPoints((short) 10); + //字体 + font.setFontName(type); + //设置字体是否加粗 + font.setBold(setBold); + //将字体样式渲染cellStyle对象中 + cellStyle.setFont(font); + if (setBorder == true){ + //设置样式对象,这里仅设置了边框属性 + cellStyle.setBorderBottom(BorderStyle.THIN); //下边框 + cellStyle.setBorderLeft(BorderStyle.THIN);//左边框 + cellStyle.setBorderTop(BorderStyle.THIN);//上边框 + cellStyle.setBorderRight(BorderStyle.THIN);//右边框 + } + + //水平居中 + cellStyle.setAlignment(horizontalDirection); + //垂直居中 + cellStyle.setVerticalAlignment(verticalAlignmentDirection); + cellStyle.setWrapText(setWrapText); + + //此处设置数据格式 + if(setDataFormat == true){ + DataFormat dataFormat = workbook.createDataFormat(); + cellStyle.setDataFormat(dataFormat.getFormat("0.00_ ")); + } + + return cellStyle; + } + + /** + *

设置每个单元格样式:包含字体类型,字体是否加粗,是否包含边框,元素水平方向的位置,元素垂直方向的位置,是否设置元素的数据格式,

+ * @param + * @return + * @author hcy + * @Date 2023/2/13 18:08 + */ + public static CellStyle setTotalStyle(Workbook workbook,String type,boolean setBold,boolean setBorder,HorizontalAlignment horizontalDirection,VerticalAlignment verticalAlignmentDirection ,boolean setDataFormat){ + //new一个cellStyle用于设置每一个单元格样式 + CellStyle cellStyle = workbook.createCellStyle(); + Font font = workbook.createFont(); + //颜色 + font.setColor(Font.COLOR_NORMAL); + //设置字体大小 + font.setFontHeightInPoints((short) 10); + //字体 + font.setFontName(type); + //设置字体是否加粗 + font.setBold(setBold); + //将字体样式渲染cellStyle对象中 + cellStyle.setFont(font); + if (setBorder == true){ + //设置样式对象,这里仅设置了边框属性 + cellStyle.setBorderBottom(BorderStyle.THIN); //下边框 + cellStyle.setBorderLeft(BorderStyle.THIN);//左边框 + cellStyle.setBorderTop(BorderStyle.THIN);//上边框 + cellStyle.setBorderRight(BorderStyle.THIN);//右边框 + } + + //水平居中 + cellStyle.setAlignment(horizontalDirection); + //垂直居中 + cellStyle.setVerticalAlignment(verticalAlignmentDirection); + + //此处设置数据格式 + if(setDataFormat == true){ + DataFormat dataFormat = workbook.createDataFormat(); + cellStyle.setDataFormat(dataFormat.getFormat("0.00_ ")); + } + + return cellStyle; + } + + + /** + * 设置每个单元格的样式,并且加粗字体,设置边框 + * + * @param workbook + * @return + */ + public static CellStyle setWordStyle(Workbook workbook, Boolean setBold) { + // 设置字体 + CellStyle cellStyle = workbook.createCellStyle(); + + //设置样式对象,这里仅设置了边框属性 + + cellStyle.setBorderBottom(BorderStyle.THIN); //下边框 + + cellStyle.setBorderLeft(BorderStyle.THIN);//左边框 + + cellStyle.setBorderTop(BorderStyle.THIN);//上边框 + + cellStyle.setBorderRight(BorderStyle.THIN);//右边框 + + //水平居中 + cellStyle.setAlignment(HorizontalAlignment.CENTER); + //垂直居中 + cellStyle.setVerticalAlignment(VerticalAlignment.CENTER); + + + Font font = workbook.createFont(); + //颜色 + font.setColor(Font.COLOR_NORMAL); + //设置字体大小 + font.setFontHeightInPoints((short) 10); + //字体 + font.setFontName("微软雅黑"); + font.setBold(setBold); + cellStyle.setFont(font); + + return cellStyle; + } + + + /** + * 设置每个单元格的样式,并且加粗字体,设置边框 + * + * @param workbook + * @return + */ + /** + *

设置每个单元格的样式,并且加粗字体,设置边框,字体位置

+ * @param workbook,setBold, + * @return + * @author hcy + * @Date 2023/2/8 20:43 + */ + public static CellStyle setWordStyle(Workbook workbook, Boolean setBold,boolean setLocation) { + // 设置字体 + CellStyle cellStyle = workbook.createCellStyle(); + + //设置样式对象,这里仅设置了边框属性 + + cellStyle.setBorderBottom(BorderStyle.THIN); //下边框 + + cellStyle.setBorderLeft(BorderStyle.THIN);//左边框 + + cellStyle.setBorderTop(BorderStyle.THIN);//上边框 + + cellStyle.setBorderRight(BorderStyle.THIN);//右边框 + + if (setLocation == true) { + //水平居中 + cellStyle.setAlignment(HorizontalAlignment.CENTER); + //垂直居中 + cellStyle.setVerticalAlignment(VerticalAlignment.CENTER); + } + + + Font font = workbook.createFont(); + //颜色 + font.setColor(Font.COLOR_NORMAL); + //设置字体大小 + font.setFontHeightInPoints((short) 10); + //字体 + font.setFontName("微软雅黑"); + font.setBold(setBold); + cellStyle.setFont(font); + + return cellStyle; + } + + /** + *

设置字体颜色和边框

+ * @param workbook + * @return CellStyle + * @author hcy + * @Date 2023/2/8 17:25 + */ + public static CellStyle setWordStyle(Workbook workbook) { + // 设置字体 + CellStyle cellStyle = workbook.createCellStyle(); + //设置样式对象,这里仅设置了边框属性 + cellStyle.setBorderBottom(BorderStyle.THIN); //下边框 + + cellStyle.setBorderLeft(BorderStyle.THIN);//左边框 + + cellStyle.setBorderTop(BorderStyle.THIN);//上边框 + + cellStyle.setBorderRight(BorderStyle.THIN);//右边框 + + //水平居中 + cellStyle.setAlignment(HorizontalAlignment.CENTER); + //垂直居中 + cellStyle.setVerticalAlignment(VerticalAlignment.CENTER); + + + + Font font = workbook.createFont(); + //颜色 + font.setColor(Font.COLOR_NORMAL); + //设置字体大小 + font.setFontHeightInPoints((short) 10); + //字体 + font.setFontName("微软雅黑"); + cellStyle.setFont(font); + return cellStyle; + } + + /** + *

仅设置字体样式

+ * @param workbook,setBold + * @return CellStyle + * @author hcy + * @Date '2023/2/8' 17:50 + */ + public static CellStyle setNolyWordStyle(Workbook workbook,Boolean setBold) { + // 设置字体 + CellStyle cellStyle = workbook.createCellStyle(); + + Font font = workbook.createFont(); + //颜色 + font.setColor(Font.COLOR_NORMAL); + //设置字体大小 + font.setFontHeightInPoints((short) 10); + //字体 + font.setFontName("微软雅黑"); + font.setBold(setBold); + cellStyle.setFont(font); + //水平居中 + cellStyle.setAlignment(HorizontalAlignment.CENTER); + //垂直居中 + cellStyle.setVerticalAlignment(VerticalAlignment.CENTER); + DataFormat dataFormat = workbook.createDataFormat();//此处设置数据格式 + cellStyle.setDataFormat(dataFormat.getFormat("0.00_ ")); + return cellStyle; + } + /** + *

仅设置字体样式,并设置字体位置

+ * @param workbook,setBold + * @return CellStyle + * @author hcy + * @Date '2023/2/8' 17:50 + */ + public static CellStyle setNolyWordStyle(Workbook workbook,Boolean setBold,Boolean setLocation) { + // 设置字体 + CellStyle cellStyle = workbook.createCellStyle(); + + Font font = workbook.createFont(); + //颜色 + font.setColor(Font.COLOR_NORMAL); + //设置字体大小 + font.setFontHeightInPoints((short) 10); + //字体 + font.setFontName("微软雅黑"); + font.setBold(setBold); + cellStyle.setFont(font); + if (setLocation == true) { + //水平居中 + cellStyle.setAlignment(HorizontalAlignment.CENTER); + //垂直居中 + cellStyle.setVerticalAlignment(VerticalAlignment.CENTER); + } + DataFormat dataFormat = workbook.createDataFormat();//此处设置数据格式 + cellStyle.setDataFormat(dataFormat.getFormat("0.00_ ")); + return cellStyle; + } + + + + + /** + * SXSSFWorkbook 转 InputStream + * @param workbook + * @return + */ + public static InputStream workbookConvertorStream(Workbook workbook) { + InputStream in = null; + try{ + //临时缓冲区 + ByteArrayOutputStream out = new ByteArrayOutputStream(); + //创建临时文件 + workbook.write(out); + byte [] bookByteAry = out.toByteArray(); + in = new ByteArrayInputStream(bookByteAry); + } + catch (Exception e){ + e.printStackTrace(); + } + return in; + } + + + /** + * 只设置边框样式 + * + * @param workbook + * @return + */ + public static CellStyle setNolyBorderStyle(Workbook workbook) { + // 设置字体 + CellStyle cellStyle = workbook.createCellStyle(); + //设置样式对象,这里仅设置了边框属性 + cellStyle.setBorderBottom(BorderStyle.THIN); //下边框 + + cellStyle.setBorderLeft(BorderStyle.THIN);//左边框 + + cellStyle.setBorderTop(BorderStyle.THIN);//上边框 + + cellStyle.setBorderRight(BorderStyle.THIN);//右边框 + + return cellStyle; + } + + + /** + * 设置单元格格式为数值型 + * @param workbook + * @return + */ + public static CellStyle setCellToNumber(Workbook workbook){ + // 设置字体 + CellStyle cellStyle = workbook.createCellStyle(); + //设置样式对象,这里仅设置了边框属性 + cellStyle.setBorderBottom(BorderStyle.THIN); //下边框 + + cellStyle.setBorderLeft(BorderStyle.THIN);//左边框 + + cellStyle.setBorderTop(BorderStyle.THIN);//上边框 + + cellStyle.setBorderRight(BorderStyle.THIN);//右边框 + Font font = workbook.createFont(); + //颜色 + font.setColor(Font.COLOR_NORMAL); + //设置字体大小 + font.setFontHeightInPoints((short) 10); + //字体 + font.setFontName("微软雅黑"); + cellStyle.setFont(font); + DataFormat dataFormat = workbook.createDataFormat();//此处设置数据格式 + cellStyle.setDataFormat(dataFormat.getFormat("0.00_ ")); + return cellStyle; + } + + /** + *

设置字体颜色,是否加粗,设置单元格格式为数值型,设置字体居中

+ * @param workbook,setBold,setLocation + * @return CellStyle + * @author hcy + * @Date 2023/2/9 13:39 + */ + public static CellStyle setCellToNumber(Workbook workbook,boolean setBold,boolean setLocation){ + // 设置字体 + CellStyle cellStyle = workbook.createCellStyle(); + //设置样式对象,这里仅设置了边框属性 + cellStyle.setBorderBottom(BorderStyle.THIN); //下边框 + + cellStyle.setBorderLeft(BorderStyle.THIN);//左边框 + + cellStyle.setBorderTop(BorderStyle.THIN);//上边框 + + cellStyle.setBorderRight(BorderStyle.THIN);//右边框 + Font font = workbook.createFont(); + //颜色 + font.setColor(Font.COLOR_NORMAL); + //设置字体大小 + font.setFontHeightInPoints((short) 10); + //字体 + font.setFontName("微软雅黑"); + cellStyle.setFont(font); + if (setBold == true){ + font.setBold(setBold); + } + if (setLocation == true){ + //水平居中 + cellStyle.setAlignment(HorizontalAlignment.CENTER); + //垂直居中 + cellStyle.setVerticalAlignment(VerticalAlignment.CENTER); + } + + DataFormat dataFormat = workbook.createDataFormat();//此处设置数据格式 + cellStyle.setDataFormat(dataFormat.getFormat("0.00_ ")); + return cellStyle; + } + + /** + *

POI设置文字水平居中、垂直居中

+ * @param workbook + * @return CellStyle + * @author hcy + * @Date 2023/2/8 20:08 + */ + public static CellStyle setCellLocations(Workbook workbook){ + CellStyle cellStyle = workbook.createCellStyle();//创建文本单元格样式 + //水平居中 + cellStyle.setAlignment(HorizontalAlignment.CENTER); + //垂直居中 + cellStyle.setVerticalAlignment(VerticalAlignment.CENTER); + return cellStyle; + } +} diff --git a/src/main/java/com/api/chaoyang/he/hcy_xintiantongxin/exportotherexcel/SheetCMRPOI.java b/src/main/java/com/api/chaoyang/he/hcy_xintiantongxin/exportotherexcel/SheetCMRPOI.java new file mode 100644 index 0000000..a744f50 --- /dev/null +++ b/src/main/java/com/api/chaoyang/he/hcy_xintiantongxin/exportotherexcel/SheetCMRPOI.java @@ -0,0 +1,437 @@ +package com.api.chaoyang.he.hcy_xintiantongxin.exportotherexcel; + +import aiyh.utils.Util; +import org.apache.log4j.Logger; +import org.apache.poi.ss.usermodel.*; +import org.apache.poi.ss.util.CellRangeAddress; +import weaver.conn.RecordSet; + +import java.text.NumberFormat; +import java.util.*; +import java.util.stream.Collectors; + +/** + *

获取其他产品uf_other_export表中的数据,渲染到sheet1---CMR中

+ * hcy + * 2023/2/9 15:40 + */ +public class SheetCMRPOI extends SetCellStylePOI{ + + private final Logger logger = Util.getLogger(); + + /** + *

将数据库中的数据放入sheet1---CMR中

+ * workbook,split + * @author hcy + 2023/2/9 14:19 + */ + public void setSheetCMR(Workbook workbook, String[] split){ + logger.info("SheetCMRPOI----开始执行"); + Sheet sheet_CMR = workbook.createSheet(); + workbook.setSheetName(0,"CMR"); + +// 将第一行数据放入CMR-sheet_0中 + Row row0 = sheet_CMR.createRow(0); + sheet_CMR.autoSizeColumn(0); + Cell cell0_0 = row0.createCell(0); + cell0_0.setCellValue("CMR Analysis Form"); + cell0_0.setCellStyle(setNolyWordStyle(workbook,true,true)); + sheet_CMR.addMergedRegion(new CellRangeAddress(0,0,0,7)); +// 将第二行数据放入CMR-sheet_0中 + Row row1 = sheet_CMR.createRow(1); + sheet_CMR.autoSizeColumn(1); + Cell cell1_0 = row1.createCell(0); + cell1_0.setCellValue("General Information"); + cell1_0.setCellStyle(setWordStyle(workbook,true,false)); + Cell cell1_1 = row1.createCell(1); + cell1_1.setCellValue("General Information"); + cell1_1.setCellStyle(setWordStyle(workbook,true,false)); + for (int colNum = 1;colNum<8;colNum++){ + Cell cell = row1.createCell(colNum); + cell.setCellStyle(setNolyBorderStyle(workbook)); + } + + sheet_CMR.addMergedRegion(new CellRangeAddress(1,1,0,7)); + String[] value_row3_9 = new String[] + {"Customer Name", + "Sales Name", + "Presales Name", + "Service Delivery Date", + "Contract Period (Months)", + "Customer Requirements", + "Service Description"}; + +// 从其他产品表单数据库表中导出主表中3-9行所需数据 + + String getValue3_9FromDB = "select * from uf_other_export where id = ?"; + RecordSet recordSet = new RecordSet(); + boolean b = recordSet.executeQuery(getValue3_9FromDB,split[0]); + logger.info("b是否执行=="+b); + List value3_9FromDB = new ArrayList<>(); + String contractterminmonths = ""; + if (recordSet.next()){ + String customerName = recordSet.getString("customername");//Customer Name 系统-客户名 + value3_9FromDB.add(customerName); + value3_9FromDB.add("");//Sales Name---手工(导出后填写) 这里设置为空 + String cjr = recordSet.getString("cjr");//Presales Name---报价单创建人 + DemoMapper getLastNameMapper = Util.getMapper(DemoMapper.class); + String getCreaterName = getLastNameMapper.selectLastName(cjr);//根据id在hrmsource表中查到LastName 姓名 + value3_9FromDB.add(getCreaterName); + value3_9FromDB.add("");//Service Delivery Date---手工(导出后填写)---这里设置为空 + contractterminmonths = recordSet.getString("contractterminmonths");//Contract Period (Months)---系统- Contract Term(in months)(contractterminmonths) + value3_9FromDB.add(contractterminmonths); + value3_9FromDB.add("");//Customer Requirements---手工(导出后填写) 这里设置为空 + value3_9FromDB.add("");////Service Description---手工(导出后填写) 这里设置为空 + } + + for (int rowNum = 2;rowNum<9;rowNum++){ + Row row = sheet_CMR.createRow(rowNum); + sheet_CMR.autoSizeColumn(rowNum); + Cell cell0 = row.createCell(0); + Cell cell1 = row.createCell(1); + cell0.setCellValue(value_row3_9[rowNum-2]);//将3-9行第一列固定数据放入sheet0中 + cell0.setCellStyle(setWordStyle(workbook,true)); + cell1.setCellValue(value3_9FromDB.get(rowNum-2));//将3-9行第二列数据库中查到的数据放入sheet0中 + cell1.setCellStyle(setWordStyle(workbook,false)); + for (int colNum =2;colNum<8;colNum++){ + Cell cell = row.createCell(colNum); + cell.setCellStyle(setNolyBorderStyle(workbook)); + } + sheet_CMR.addMergedRegion(new CellRangeAddress(rowNum,rowNum,1,7)); + } + + + + +// 开始写入11-12行固定值数据 + String[] valueRow11 = new String[] + {"Revenue Information(RMB) VAT Exclusive", + "", + "Quotation", + "Quotation", + "COST", + "COST", + "Agent fee", + "Agent fee" + }; + String[] valueRow12 = new String[] + {"Revenue Information(RMB) VAT Exclusive", + "Revenue Information(RMB) VAT Exclusive", + "One Time Charge", + "Recurring Monthly Charge", + "One Time Charge", + "Recurring Monthly Charge", + "One Time Charge", + "Recurring Monthly Charge" + }; + List list11 = Arrays.asList(valueRow11); + List list12 = Arrays.asList(valueRow12); + List> list11_12 = new ArrayList<>();//new 一个list对象用于存放12-13行所有的元素 + list11_12.add(list11); + list11_12.add(list12); + + for (int rowNum = 10;rowNum<12;rowNum++){ + Row row = sheet_CMR.createRow(rowNum); + sheet_CMR.autoSizeColumn(rowNum); + List list = list11_12.get(rowNum - 10);//将list11_12中数据放入list中 + for (int cowNum = 0;cowNum<8;cowNum++){ + Cell cell = row.createCell(cowNum); + cell.setCellStyle(setWordStyle(workbook,true)); + cell.setCellValue(list.get(cowNum));//开始写入数据 + } + } + //开始合并12-13行数据 + sheet_CMR.addMergedRegion(new CellRangeAddress(10,11,0,1)); + sheet_CMR.addMergedRegion(new CellRangeAddress(10,10,2,3)); + sheet_CMR.addMergedRegion(new CellRangeAddress(10,10,4,5)); + sheet_CMR.addMergedRegion(new CellRangeAddress(10,10,6,7)); + + //开始处理14行及其14行一下的其他产品明细表中的数据 + List splitList = Arrays.asList(split); + DemoMapper mapper = Util.getMapper(DemoMapper.class);//获得mapper对象 + List> dynamicData = mapper.selectCMRData(splitList);//13行及其13行一下的动态数据获取到dynamicData对象中 + logger.info("dynamicData==="+dynamicData); + + Map>> newMap = dynamicData.stream() + .collect(Collectors.groupingBy(map1 -> map1.get("servicetype"))); + List> result = new ArrayList<>();//明细表中动态表格最终的数据来源 + for (Map.Entry>> e : newMap.entrySet()) { + Object key = e.getKey(); + List> maps = e.getValue(); + Map resultMap = new HashMap<>(); + for (Map map1 : maps) { + for (Map.Entry entry : map1.entrySet()) { + String k = entry.getKey(); + Object v = entry.getValue(); + if ("priceexcludingtaxotc".equals(k) || "priceexcludingtaxmrc".equals(k) || k.equals("costexcludingtaxotc") || k.equals("costexcludingtaxmrc") ) { + if ("".equals(Util.null2String(v))) { + v = 0; + } + resultMap.merge(k, v, (v1, v2) -> Double.parseDouble(Util.null2String(v1)) + Double.parseDouble(Util.null2String(v2))); + } + + if ("xxfylx".equals(k)){ //代理费用类型(xxfylx)== 0.项目百分比 1.固定金额 2.月租百分比 + String channeltype = Util.null2String(v); + if ("0".equals(channeltype)){//项目百分比 = 0时 One Time Charge = agentfee + Object agent_fee = map1.get("agentfee");//代理费用(不含税) + String price = Util.null2String(agent_fee); + logger.info("最后一次需求变更----price===="+price); +// Object channelfeeper = map1.get("channelFeePer"); +// String percent = Util.null2String(channelfeeper);//代理费用占比 + double Agent_fee_One_Time_Charge; + if (!"".equals(price)){ + Agent_fee_One_Time_Charge = Double.parseDouble(price); + resultMap.merge("OneTimeCharge", Agent_fee_One_Time_Charge, (v1, v2) -> Double.parseDouble(Util.null2String(v1)) + Double.parseDouble(Util.null2String(v2))); + }else{ + Agent_fee_One_Time_Charge = 0; + resultMap.merge("OneTimeCharge", Agent_fee_One_Time_Charge, (v1, v2) -> Double.parseDouble(Util.null2String(v1)) + Double.parseDouble(Util.null2String(v2))); + } + }else if ("1".equals(channeltype)) {//固定金额 + Object agent_fee = map1.get("agentfee"); + String price = Util.null2String(agent_fee); + logger.info("最后一次需求变更----price===="+price); + double Agent_fee_One_Time_Charge; + if (!"".equals(price)){ + Agent_fee_One_Time_Charge = Double.parseDouble(price); + resultMap.merge("OneTimeCharge", Agent_fee_One_Time_Charge, (v1, v2) -> Double.parseDouble(Util.null2String(v1)) + Double.parseDouble(Util.null2String(v2))); + }else{ + Agent_fee_One_Time_Charge = 0; + resultMap.merge("OneTimeCharge", Agent_fee_One_Time_Charge, (v1, v2) -> Double.parseDouble(Util.null2String(v1)) + Double.parseDouble(Util.null2String(v2))); + } + }else if ("2".equals(channeltype)){//月租百分比 +// Object xxfyzb = map1.get("xxfyzb");//代理费用占比 +// String percent = Util.null2String(xxfyzb); + Object agent_fee = map1.get("agentfee"); + String price = Util.null2String(agent_fee); + logger.info("最后一次需求变更----price===="+price); + int terms = Util.getIntValue(Util.null2String(map1.get("terms"))); + logger.info("最后一次需求变更----terms===="+terms); + double Agent_fee_One_Time_Charge; + if (!"".equals(price)){ + double priceDouble = Double.parseDouble(price); +// double percentDouble = Double.parseDouble(percent); + Agent_fee_One_Time_Charge = priceDouble / terms; + logger.info("最后一次需求变更----Agent_fee_One_Time_Charge===="+Agent_fee_One_Time_Charge); + resultMap.merge("RecurringMonthlyCharge", Agent_fee_One_Time_Charge, (v1, v2) -> Double.parseDouble(Util.null2String(v1)) + Double.parseDouble(Util.null2String(v2))); + }else{ + Agent_fee_One_Time_Charge = 0; + resultMap.merge("RecurringMonthlyCharge", Agent_fee_One_Time_Charge, (v1, v2) -> Double.parseDouble(Util.null2String(v1)) + Double.parseDouble(Util.null2String(v2))); + } + } + } + } + } + resultMap.put("servicetype", key); + result.add(resultMap); + } + //-------新的业务逻辑--------- + int tag = 0; + double totalColumn3 = 0; + double totalColumn4 = 0; + double totalColumn5 = 0; + double totalColumn6 = 0; + double totalColumn7 = 0; + double totalColumn8 = 0; + + for (int cowNum=12;cowNum < result.size()+12;cowNum++ ){ + Row row = sheet_CMR.createRow(cowNum); + sheet_CMR.autoSizeColumn(cowNum); + Map map = result.get(cowNum - 12); + for (int colNum = 0;colNum < 8;colNum++){ + if (colNum==0){ + Cell cell = row.createCell(colNum); + tag++; + cell.setCellValue(tag); + cell.setCellStyle(setWordStyle(workbook,false,true)); + }else if (colNum == 1){ //servicetype + Cell cell = row.createCell(colNum); + Object servicetype = map.get("servicetype"); + String string = Util.null2String(servicetype); + if (!"".equals(string) && (int)Double.parseDouble(string)!=-1) { + DemoMapper getServicetyeMapper = Util.getMapper(DemoMapper.class); + String serviceTypeSql = getServicetyeMapper.getServiceTypeSql(string); + cell.setCellValue(serviceTypeSql); + cell.setCellStyle(setWordStyle(workbook,false,true)); + }else { + cell.setCellStyle(setNolyBorderStyle(workbook)); + } + + }else if (colNum == 2) { //priceexcludingtaxotc + Cell cell = row.createCell(colNum); + Object priceexcludingtaxotc = map.get("priceexcludingtaxotc"); + String string = Util.null2String(priceexcludingtaxotc); + if (!"".equals(string)){ + if ((int)Double.parseDouble(string)!=-1){ + double stringToDouble = Double.parseDouble(string); + totalColumn3 += stringToDouble;//统计第三列数据的和 + cell.setCellStyle(setCellToNumber(workbook,false,true));//设置为数值型 + cell.setCellValue(stringToDouble); + }else { + cell.setCellStyle(setNolyBorderStyle(workbook)); + } + }else{ + cell.setCellStyle(setNolyBorderStyle(workbook)); + } + + }else if (colNum == 3) {//priceexcludingtaxmrc + Cell cell = row.createCell(colNum); + Object priceexcludingtaxmrc = map.get("priceexcludingtaxmrc"); + String string = Util.null2String(priceexcludingtaxmrc); + if (!"".equals(string)){ + if ((int)Double.parseDouble(string)!=-1){ + double stringToDouble = Double.parseDouble(string); + totalColumn4 += stringToDouble; + cell.setCellStyle(setCellToNumber(workbook,false,true));//设置为数值型 + cell.setCellValue(stringToDouble); + }else { + cell.setCellStyle(setNolyBorderStyle(workbook)); + } + }else { + cell.setCellStyle(setNolyBorderStyle(workbook)); + } + }else if (colNum == 4) {//costexcludingtaxotc + Cell cell = row.createCell(colNum); + Object costexcludingtaxotc = map.get("costexcludingtaxotc"); + String string = Util.null2String(costexcludingtaxotc); + if (!"".equals(string)){ + if ((int)Double.parseDouble(string)!=-1){ + double stringToDouble = Double.parseDouble(string); + totalColumn5 += stringToDouble; + cell.setCellStyle(setCellToNumber(workbook,false,true));//设置为数值型 + cell.setCellValue(stringToDouble); + }else { + cell.setCellStyle(setNolyBorderStyle(workbook)); + } + }else { + cell.setCellStyle(setNolyBorderStyle(workbook)); + } + }else if (colNum == 5) {//costexcludingtaxmrc + Cell cell = row.createCell(colNum); + Object costexcludingtaxmrc = map.get("costexcludingtaxmrc"); + String string = Util.null2String(costexcludingtaxmrc); + if (!"".equals(string)){ + if ((int)Double.parseDouble(string)!=-1){ + double stringToDouble = Double.parseDouble(string); + totalColumn6 += stringToDouble; + cell.setCellStyle(setCellToNumber(workbook,false,true));//设置为数值型 + cell.setCellValue(stringToDouble); + }else { + cell.setCellStyle(setNolyBorderStyle(workbook)); + } + }else { + cell.setCellStyle(setNolyBorderStyle(workbook)); + } + }else if (colNum == 6) {//channel_fee_type channelfeetype channel_fee_per channelfeeper + Cell cell = row.createCell(colNum); + Object oneTimeCharge = map.get("OneTimeCharge"); + String oneTimeChargeValue = Util.null2String(oneTimeCharge); + if (!"".equals(oneTimeChargeValue)){ + double oneTimeChargeDouble = Double.parseDouble(oneTimeChargeValue); + cell.setCellStyle(setCellToNumber(workbook,false,true)); + cell.setCellValue(oneTimeChargeDouble); + totalColumn7 += oneTimeChargeDouble; + }else { + cell.setCellStyle(setNolyBorderStyle(workbook)); + } + }else{//channel_fee_per channelfeeper + Cell cell = row.createCell(colNum); + Object recurringMonthlyCharge = map.get("RecurringMonthlyCharge"); + String recurringMonthlyChargeValue = Util.null2String(recurringMonthlyCharge); + if (!"".equals(recurringMonthlyChargeValue)){ + double recurringMonthlyChargeDouble= Double.parseDouble(recurringMonthlyChargeValue); + cell.setCellStyle(setCellToNumber(workbook,false,true)); + cell.setCellValue(recurringMonthlyChargeDouble); + totalColumn8 += recurringMonthlyChargeDouble; + } else { + cell.setCellStyle(setNolyBorderStyle(workbook)); + } + } + } + } + //开始写入Total一行,用来统计第三列到第八列明细表中数据的和 + int cowNumTotal = 12 + result.size(); + Row row_cowNumTotal = sheet_CMR.createRow(cowNumTotal); + sheet_CMR.autoSizeColumn(cowNumTotal); + Cell cell_cowNumTotal_0 = row_cowNumTotal.createCell(0); + cell_cowNumTotal_0.setCellValue("Total"); + cell_cowNumTotal_0.setCellStyle(setWordStyle(workbook,true,true)); + sheet_CMR.addMergedRegion(new CellRangeAddress(cowNumTotal,cowNumTotal,0,1)); + + //开始写入数据和具体数值 第三列到第八列 + Cell cell_cowNumTotal_2 = row_cowNumTotal.createCell(2); + cell_cowNumTotal_2.setCellValue(totalColumn3);//写入第三列总和 + cell_cowNumTotal_2.setCellStyle(setCellToNumber(workbook,true,true)); + Cell cell_cowNumTotal_3 = row_cowNumTotal.createCell(3); + cell_cowNumTotal_3.setCellValue(totalColumn4);//写入第4列总和 + cell_cowNumTotal_3.setCellStyle(setCellToNumber(workbook,true,true)); + Cell cell_cowNumTotal_4 = row_cowNumTotal.createCell(4); + cell_cowNumTotal_4.setCellValue(totalColumn5);//写入第5列总和 + cell_cowNumTotal_4.setCellStyle(setCellToNumber(workbook,true,true)); + Cell cell_cowNumTotal_5 = row_cowNumTotal.createCell(5); + cell_cowNumTotal_5.setCellValue(totalColumn6);//写入第6列总和 + cell_cowNumTotal_5.setCellStyle(setCellToNumber(workbook,true,true)); + Cell cell_cowNumTotal_6 = row_cowNumTotal.createCell(6); + cell_cowNumTotal_6.setCellValue(totalColumn7);//写入第7列总和 + cell_cowNumTotal_6.setCellStyle(setCellToNumber(workbook,true,true)); + Cell cell_cowNumTotal_7 = row_cowNumTotal.createCell(7); + cell_cowNumTotal_7.setCellValue(totalColumn8);//写入第4列总和 + cell_cowNumTotal_7.setCellStyle(setCellToNumber(workbook,true,true)); + +// 开始写入最后一行数据 + Row finalRow = sheet_CMR.createRow(cowNumTotal + 1); + sheet_CMR.autoSizeColumn(cowNumTotal +1); + Cell cell_final_0 = finalRow.createCell(0); + cell_final_0.setCellValue("Contribution Margin"); + cell_final_0.setCellStyle(setWordStyle(workbook,true,true)); + Cell cell_final_1 = finalRow.createCell(1); + cell_final_1.setCellValue("CMR(%)"); + cell_final_1.setCellStyle(setWordStyle(workbook,true,true)); + + //开始计算最后一行的公式:="【D20+E20*C8-F20-G20*C8-H20-I20*C8】/【D20+E20*C8】" + double month =0; + if (!contractterminmonths.equals("") ){ + month = Double.parseDouble(contractterminmonths); + if ((int)month == -1){ + month = 0; + } + } +// -36 / (120+120*12) + double expressions = ( totalColumn3 + totalColumn4 * month - totalColumn5 - totalColumn6 * month - totalColumn7 - totalColumn8 * month) / ( totalColumn3 + totalColumn4 * month); + Cell cell_final_2 = finalRow.createCell(2); + + cell_final_2.setCellType(CellType.NUMERIC); + cell_final_2.setCellValue(getPercentFormat(expressions,2,2)); + cell_final_2.setCellStyle(setWordStyle(workbook,true,true)); + for (int colNmu = 3 ;colNmu < 8 ;colNmu++){ + Cell cell = finalRow.createCell(colNmu); + cell.setCellStyle(setCellToNumber(workbook,true,true)); + } + sheet_CMR.addMergedRegion(new CellRangeAddress(cowNumTotal+1,cowNumTotal+1,2,7)); + + sheet_CMR.setColumnWidth(10,sheet_CMR.getColumnWidth(10)*17/10); + // 设置自动列宽 + for (int num = 0; num < 8; num++) { + sheet_CMR.autoSizeColumn(num); + sheet_CMR.setColumnWidth(num, (sheet_CMR.getColumnWidth(num))); + } + sheet_CMR.setColumnWidth(1, 20*256); + + } + + /** + *

Double转化成百分数

+ * @param d 要转换的内容 + * @param IntegerDigits 整数部分 + * @param FractionDigits 小数部分 + * @return String + * @author hcy + 2023/2/21 17:50 + */ + public static String getPercentFormat(double d,int IntegerDigits,int FractionDigits) { + NumberFormat nf = NumberFormat.getPercentInstance(); + nf.setMaximumIntegerDigits(IntegerDigits);//小数点前保留几位 + nf.setMinimumFractionDigits(FractionDigits);// 小数点后保留几位 + return nf.format(d); + } + +} diff --git a/src/main/java/com/api/chaoyang/he/hcy_xintiantongxin/exportotherexcel/SheetCostPOI.java b/src/main/java/com/api/chaoyang/he/hcy_xintiantongxin/exportotherexcel/SheetCostPOI.java new file mode 100644 index 0000000..561e1ea --- /dev/null +++ b/src/main/java/com/api/chaoyang/he/hcy_xintiantongxin/exportotherexcel/SheetCostPOI.java @@ -0,0 +1,452 @@ +package com.api.chaoyang.he.hcy_xintiantongxin.exportotherexcel; + +import aiyh.utils.Util; +import com.alibaba.fastjson.JSON; +import org.apache.log4j.Logger; +import org.apache.poi.ss.usermodel.*; +import org.apache.poi.ss.util.CellRangeAddress; +import weaver.conn.RecordSet; + +import java.text.SimpleDateFormat; +import java.util.*; +import java.util.concurrent.atomic.AtomicInteger; +import java.util.stream.Collectors; + +/** + *

获取其他产品uf_other_export表中的数据,渲染到sheet3---Cost中

+ * @Author hcy + * @Date 2023/2/9 14:27 + */ +public class SheetCostPOI extends SetCellStylePOI{ + + private final Logger logger = Util.getLogger(); + + + + /** + *

将数据库中的数据渲染到sheet3---Cost中

+ * @param workbook:poi workbook对象用来操作excel表, split:前端传来的数据的id组成的数组 + * @return + * @author hcy + * @Date 2023/2/9 14:35 + */ + public void getSheetCost(Workbook workbook,String[] split){ + try { + Sheet sheet_Cost = workbook.createSheet(); + workbook.setSheetName(2,"Cost"); + + String[] tableFiled = new String[]{"Customer Name", "Service Provider", "Contract Term(in months)", "Currency Used", "Issueing Date", "Expiration Date"}; + List systemFiled = new ArrayList<>(); + String sql_other_export_db = "select * from uf_other_export where id = ?"; + RecordSet rs = new RecordSet(); + rs.executeQuery(sql_other_export_db,split[0]); + while (rs.next()){ + String customername = rs.getString("customername"); + systemFiled.add(customername);//Customer Name + systemFiled.add("SST");//Service Provider + systemFiled.add(rs.getString("contractterminmonths"));//Contract Term(in months) + systemFiled.add("RMB");//Currency Used + //系统当前时间 + SimpleDateFormat formatter = new SimpleDateFormat("yyyy-MM-dd"); + Date date = new Date(System.currentTimeMillis()); + systemFiled.add(formatter.format(date));//Issueing Date + //系统当前时间再往后推30天 + Calendar currentdate = Calendar.getInstance(); + //在这里进行加30天(ps:周六周日也算在里边了) + currentdate.add(Calendar.DATE, 30); + //得到最后的时间 + Date finalday = currentdate.getTime(); + + systemFiled.add(formatter.format(finalday));//Expiration Date + } + //将1-6行固定值数据放入excel中 + for (int cowNum = 0; cowNum < 6; cowNum++) { + Row row = sheet_Cost.createRow(cowNum); + Cell cell0col = row.createCell(0); + Cell cell1col = row.createCell(1); + cell0col.setCellStyle(setNolyWordStyle(workbook,true)); + cell0col.setCellValue(tableFiled[cowNum]); + cell1col.setCellStyle(setNolyWordStyle(workbook,true)); + cell1col.setCellValue(systemFiled.get(cowNum)); + } + //将8行数据放入excel中 + //Quotation Breakdown: + Row row7 = sheet_Cost.createRow(7); + Cell cell7_0 = row7.createCell(0); + cell7_0.setCellStyle(setNolyWordStyle(workbook,true)); + cell7_0.setCellValue("Quotation Breakdown:"); + Cell cell7_1 = row7.createCell(1); + cell7_1.setCellStyle(setNolyWordStyle(workbook,true)); + cell7_1.setCellValue("Quotation Breakdown:"); + sheet_Cost.addMergedRegion(new CellRangeAddress(7,7,0,1)); + + //将第九行第十行前四列放入excel中并合并单元格 + //1Service Type 2.Site 3.Item 4.Service Description + String[] string8_4 = new String[]{"Service Type","Site","Item","Service Description"}; + Row row8 = sheet_Cost.createRow(8); + Row row9 = sheet_Cost.createRow(9); + for (int colNum = 0;colNum<4;colNum++){ + Cell cell8 = row8.createCell(colNum); + cell8.setCellStyle(setWordStyle(workbook,true)); + cell8.setCellValue(string8_4[colNum]); + Cell cell9 = row9.createCell(colNum); + cell9.setCellStyle(setWordStyle(workbook,true)); + cell9.setCellValue(""); + sheet_Cost.addMergedRegion(new CellRangeAddress(8,9,colNum,colNum)); + } + //Price Plus tax VAT rate % Price Excluding tax + //第九行三个字段并合并字段 5-10列 + Cell cell8_4 = row8.createCell(4); + cell8_4.setCellValue("Cost Plus tax"); + cell8_4.setCellStyle(setWordStyle(workbook,true)); + Cell cell8_5 = row8.createCell(5); + cell8_5.setCellStyle(setWordStyle(workbook,true)); + sheet_Cost.addMergedRegion(new CellRangeAddress(8,8,4,5)); + Cell cell8_6 = row8.createCell(6); + cell8_6.setCellValue("VAT rate %"); + cell8_6.setCellStyle(setWordStyle(workbook,true)); + Cell cell8_7 = row8.createCell(7); + cell8_7.setCellStyle(setWordStyle(workbook,true)); + sheet_Cost.addMergedRegionUnsafe(new CellRangeAddress(8,8,6,7)); + Cell cell8_8 = row8.createCell(8); + cell8_8.setCellStyle(setWordStyle(workbook,true)); + cell8_8.setCellValue("Cost Excluding tax"); + Cell cell8_9 = row8.createCell(9); + cell8_9.setCellStyle(setWordStyle(workbook,true)); + sheet_Cost.addMergedRegionUnsafe(new CellRangeAddress(8,8,8,9)); + + //OTC MRC OTC MRC OTC MRC + //写入10行第5列到第10列的内容 + Cell cell9_4 = row9.createCell(4); + cell9_4.setCellStyle(setWordStyle(workbook,true)); + cell9_4.setCellValue("OTC"); + Cell cell9_5 = row9.createCell(5); + cell9_5.setCellStyle(setWordStyle(workbook,true)); + cell9_5.setCellValue("MRC"); + Cell cell9_6 = row9.createCell(6); + cell9_6.setCellStyle(setWordStyle(workbook,true)); + cell9_6.setCellValue("OTC"); + Cell cell9_7 = row9.createCell(7); + cell9_7.setCellStyle(setWordStyle(workbook,true)); + cell9_7.setCellValue("MRC"); + Cell cell9_8 = row9.createCell(8); + cell9_8.setCellStyle(setWordStyle(workbook,true)); + cell9_8.setCellValue("OTC"); + Cell cell9_9 = row9.createCell(9); + cell9_9.setCellStyle(setWordStyle(workbook,true)); + cell9_9.setCellValue("MRC"); + //写入remark 9行11列 并合并9行10行 + Cell cell8_10 = row8.createCell(10); + cell8_10.setCellStyle(setWordStyle(workbook,true)); + cell8_10.setCellValue("Remark"); + Cell cell9_10 = row9.createCell(10); + cell9_10.setCellStyle(setWordStyle(workbook,true)); + cell9_10.setCellValue(""); + sheet_Cost.addMergedRegion(new CellRangeAddress(8,9,10,10)); + + //开始写入动态表格中的内容 + DemoMapper mapper = Util.getMapper(DemoMapper.class); + List idList = Arrays.asList(split); + + List> maps = mapper.selectAll(idList); + Map>> servicetype = maps.stream() + .collect(Collectors.groupingBy(item -> item.get("servicetype")));//servicetype的种类,以及每个种类的数量 +// System.out.println("servicetype===="+JSON.toJSONString(servicetype)); +// servicetype.forEach((key,value)->{ +// System.out.println(key + " : " + value.size()); +// }); + Map>>> result = new HashMap<>(); + servicetype.forEach((key,value)->{ + Map>> site = value.stream().collect(Collectors.groupingBy(item -> item.get("site"))); + result.put(key,site); + }); + + + List> list = new ArrayList<>(); + System.out.println("result===="+ JSON.toJSONString(result)); + result.forEach((key,value)->{ + AtomicInteger serviceSize = new AtomicInteger(); + value.forEach((itemKey,itemValue)->{ + serviceSize.addAndGet(itemValue.size()); + list.addAll(itemValue); + }); + // System.out.println(key + " : " + serviceSize.get()); + // value.forEach((itemKey,itemValue)->{ + // System.out.println("\t\t" + itemKey + " : " + itemValue.size()); + // }); + }); +// System.out.println(JSON.toJSONString(list)); + + + //从第11行开始插入明细表中的数据 + int fisrtCowCol_0 = 10; + int lastCowCol_1; + double sum4 = 0d; + double sum5 = 0d; + double sum8 = 0d; + double sum9 = 0d; + + int i = 0; + for (int cowNum=10;cowNum<10+ list.size();cowNum++){ + Row row = sheet_Cost.createRow(cowNum); + Map map = list.get(i); + for (int colNum=0;colNum<11;colNum++){ + Cell cell = row.createCell(colNum); + if (colNum==0){ + cell.setCellStyle(setWordStyle(workbook)); + String servicetypeId = String.valueOf(map.get("servicetype")); + String getServiceTypeSql = "select pd_name from uf_pd_base_inf where id = ?"; + RecordSet recordSet = new RecordSet(); + boolean b = recordSet.executeQuery(getServiceTypeSql, servicetypeId); + logger.info("查询serviceType在数据库中的值的sql语句是否查询成功=="+b); + if (recordSet.next()){ + String pd_name = recordSet.getString("pd_name"); + cell.setCellValue(pd_name); + } + }else if (colNum==1){ + String value = String.valueOf(map.get("site")); + if (!value.equals("")){ + cell.setCellStyle(setWordStyle(workbook)); + cell.setCellValue(String.valueOf(map.get("site"))); + }else { + cell.setCellStyle(setNolyBorderStyle(workbook)); + } + }else if (colNum ==2){ + String itemId = String.valueOf(map.get("item"));//Description + String getItemValueSql = "select item from uf_pd_item_inf where id =?";//uf_pd_item_inf + RecordSet recordSet1 = new RecordSet(); + boolean b2 = recordSet1.executeQuery(getItemValueSql, itemId); + logger.info("查询item值sql是否执行成功=" + b2); + String item = "";//从数据库中查询到item的值 + if (recordSet1.next()) { + item = recordSet1.getString("Item"); + } + if (!itemId.equals("")){ + cell.setCellStyle(setWordStyle(workbook)); + cell.setCellValue(item); + }else { + cell.setCellStyle(setNolyBorderStyle(workbook)); + } + }else if (colNum == 3){ + String value = String.valueOf(map.get("servicedescription")); + if (!value.equals("")){ + cell.setCellStyle(setWordStyle(workbook)); +// String valueHtml = stringEscapeUtils.escapeHtml(value);//此处完成国际特殊字符转译 + String newValue = value.replace(" ", " "); + cell.setCellValue(newValue); + + }else { + cell.setCellStyle(setNolyBorderStyle(workbook)); + } + + }else if (colNum== 4){ + try { + String value = String.valueOf(map.get("costplustaxotc"));//costplustaxotc + if (!value.equals("")){ + if ((int)Double.parseDouble(value)!=-1){ + double newValue = Double.parseDouble(value); + sum4 += newValue; + cell.setCellStyle(setCellToNumber(workbook)); + cell.setCellValue(newValue); + }else{ + cell.setCellStyle(setNolyBorderStyle(workbook)); + } + }else { + cell.setCellStyle(setNolyBorderStyle(workbook)); + } + } catch (NumberFormatException e) { + e.printStackTrace(); + } + }else if (colNum==5){ + String value = String.valueOf(map.get("costplustaxmrc"));//costplustaxmrc + if (!value.equals("")){ + if ((int)Double.parseDouble(value)!=-1){ + double newValue = Double.parseDouble(value); + sum5 += newValue; + cell.setCellStyle(setCellToNumber(workbook)); + cell.setCellValue(newValue); + }else{ + cell.setCellStyle(setNolyBorderStyle(workbook)); + } + }else { + cell.setCellStyle(setNolyBorderStyle(workbook)); + } + + }else if (colNum ==6){ + String vatrateotc = String.valueOf(map.get("vatrateotc"));//vatrateotc + double value; + if (!vatrateotc.equals("")){ + if ((int)Double.parseDouble(vatrateotc)!=-1) { + value = Double.parseDouble(vatrateotc); + cell.setCellStyle(setWordStyle(workbook)); + cell.setCellValue((int)(value*100)+"%"); + } else { + cell.setCellStyle(setNolyBorderStyle(workbook)); + } + }else { + cell.setCellStyle(setNolyBorderStyle(workbook)); + } + + }else if (colNum==7){ + String vatratemrc = String.valueOf(map.get("vatratemrc"));//vatratemrc + double value; + if (!vatratemrc.equals("")){ + if ((int)Double.parseDouble(vatratemrc)!=-1) { + value = Double.parseDouble(vatratemrc); + cell.setCellType(CellType.NUMERIC); + cell.setCellStyle(setWordStyle(workbook)); + cell.setCellValue((int)(value*100)+"%"); + } else { + cell.setCellStyle(setNolyBorderStyle(workbook)); + } + }else { + cell.setCellStyle(setNolyBorderStyle(workbook)); + } + }else if (colNum == 8){ + + String value = String.valueOf(map.get("costexcludingtaxotc"));//costexcludingtaxotc + if (!value.equals("")){ + if ((int)Double.parseDouble(value)!=-1) { + double newValue = Double.parseDouble(value); + sum8 += newValue; + cell.setCellType(CellType.NUMERIC); + cell.setCellStyle(setCellToNumber(workbook)); + cell.setCellValue(newValue); + } else { + cell.setCellStyle(setNolyBorderStyle(workbook)); + } + }else { + cell.setCellStyle(setNolyBorderStyle(workbook)); + } + }else if (colNum ==9){ + String value = String.valueOf(map.get("costexcludingtaxmrc"));//costexcludingtaxmrc + if (!value.equals("")){ + if ((int)Double.parseDouble(value)!=-1) { + double newValue = Double.parseDouble(value); + sum9 += newValue; + cell.setCellType(CellType.NUMERIC); + cell.setCellStyle(setCellToNumber(workbook)); + cell.setCellValue(newValue); + } else { + cell.setCellStyle(setNolyBorderStyle(workbook)); + } + }else { + cell.setCellStyle(setNolyBorderStyle(workbook)); + } + + }else{ + String value = String.valueOf(map.get("remark")); + if (!value.equals("")){ + cell.setCellStyle(setWordStyle(workbook)); + cell.setCellValue(value); + }else { + cell.setCellStyle(setNolyBorderStyle(workbook)); + } + + } + } + i++; + } + + //合并第一列单元格 + for (Map.Entry>> entry : servicetype.entrySet()) { + Object key = entry.getKey(); + List> value = entry.getValue(); + System.out.println(key + " : " + value.size()); + int size = value.size(); + lastCowCol_1 = fisrtCowCol_0 + size; + if (size>1){ + sheet_Cost.addMergedRegion(new CellRangeAddress(fisrtCowCol_0, lastCowCol_1-1, 0, 0)); + } + fisrtCowCol_0 = lastCowCol_1; + } + + //合并明细表里面第二列单元格 + + int firstRowCol_1 = 10; + int lastRowCol_1; + for (Map.Entry>>> entry : result.entrySet()) { + Object key = entry.getKey(); + Map>> value = entry.getValue(); + AtomicInteger serviceSize = new AtomicInteger(); + value.forEach((itemKey, itemValue) -> { + serviceSize.addAndGet(itemValue.size()); + list.addAll(itemValue); + }); + System.out.println(key + " : " + serviceSize.get()); + for (Map.Entry>> e : value.entrySet()) { + Object itemKey = e.getKey(); + List> itemValue = e.getValue(); + System.out.println("\t\t" + itemKey + " : " + itemValue.size()); + int size = itemValue.size(); + lastRowCol_1 = size + firstRowCol_1; + if (size>1){ + sheet_Cost.addMergedRegion(new CellRangeAddress(firstRowCol_1, lastRowCol_1-1, 1, 1)); + } + firstRowCol_1 = lastRowCol_1; + } + } + + //写入统计第四列内容 Grand Total + Row row = sheet_Cost.createRow(fisrtCowCol_0); + Cell cellGrandToTal_3 = row.createCell(3); + cellGrandToTal_3.setCellStyle(setNolyWordStyle(workbook,true)); + cellGrandToTal_3.setCellValue("Grand Total"); + + Cell cellGrandToTal_4 = row.createCell(4); + Cell cellGrandToTal_5 = row.createCell(5); + Cell cellGrandToTal_8 = row.createCell(8); + Cell cellGrandToTal_9 = row.createCell(9); + + cellGrandToTal_4.setCellStyle(setNolyWordStyle(workbook,true)); + cellGrandToTal_5.setCellStyle(setNolyWordStyle(workbook,true)); + cellGrandToTal_8.setCellStyle(setNolyWordStyle(workbook,true)); + cellGrandToTal_9.setCellStyle(setNolyWordStyle(workbook,true)); + cellGrandToTal_4.setCellValue(sum4); + cellGrandToTal_5.setCellValue(sum5); + cellGrandToTal_8.setCellValue(sum8); + cellGrandToTal_9.setCellValue(sum9); + + + String[] finalyString = new String[]{ + "Note:", + "1.This price is for budgetary use only and subject to SST's final confirmation;", + "2.OTC stands for one time charge and MRC stands for monthly recurring charge.", + "3. The price is exclusive of any in-house wiring charge which may be needed in customer's building.", + "4. In case the resources of the local telecom operator at the customer premises can not meet the requirement of the Service in such spot, customer will assume the additional engineering cost.", + "5.A PSTN line should be provided by the customer at each location for out-of-band access to the managed CPE;", + "6.Managed CPE contains router installation, configuring, on-going MA (subject to the actual site addresses) and helpdesk support;", + "7. There is no SLA for the performance of Internet access;", + "8. The early termination penalty is 100% of the monthly charges of remaining contract period.", + "9. Customer acknowledges and agrees that SST is entitled to withdraw, revoke or terminate this quotation for convenience at any time upon written notice to Customer due to applicable policy " + + "adjustment which is relevant to SST’s cost led by the authority or any other government agencies, such as tariff increase, even if Customer had received or confirmed this quotation. SST will reissue the quotation with updated OTC and MRC to Customer at its request.", + }; + + int finalyCow = fisrtCowCol_0+2; + int j=0; + for (int cowNum = finalyCow;cowNum获取其他产品uf_other_export表中的数据,渲染到sheet2---Quotation中 + * @Author hcy + * @Date 2023/2/9 15:49 + */ +public class SheetQuotationPOI extends SetCellStylePOI{ + + Logger logger = Util.getLogger(); + + + /** + *

将数据库中的数据放入sheet2---Quotation中

+ * @param workbook,split + * @return void + * @author hcy + * @Date 2023/2/9 15:50 + */ + public void setQuotationSheet(Workbook workbook, String[] split){ + + try { + Sheet sheet_Quotation = workbook.createSheet(); + workbook.setSheetName(1,"Quotation"); + + + String[] tableFiled = new String[]{"Customer Name", "Service Provider", "Contract Term(in months)", "Currency Used", "Issueing Date", "Expiration Date"}; + List systemFiled = new ArrayList<>(); + String sql_other_export_db = "select * from uf_other_export where id = ?"; + RecordSet rs = new RecordSet(); + rs.executeQuery(sql_other_export_db,split[0]); + while (rs.next()){ + String customername = rs.getString("customername"); + systemFiled.add(customername);//Customer Name + systemFiled.add("SST");//Service Provider + systemFiled.add(rs.getString("contractterminmonths"));//Contract Term(in months) + systemFiled.add("RMB");//Currency Used + //系统当前时间 + SimpleDateFormat formatter = new SimpleDateFormat("yyyy-MM-dd"); + Date date = new Date(System.currentTimeMillis()); + systemFiled.add(formatter.format(date));//Issueing Date + //系统当前时间再往后推30天 + Calendar currentdate = Calendar.getInstance(); + //在这里进行加30天(ps:周六周日也算在里边了) + currentdate.add(Calendar.DATE, 30); + //得到最后的时间 + Date finalday = currentdate.getTime(); + systemFiled.add(formatter.format(finalday));//Expiration Date + } + //将1-6行固定值数据放入excel中 + for (int cowNum = 0; cowNum < 6; cowNum++) { + Row row = sheet_Quotation.createRow(cowNum); + Cell cell0col = row.createCell(0); + Cell cell1col = row.createCell(1); + cell0col.setCellStyle(setNolyWordStyle(workbook,true)); + cell0col.setCellValue(tableFiled[cowNum]); + cell1col.setCellStyle(setNolyWordStyle(workbook,true)); + cell1col.setCellValue(systemFiled.get(cowNum)); + } + //将8行数据放入excel中 + //Quotation Breakdown: + Row row7 = sheet_Quotation.createRow(7); + Cell cell7_0 = row7.createCell(0); + cell7_0.setCellStyle(setNolyWordStyle(workbook,true)); + cell7_0.setCellValue("Quotation Breakdown:"); + Cell cell7_1 = row7.createCell(1); + cell7_1.setCellStyle(setNolyWordStyle(workbook,true)); + cell7_1.setCellValue("Quotation Breakdown:"); + sheet_Quotation.addMergedRegion(new CellRangeAddress(7,7,0,1)); + + //将第九行第十行前四列放入excel中并合并单元格 + //1Service Type 2.Site 3.Item 4.Service Description + String[] string8_4 = new String[]{"Service Type","Site","Item","Service Description"}; + Row row8 = sheet_Quotation.createRow(8); + Row row9 = sheet_Quotation.createRow(9); + for (int colNum = 0;colNum<4;colNum++){ + Cell cell8 = row8.createCell(colNum); + cell8.setCellStyle(setWordStyle(workbook,true)); + cell8.setCellValue(string8_4[colNum]); + Cell cell9 = row9.createCell(colNum); + cell9.setCellStyle(setWordStyle(workbook,true)); + cell9.setCellValue(""); + sheet_Quotation.addMergedRegion(new CellRangeAddress(8,9,colNum,colNum)); + } + //Price Plus tax VAT rate % Price Excluding tax + //第九行三个字段并合并字段 5-10列 + Cell cell8_4 = row8.createCell(4); + cell8_4.setCellValue("Price Plus tax"); + cell8_4.setCellStyle(setWordStyle(workbook,true)); + Cell cell8_5 = row8.createCell(5); + cell8_5.setCellStyle(setWordStyle(workbook,true)); + sheet_Quotation.addMergedRegion(new CellRangeAddress(8,8,4,5)); + Cell cell8_6 = row8.createCell(6); + cell8_6.setCellValue("VAT rate %"); + cell8_6.setCellStyle(setWordStyle(workbook,true)); + Cell cell8_7 = row8.createCell(7); + cell8_7.setCellStyle(setWordStyle(workbook,true)); + sheet_Quotation.addMergedRegionUnsafe(new CellRangeAddress(8,8,6,7)); + Cell cell8_8 = row8.createCell(8); + cell8_8.setCellStyle(setWordStyle(workbook,true)); + cell8_8.setCellValue("Price Excluding tax"); + Cell cell8_9 = row8.createCell(9); + cell8_9.setCellStyle(setWordStyle(workbook,true)); + sheet_Quotation.addMergedRegionUnsafe(new CellRangeAddress(8,8,8,9)); + + //OTC MRC OTC MRC OTC MRC + //写入10行第5列到第10列的内容 + Cell cell9_4 = row9.createCell(4); + cell9_4.setCellStyle(setWordStyle(workbook,true)); + cell9_4.setCellValue("OTC"); + Cell cell9_5 = row9.createCell(5); + cell9_5.setCellStyle(setWordStyle(workbook,true)); + cell9_5.setCellValue("MRC"); + Cell cell9_6 = row9.createCell(6); + cell9_6.setCellStyle(setWordStyle(workbook,true)); + cell9_6.setCellValue("OTC"); + Cell cell9_7 = row9.createCell(7); + cell9_7.setCellStyle(setWordStyle(workbook,true)); + cell9_7.setCellValue("MRC"); + Cell cell9_8 = row9.createCell(8); + cell9_8.setCellStyle(setWordStyle(workbook,true)); + cell9_8.setCellValue("OTC"); + Cell cell9_9 = row9.createCell(9); + cell9_9.setCellStyle(setWordStyle(workbook,true)); + cell9_9.setCellValue("MRC"); + //写入remark 9行11列 并合并9行10行 + Cell cell8_10 = row8.createCell(10); + cell8_10.setCellStyle(setWordStyle(workbook,true)); + cell8_10.setCellValue("Remark"); + Cell cell9_10 = row9.createCell(10); + cell9_10.setCellStyle(setWordStyle(workbook,true)); + cell9_10.setCellValue(""); + sheet_Quotation.addMergedRegion(new CellRangeAddress(8,9,10,10)); + + //开始写入动态表格中的内容 + DemoMapper mapper = Util.getMapper(DemoMapper.class); + List idList = Arrays.asList(split); + + List> maps = mapper.selectAll(idList); + Map>> servicetype = maps.stream() + .collect(Collectors.groupingBy(item -> item.get("servicetype")));//servicetype的种类,以及每个种类的数量 +// System.out.println("servicetype===="+JSON.toJSONString(servicetype)); +// servicetype.forEach((key,value)->{ +// System.out.println(key + " : " + value.size()); +// }); + Map>>> result = new HashMap<>(); + servicetype.forEach((key,value)->{ + Map>> site = value.stream().collect(Collectors.groupingBy(item -> item.get("site"))); + result.put(key,site); + }); + + + List> list = new ArrayList<>(); + System.out.println("result===="+ JSON.toJSONString(result)); + result.forEach((key,value)->{ + AtomicInteger serviceSize = new AtomicInteger(); + value.forEach((itemKey,itemValue)->{ + serviceSize.addAndGet(itemValue.size()); + list.addAll(itemValue); + }); + // System.out.println(key + " : " + serviceSize.get()); + // value.forEach((itemKey,itemValue)->{ + // System.out.println("\t\t" + itemKey + " : " + itemValue.size()); + // }); + }); +// System.out.println(JSON.toJSONString(list)); + + + //从第11行开始插入明细表中的数据 + int fisrtCowCol_0 = 10; + int lastCowCol_1; + double sum4 = 0d; + double sum5 = 0d; + double sum8 = 0d; + double sum9 = 0d; + + int i = 0; + for (int cowNum=10;cowNum<10+ list.size();cowNum++){ + Row row = sheet_Quotation.createRow(cowNum); + Map map = list.get(i); + for (int colNum=0;colNum<11;colNum++){ + Cell cell = row.createCell(colNum); + if (colNum==0){ + cell.setCellStyle(setWordStyle(workbook)); + String servicetypeId = String.valueOf(map.get("servicetype")); + String getServiceTypeSql = "select pd_name from uf_pd_base_inf where id = ?"; + RecordSet recordSet = new RecordSet(); + boolean b = recordSet.executeQuery(getServiceTypeSql, servicetypeId); + logger.info("查询serviceType在数据库中的值的sql语句是否查询成功=="+b); + if (recordSet.next()){ + String pd_name = recordSet.getString("pd_name"); + cell.setCellValue(pd_name); + } + }else if (colNum==1){ + String value = String.valueOf(map.get("site")); + if (!value.equals("")){ + cell.setCellStyle(setWordStyle(workbook)); + cell.setCellValue(String.valueOf(map.get("site"))); + }else { + cell.setCellStyle(setNolyBorderStyle(workbook)); + } + }else if (colNum ==2){ + String itemId = String.valueOf(map.get("item"));//Description + String getItemValueSql = "select item from uf_pd_item_inf where id =?";//uf_pd_item_inf + RecordSet recordSet1 = new RecordSet(); + boolean b2 = recordSet1.executeQuery(getItemValueSql, itemId); + logger.info("查询item值sql是否执行成功=" + b2); + String item = "";//从数据库中查询到item的值 + if (recordSet1.next()) { + item = recordSet1.getString("Item"); + } + if (!itemId.equals("")){ + cell.setCellStyle(setWordStyle(workbook)); + cell.setCellValue(item); + }else { + cell.setCellStyle(setNolyBorderStyle(workbook)); + } + }else if (colNum == 3){ + String value = String.valueOf(map.get("servicedescription")); + if (!value.equals("")){ + cell.setCellStyle(setWordStyle(workbook)); +// String valueHtml = stringEscapeUtils.escapeHtml(value);//此处完成国际特殊字符转译 + String newValue = value.replace(" ", " "); + cell.setCellValue(newValue); + }else { + cell.setCellStyle(setNolyBorderStyle(workbook)); + } + + }else if (colNum== 4){ + try { + String value = String.valueOf(map.get("priceplustaxotc")); + if (!value.equals("")){ + if ((int)Double.parseDouble(value)!=-1){ + double newValue = Double.parseDouble(value); + sum4 += newValue; + cell.setCellStyle(setCellToNumber(workbook)); + cell.setCellValue(newValue); + }else{ + cell.setCellStyle(setNolyBorderStyle(workbook)); + } + }else { + cell.setCellStyle(setNolyBorderStyle(workbook)); + } + } catch (NumberFormatException e) { + e.printStackTrace(); + } + }else if (colNum==5){ + String value = String.valueOf(map.get("priceplustaxmrc")); + if (!value.equals("")){ + if ((int)Double.parseDouble(value)!=-1){ + double newValue = Double.parseDouble(value); + sum5 += newValue; + cell.setCellStyle(setCellToNumber(workbook)); + cell.setCellValue(newValue); + }else{ + cell.setCellStyle(setNolyBorderStyle(workbook)); + } + }else { + cell.setCellStyle(setNolyBorderStyle(workbook)); + } + + }else if (colNum ==6){ + String vatrateotc = String.valueOf(map.get("vatrateotc")); + double value; + if (!vatrateotc.equals("")){ + if ((int)Double.parseDouble(vatrateotc)!=-1) { + value = Double.parseDouble(vatrateotc); + cell.setCellStyle(setWordStyle(workbook)); + cell.setCellValue((int)(value*100)+"%"); + } else { + cell.setCellStyle(setNolyBorderStyle(workbook)); + } + }else { + cell.setCellStyle(setNolyBorderStyle(workbook)); + } + + }else if (colNum==7){ + String vatratemrc = String.valueOf(map.get("vatratemrc")); + double value; + if (!vatratemrc.equals("")){ + if ((int)Double.parseDouble(vatratemrc)!=-1) { + value = Double.parseDouble(vatratemrc); + cell.setCellType(CellType.NUMERIC); + cell.setCellStyle(setWordStyle(workbook)); + cell.setCellValue((int)(value*100)+"%"); + } else { + cell.setCellStyle(setNolyBorderStyle(workbook)); + } + }else { + cell.setCellStyle(setNolyBorderStyle(workbook)); + } + }else if (colNum == 8){ + + String value = String.valueOf(map.get("priceexcludingtaxotc")); + if (!value.equals("")){ + if ((int)Double.parseDouble(value)!=-1) { + double newValue = Double.parseDouble(value); + sum8 += newValue; + cell.setCellType(CellType.NUMERIC); + cell.setCellStyle(setCellToNumber(workbook)); + cell.setCellValue(newValue); + } else { + cell.setCellStyle(setNolyBorderStyle(workbook)); + } + }else { + cell.setCellStyle(setNolyBorderStyle(workbook)); + } + }else if (colNum ==9){ + String value = String.valueOf(map.get("priceexcludingtaxmrc")); + if (!value.equals("")){ + if ((int)Double.parseDouble(value)!=-1) { + double newValue = Double.parseDouble(value); + sum9 += newValue; + cell.setCellType(CellType.NUMERIC); + cell.setCellStyle(setCellToNumber(workbook)); + cell.setCellValue(newValue); + } else { + cell.setCellStyle(setNolyBorderStyle(workbook)); + } + }else { + cell.setCellStyle(setNolyBorderStyle(workbook)); + } + + }else{ + String value = String.valueOf(map.get("remark")); + if (!value.equals("")){ + cell.setCellStyle(setWordStyle(workbook)); + cell.setCellValue(value); + }else { + cell.setCellStyle(setNolyBorderStyle(workbook)); + } + + } + } + i++; + } + + //合并第一列单元格 + for (Map.Entry>> entry : servicetype.entrySet()) { + Object key = entry.getKey(); + List> value = entry.getValue(); + System.out.println(key + " : " + value.size()); + int size = value.size(); + lastCowCol_1 = fisrtCowCol_0 + size; + if (size>1){ + sheet_Quotation.addMergedRegion(new CellRangeAddress(fisrtCowCol_0, lastCowCol_1-1, 0, 0)); + } + fisrtCowCol_0 = lastCowCol_1; + } + + //合并明细表里面第二列单元格 + + int firstRowCol_1 = 10; + int lastRowCol_1; + for (Map.Entry>>> entry : result.entrySet()) { + Object key = entry.getKey(); + Map>> value = entry.getValue(); + AtomicInteger serviceSize = new AtomicInteger(); + value.forEach((itemKey, itemValue) -> { + serviceSize.addAndGet(itemValue.size()); + list.addAll(itemValue); + }); + System.out.println(key + " : " + serviceSize.get()); + for (Map.Entry>> e : value.entrySet()) { + Object itemKey = e.getKey(); + List> itemValue = e.getValue(); + System.out.println("\t\t" + itemKey + " : " + itemValue.size()); + int size = itemValue.size(); + lastRowCol_1 = size + firstRowCol_1; + if (size>1){ + sheet_Quotation.addMergedRegion(new CellRangeAddress(firstRowCol_1, lastRowCol_1-1, 1, 1)); + } + firstRowCol_1 = lastRowCol_1; + } + } + + //写入统计第四列内容 Grand Total + Row row = sheet_Quotation.createRow(fisrtCowCol_0); + Cell cellGrandToTal_3 = row.createCell(3); + cellGrandToTal_3.setCellStyle(setNolyWordStyle(workbook,true)); + cellGrandToTal_3.setCellValue("Grand Total"); + + Cell cellGrandToTal_4 = row.createCell(4); + Cell cellGrandToTal_5 = row.createCell(5); + Cell cellGrandToTal_8 = row.createCell(8); + Cell cellGrandToTal_9 = row.createCell(9); + + cellGrandToTal_4.setCellStyle(setNolyWordStyle(workbook,true)); + cellGrandToTal_5.setCellStyle(setNolyWordStyle(workbook,true)); + cellGrandToTal_8.setCellStyle(setNolyWordStyle(workbook,true)); + cellGrandToTal_9.setCellStyle(setNolyWordStyle(workbook,true)); + cellGrandToTal_4.setCellValue(sum4); + cellGrandToTal_5.setCellValue(sum5); + cellGrandToTal_8.setCellValue(sum8); + cellGrandToTal_9.setCellValue(sum9); + + + String[] finalyString = new String[]{ + "Note:", + "1.This price is for budgetary use only and subject to SST's final confirmation;", + "2.OTC stands for one time charge and MRC stands for monthly recurring charge.", + "3. The price is exclusive of any in-house wiring charge which may be needed in customer's building.", + "4. In case the resources of the local telecom operator at the customer premises can not meet the requirement of the Service in such spot, customer will assume the additional engineering cost.", + "5.A PSTN line should be provided by the customer at each location for out-of-band access to the managed CPE;", + "6.Managed CPE contains router installation, configuring, on-going MA (subject to the actual site addresses) and helpdesk support;", + "7. There is no SLA for the performance of Internet access;", + "8. The early termination penalty is 100% of the monthly charges of remaining contract period.", + "9. Customer acknowledges and agrees that SST is entitled to withdraw, revoke or terminate this quotation for convenience at any time upon written notice to Customer due to applicable policy adjustment which is relevant to SST’s cost led by the authority or any other government agencies, such as tariff increase, even if Customer had received or confirmed this quotation. SST will reissue the quotation with updated OTC and MRC to Customer at its request.", + }; + + int finalyCow = fisrtCowCol_0+2; + int j=0; + for (int cowNum = finalyCow;cowNum escapeMap = new HashMap<>(); + + static { + escapeMap.put("&", "&"); + escapeMap.put("<", "<"); + escapeMap.put(">", ">"); + escapeMap.put("\"", """); + escapeMap.put("'", "'"); + escapeMap.put("/", "/"); + escapeMap.put(" "," ");//空格 + } + + public static String escapeHtml(String input) { + if (input == null) { + return null; + } + StringBuilder output = new StringBuilder(); + for (int i = 0; i < input.length(); i++) { + char c = input.charAt(i); + String escape = escapeMap.get(Character.toString(c)); + if (escape != null) { + output.append(escape); + } else { + output.append(c); + } + } + return output.toString(); + } + +} diff --git a/src/main/java/com/api/chaoyang/he/hcy_xintiantongxin/projectorder/controller/CheckProjectNameApi.java b/src/main/java/com/api/chaoyang/he/hcy_xintiantongxin/projectorder/controller/CheckProjectNameApi.java new file mode 100644 index 0000000..7330989 --- /dev/null +++ b/src/main/java/com/api/chaoyang/he/hcy_xintiantongxin/projectorder/controller/CheckProjectNameApi.java @@ -0,0 +1,109 @@ +package com.api.chaoyang.he.hcy_xintiantongxin.projectorder.controller; + +import aiyh.utils.ApiResult; +import aiyh.utils.Util; +import org.apache.log4j.Logger; +import weaver.conn.RecordSet; +import weaver.wechat.util.Utils; + +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.ArrayList; +import java.util.HashMap; +import java.util.List; +import java.util.Map; +import java.util.stream.Collectors; + +/** + *

校验项目报价记录查询中,项目名称是否是同一个

+ * @Author hcy + * @Date 2023/2/17 14:55 + */ +@Path("/projectorder") +public class CheckProjectNameApi { + + private final Logger logger = Util.getLogger(); + /** + *

接收前端传过来的主表id

+ * @param request,response + * @return String + * @author hcy + * @Date 2023/2/17 15:36 + */ + @POST + @Path("/checkProjectNameApi") + @Produces(MediaType.APPLICATION_JSON) + public String checkProjectNameApi(@Context HttpServletRequest request, @Context HttpServletResponse response) { + try { + String ids = request.getParameter("ids"); + RecordSet recordSet = new RecordSet(); + String[] split = ids.split(","); + List> projectLists = new ArrayList<>(); + for (String s : split) { + Map map = new HashMap<>(); + String getDataSql = "select project_name,order_record,servicetype from uf_project_order where id = ?"; + if (recordSet.executeQuery(getDataSql,s)){ + while (recordSet.next()){ + String project_name = recordSet.getString("project_name");//项目名称 + map.put("project_name",project_name); + String order_record = recordSet.getString("order_record");//报价记录 + map.put("order_record",order_record); + String servicetype = Utils.null2String(recordSet.getString("servicetype"));//服务类型 + map.put("servicetype",servicetype); + projectLists.add(map); + } + } + } + + List> lists = new ArrayList<>();//用于存放其他产品中customername,currencyused,contractterminmonths,contractmodel + for (Map projectList : projectLists) { + String project_name = Util.null2String(projectList.get("project_name")); + String order_record = Util.null2String(projectList.get("order_record")); + String servicetype = Utils.null2String(projectList.get("servicetype")); + String getCheckData = "select customername,currencyused,contractterminmonths,contractmodel from uf_other_export where lcid =?"; + boolean b = recordSet.executeQuery(getCheckData, order_record); + logger.info("查询验证信息sql是否执行"+b); + if ((!servicetype.equals("373")) && (!servicetype.equals("384"))){ + Map map = new HashMap<>(); + String customername = recordSet.getString("customername");//系统-客户名 + String currencyused = recordSet.getString("currencyused"); + String contractterminmonths = recordSet.getString("contractterminmonths"); + String contractmodel = recordSet.getString("contractmodel"); + map.put("customername",customername); + map.put("currencyused",currencyused); + map.put("contractterminmonths",contractterminmonths); + map.put("contractmodel",contractmodel); + map.put("project_name",project_name); + lists.add(map); + } + } + logger.info("lists==="+lists); + List> collect1 = lists.stream().distinct().collect(Collectors.toList()); + String checkTag; + String getMsgSql = "select * from uf_cus_dev_config where only_mark = ?"; + recordSet.executeQuery(getMsgSql,"exportProject"); + recordSet.next(); + String msg = recordSet.getString("param_value"); + //校验项目名称是否一致 + if (collect1.size()==1) { + checkTag = "1"; + return ApiResult.success(checkTag); + }else { + checkTag = "0"; + return ApiResult.success(checkTag,msg); + } + } catch (Exception e) { + e.printStackTrace(); + logger.info("异常==="+e); + return ApiResult.success(0,"代码异常"); + } + + + } + +} \ No newline at end of file diff --git a/src/main/java/com/api/chaoyang/he/hcy_xintiantongxin/projectorder/controller/ExportExcelApi.java b/src/main/java/com/api/chaoyang/he/hcy_xintiantongxin/projectorder/controller/ExportExcelApi.java new file mode 100644 index 0000000..a821163 --- /dev/null +++ b/src/main/java/com/api/chaoyang/he/hcy_xintiantongxin/projectorder/controller/ExportExcelApi.java @@ -0,0 +1,294 @@ +package com.api.chaoyang.he.hcy_xintiantongxin.projectorder.controller; + +import aiyh.utils.ApiResult; +import aiyh.utils.Util; + +import com.api.chaoyang.he.hcy_xintiantongxin.projectorder.service.ExportExcelAVPNService; +import com.api.chaoyang.he.hcy_xintiantongxin.projectorder.service.ExportExcelL3NSService; +import com.api.chaoyang.he.hcy_xintiantongxin.projectorder.service.ExportExcelOtherService; +import com.api.chaoyang.he.hcy_xintiantongxin.projectorder.service.impl.ExportExcelAVPNServiceImpl; +import com.api.chaoyang.he.hcy_xintiantongxin.projectorder.service.impl.ExportExcelL3NSServiceImpl; +import com.api.chaoyang.he.hcy_xintiantongxin.projectorder.service.impl.ExportExcelOtherServiceImpl; +import org.apache.log4j.Logger; +import weaver.conn.RecordSet; +import weaver.wechat.util.Utils; + +import javax.servlet.http.HttpServletRequest; +import javax.servlet.http.HttpServletResponse; +import javax.ws.rs.GET; +import javax.ws.rs.Path; +import javax.ws.rs.Produces; +import javax.ws.rs.core.Context; +import javax.ws.rs.core.MediaType; +import javax.ws.rs.core.Response; +import java.text.SimpleDateFormat; +import java.util.*; + +@Path("/export") +public class ExportExcelApi { + + /** + * 用于处理AVPN的excel导出的业务处理 + */ + private final ExportExcelAVPNService exportExcelAVPNService = new ExportExcelAVPNServiceImpl(); + /** + * 用于处理L3NS的excel导出的业务处理 + */ + private final ExportExcelL3NSService exportExcelL3NSService = new ExportExcelL3NSServiceImpl(); + + /** + * 用于处理other的excel导出的业务处理 + */ + private final ExportExcelOtherService exportExcelOtherService = new ExportExcelOtherServiceImpl(); + + /** + * 日志处理 + */ + private final Logger logger = Util.getLogger(); + + + + + @GET + @Path("/exportProjectExcel") + @Produces(MediaType.APPLICATION_OCTET_STREAM) + public Response exportProjectExcel(@Context HttpServletRequest request, @Context HttpServletResponse response) { + + String ids = request.getParameter("ids"); + RecordSet recordSet = new RecordSet(); + String[] split = ids.split(","); + List datas = Arrays.asList(split); + List> listMapData = new ArrayList<>();//用于存放每一条数据的报价记录、serviceType + + for (String data : datas) { + Map map = new HashMap<>(); + String getDataSql = "select * from uf_project_order where id = ?"; + if (recordSet.executeQuery(getDataSql,data)){ + while (recordSet.next()){ + String id = Utils.null2String(recordSet.getString("id"));//id + map.put("id",id); + String servicetype = Utils.null2String(recordSet.getString("servicetype"));//Service Type + map.put("servicetype",servicetype); + String order_record = Utils.null2String(recordSet.getString("order_record"));//报价记录 + map.put("order_record",order_record); + listMapData.add(map); + } + } + + } + String otherIds = ""; + String projectId = ""; + for (Map map : listMapData) { + int servicetype = Integer.parseInt(String.valueOf(map.get("servicetype"))); + //AVPN=373 L3NS=384 + if (servicetype == 373){ + String AVPNIds = String.valueOf(map.get("id")); + String AVPNFileName = getAVPNFileName(AVPNIds); + //表名:uf_avpn_export + //uf_project_order.order_record = uf_avpn_export.lcid + String order_record = Utils.null2String(String.valueOf(map.get("order_record"))); + String get_uf_avpn_export_id = "select id from uf_avpn_export where lcid = ?"; + if (recordSet.executeQuery(get_uf_avpn_export_id,order_record)){ + recordSet.next(); + String id = recordSet.getString("id"); + Response response1 = exportExcelAVPNService.exportExcelAVPN(id,AVPNFileName); + return response1; + } + }else if (servicetype == 384){ + //数据库表名:uf_L3NS_exportt + String L3NSIds = Utils.null2String(map.get("id")); + String L3NSFileName = getL3NSFileName(L3NSIds); + String order_record = Utils.null2String(String.valueOf(map.get("order_record"))); + String get_uf_L3NS_exportt_id = "select id from uf_L3NS_exportt where lcid = ?"; + if (recordSet.executeQuery(get_uf_L3NS_exportt_id,order_record)){ + recordSet.next(); + String id = recordSet.getString("id"); + Response response1 = exportExcelL3NSService.exportExcelL3NSService(id,L3NSFileName); + return response1; + } + }else { //servicetype == other + //数据库表名:uf_other_export + String projectOrderId = Utils.null2String(map.get("id")); + projectId += projectOrderId + ","; + String order_record = Utils.null2String(String.valueOf(map.get("order_record"))); + String get_uf_other_export = "select id from uf_other_export where lcid = ?"; + if (recordSet.executeQuery(get_uf_other_export,order_record)&&recordSet.next()){ + String id = Utils.null2String(recordSet.getString("id")); + if(!id.equals("")){ + otherIds += id +","; + } + } + + } + } + //处理导出other-excel的业务 + if (!otherIds.equals("")){{ + String otherFileName = getOtherFileName(projectId); + Response response1 = exportExcelOtherService.exportExcelOther(otherIds,otherFileName); + return response1; + }} + + return Response.ok(ApiResult.error("出现错误,错误原因: " ), MediaType.TEXT_PLAIN).build(); + + } + + /** + *

获取导出AVPN类型的excel的文件名称

+ * @param AVPNIds:数据id + * @return String + * @author hcy + * @Date 2023/2/28 12:20 + */ + public String getAVPNFileName(String AVPNIds) { + + //“CMR” + customer_name + (select uf_project_inf .project_name from uf_project_inf where id = 导出数据表.project_name) + project_code + 日期(导出的日期) + //CMR + //project_name + String fileName = "SST Discount Request Form"; + RecordSet rs = new RecordSet(); + String getDBFrom_uf_project_order = "select order_record,project_name from uf_project_order where id = ?"; + Map map = new HashMap<>(); + if (rs.executeQuery(getDBFrom_uf_project_order,AVPNIds) && rs.next()){ + String order_record = Utils.null2String(rs.getString("order_record")); + map.put("order_record",order_record); + String project_name = Utils.null2String(rs.getString("project_name"));//项目名称 + map.put("project_name",project_name); + } + String get_customer_name = "select * from uf_avpn_export where lcid = ?"; + if (rs.executeQuery(get_customer_name,map.get("order_record")) && rs.next()){ + String customer_name = Utils.null2String(rs.getString("customer_name")); + if (!customer_name.equals("")){ + fileName += "-"+customer_name;//拼接customer_name + } + } + + String get_project_name = "select project_name,project_code from uf_project_inf where id = ?"; + if (rs.executeQuery(get_project_name,map.get("project_name")) && rs.next()){ + String project_name = Utils.null2String(rs.getString("project_name")); + String project_code = Utils.null2String(rs.getString("project_code")); + if (!project_name.equals("")){ + fileName += "-"+project_name; + } + if (!project_code.equals("")){ + fileName += "-"+project_code; + } + } + + //获取系统当前时间 + String currentTime = this.getCurrentTime(); + fileName += "-"+currentTime+".xlsx"; + //拼接后缀名 + + + return fileName; + } + /** + *

获取导出L3NS类型的excel的文件名称

+ * @param L3NSIds:数据id + * @return String:文件名称 + * @author hcy + * @Date 2023/2/28 12:22 + */ + public String getL3NSFileName(String L3NSIds) { + + //“CMR” + customer_name + (select uf_project_inf .project_name from uf_project_inf where id = 导出数据表.project_name) + project_code + 日期(导出的日期) + //CMR + //project_name + String fileName = "SST Discount Request Form"; + RecordSet rs = new RecordSet(); + String getDBFrom_uf_project_order = "select order_record,project_name from uf_project_order where id = ?"; + Map map = new HashMap<>(); + if (rs.executeQuery(getDBFrom_uf_project_order,L3NSIds) && rs.next()){ + String order_record = Utils.null2String(rs.getString("order_record")); + map.put("order_record",order_record); + String project_name = Utils.null2String(rs.getString("project_name"));//项目名称 + map.put("project_name",project_name); + } + String get_customer_name = "select * from uf_L3NS_exportt where lcid = ?"; + if (rs.executeQuery(get_customer_name,map.get("order_record")) && rs.next()){ + String customer_name = Utils.null2String(rs.getString("customer_name")); + if (!customer_name.equals("")){ + fileName += "-"+customer_name;//拼接customer_name + } + } + + String get_project_name = "select project_name,project_code from uf_project_inf where id = ?"; + if (rs.executeQuery(get_project_name,map.get("project_name")) && rs.next()){ + String project_name = Utils.null2String(rs.getString("project_name")); + String project_code = Utils.null2String(rs.getString("project_code")); + if (!project_name.equals("")){ + fileName += "-"+project_name; + } + if (!project_code.equals("")){ + fileName += "-"+project_code; + } + } + + //获取系统当前时间 + String currentTime = this.getCurrentTime(); + fileName += "-"+currentTime+".xlsx"; + + return fileName; + } + /** + *

获取导出OtherIds类型的excel的文件名称

+ * @param OtherIds:数据id + * @return String:文件名称 + * @author hcy + * @Date 2023/2/28 12:23 + */ + public String getOtherFileName(String OtherIds) { + + //“CMR” + customer_name + (select uf_project_inf .project_name from uf_project_inf where id = 导出数据表.project_name) + project_code + 日期(导出的日期) + //CMR + //project_name + String[] split = OtherIds.split(","); + String fileName = "CMR"; + RecordSet rs = new RecordSet(); + String getDBFrom_uf_project_order = "select order_record,project_name from uf_project_order where id = ?"; + Map map = new HashMap<>(); + if (rs.executeQuery(getDBFrom_uf_project_order,split[0]) && rs.next()){ + String order_record = Utils.null2String(rs.getString("order_record")); + map.put("order_record",order_record); + String project_name = Utils.null2String(rs.getString("project_name"));//项目名称 + map.put("project_name",project_name); + } + String get_customer_name = "select * from uf_other_export where lcid = ?"; + if (rs.executeQuery(get_customer_name,map.get("order_record")) && rs.next()){ + String customer_name = Utils.null2String(rs.getString("customername")); + if (!customer_name.equals("")){ + fileName += "-"+customer_name;//拼接customer_name + } + } + + String get_project_name = "select project_name,project_code from uf_project_inf where id = ?"; + if (rs.executeQuery(get_project_name,map.get("project_name")) && rs.next()){ + String project_name = Utils.null2String(rs.getString("project_name")); + String project_code = Utils.null2String(rs.getString("project_code")); + if (!project_name.equals("")){ + fileName += "-"+project_name; + } + if (!project_code.equals("")){ + fileName += "-"+project_code; + } + } + + //获取系统当前时间 + String currentTime = this.getCurrentTime(); + fileName += "-"+currentTime+".xlsx"; + + return fileName; + } + /** + *

返回系统当前日期时间

+ * @param + * @return String 当前日期 + * @author hcy + */ + public String getCurrentTime(){ + SimpleDateFormat dateFormat = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss"); + Date date = new Date(); + return dateFormat.format(date); + } + +} diff --git a/src/main/java/com/api/chaoyang/he/hcy_xintiantongxin/projectorder/controller/ExportExcelApi_copy.java b/src/main/java/com/api/chaoyang/he/hcy_xintiantongxin/projectorder/controller/ExportExcelApi_copy.java new file mode 100644 index 0000000..025617d --- /dev/null +++ b/src/main/java/com/api/chaoyang/he/hcy_xintiantongxin/projectorder/controller/ExportExcelApi_copy.java @@ -0,0 +1,216 @@ +package com.api.chaoyang.he.hcy_xintiantongxin.projectorder.controller;//package com.api.hcy_xintiantongxin.projectorder.controller; +// +//import aiyh.utils.ApiResult; +//import aiyh.utils.Util; +//import com.api.hcy_xintiantongxin.projectorder.service.ExportExcelAVPNService; +//import com.api.hcy_xintiantongxin.projectorder.service.ExportExcelL3NSService; +//import com.api.hcy_xintiantongxin.projectorder.service.ExportExcelOtherService; +//import com.api.hcy_xintiantongxin.projectorder.service.impl.ExportExcelAVPNServiceImpl; +//import com.api.hcy_xintiantongxin.projectorder.service.impl.ExportExcelL3NSServiceImpl; +//import com.api.hcy_xintiantongxin.projectorder.service.impl.ExportExcelOtherServiceImpl; +//import org.apache.log4j.Logger; +//import weaver.conn.RecordSet; +//import weaver.wechat.util.Utils; +// +//import javax.servlet.http.HttpServletRequest; +//import javax.servlet.http.HttpServletResponse; +//import javax.ws.rs.GET; +//import javax.ws.rs.Path; +//import javax.ws.rs.Produces; +//import javax.ws.rs.core.Context; +//import javax.ws.rs.core.MediaType; +//import javax.ws.rs.core.Response; +//import javax.ws.rs.core.StreamingOutput; +//import java.io.FileInputStream; +//import java.io.IOException; +//import java.io.InputStream; +//import java.io.UnsupportedEncodingException; +//import java.nio.charset.StandardCharsets; +//import java.util.*; +//import java.util.zip.ZipEntry; +//import java.util.zip.ZipOutputStream; +// +//import static com.caucho.server.log.AccessLog.BUFFER_SIZE; +// +//@Path("/export") +//public class ExportExcelApi_copy { +// +//* +// * 用于处理AVPN的excel导出的业务处理 +// +// +// private final ExportExcelAVPNService exportExcelAVPNService = new ExportExcelAVPNServiceImpl(); +//* +// * 用于处理L3NS的excel导出的业务处理 +// +// +// private final ExportExcelL3NSService exportExcelL3NSService = new ExportExcelL3NSServiceImpl(); +// +//* +// * 用于处理other的excel导出的业务处理 +// +// +// private final ExportExcelOtherService exportExcelOtherService = new ExportExcelOtherServiceImpl(); +// +//* +// * 日志处理 +// +// +// private final Logger logger = Util.getLogger(); +// +// +// +// +// @GET +// @Path("/exportProjectExcel") +// @Produces(MediaType.APPLICATION_OCTET_STREAM) +// public Response exportProjectExcel(@Context HttpServletRequest request, @Context HttpServletResponse response) { +// +// String ids = request.getParameter("ids"); +// RecordSet recordSet = new RecordSet(); +// String[] split = ids.split(","); +// List datas = Arrays.asList(split); +// List> listMapData = new ArrayList<>();//用于存放每一条数据的报价记录、serviceType +// +// for (String data : datas) { +// Map map = new HashMap<>(); +// String getDataSql = "select * from uf_project_order where id = ?"; +// if (recordSet.executeQuery(getDataSql,data)){ +// while (recordSet.next()){ +// String servicetype = Utils.null2String(recordSet.getString("servicetype"));//Service Type +// map.put("servicetype",servicetype); +// String order_record = Utils.null2String(recordSet.getString("order_record"));//报价记录 +// map.put("order_record",order_record); +// listMapData.add(map); +// } +// } +// +// } +// +// logger.info("listMapData==="+listMapData); +// StreamingOutput output = outputStream -> { +// ZipOutputStream zipOut = new ZipOutputStream(outputStream); +// String otherIds = ""; +// for (Map map : listMapData) { +// int servicetype = Integer.parseInt(String.valueOf(map.get("servicetype"))); +// //AVPN=373 L3NS=384 +// if (servicetype == 373){ +// //表名:uf_avpn_export +// //uf_project_order.order_record = uf_avpn_export.lcid +// String order_record = Utils.null2String(String.valueOf(map.get("order_record"))); +// String get_uf_avpn_export_id = "select id from uf_avpn_export where lcid = ?"; +// if (recordSet.executeQuery(get_uf_avpn_export_id,order_record)){ +// recordSet.next(); +// String id = recordSet.getString("id"); +// InputStream inputStream = exportExcelAVPNService.exportExcelAVPN(id); +// //文件名称的获取规则为:“CMR” + customer_name + (select uf_project_inf .project_name from uf_project_inf where id = 导出数据表.project_name) + project_code + 日期(导出的日期) +// String filename = exportExcelAVPNService.getFilename(id); +// toZip(inputStream,zipOut,filename); +// } +// }else if (servicetype == 384){ +// //数据库表名:uf_L3NS_exportt +// String order_record = Utils.null2String(String.valueOf(map.get("order_record"))); +// String get_uf_L3NS_exportt_id = "select id from uf_L3NS_exportt where lcid = ?"; +// if (recordSet.executeQuery(get_uf_L3NS_exportt_id,order_record)){ +// recordSet.next(); +// String id = recordSet.getString("id"); +// InputStream inputStream = exportExcelL3NSService.exportExcelL3NSService(id); +// String filename = exportExcelL3NSService.getFilename(id); +// toZip(inputStream,zipOut,filename); +// } +// }else { //servicetype == other +// //数据库表名:uf_other_export +// String order_record = Utils.null2String(String.valueOf(map.get("order_record"))); +// String get_uf_other_export = "select id from uf_other_export where lcid = ?"; +// if (recordSet.executeQuery(get_uf_other_export,order_record)&&recordSet.next()){ +// String id = Utils.null2String(recordSet.getString("id")); +// if(!id.equals("")){ +// otherIds += id +","; +// } +// } +// } +// } +// //处理导出other-excel的业务 +// if (!otherIds.equals("")){{ +// InputStream inputStream = exportExcelOtherService.exportExcelOther(otherIds); +// String filename = exportExcelOtherService.getFilename(otherIds); +// toZip(inputStream,zipOut,filename); +// }} +// //关闭流 +// zipOut.flush(); +// zipOut.close(); +// outputStream.flush(); +// outputStream.close(); +// }; +// +// try { +// return Response.ok(output, MediaType.APPLICATION_OCTET_STREAM).type("application/zip") +// .header("Content-Disposition", "attachment;filename=\"" + +// new String("项目报价记录".getBytes("GBK"), StandardCharsets.ISO_8859_1) + ".zip" + "\"").build(); +// } catch (UnsupportedEncodingException e) { +// e.printStackTrace(); +// return Response.ok(ApiResult.error("出现错误,错误原因:"+e),MediaType.TEXT_PLAIN).build(); +// } +// } +//* +// *

添加压缩文件

+// * @param is,zipOut,fileName +// * @return +// * @author hcy +// * @Date 2023/2/18 16:59 +// +// +// private static void addToZip(InputStream is, ZipOutputStream zipOut, String fileName) { +// try{ +// ZipEntry entry = new ZipEntry(fileName); +// zipOut.putNextEntry(entry); +// int len; +// byte[] buffer = new byte[1024]; +// while ((len = is.read(buffer)) > 0) { +// zipOut.write(buffer, 0, len); +// } +// zipOut.closeEntry(); +// is.close(); +// }catch (Exception e){ +// e.printStackTrace(); +// } +// } +// +// +//* +// *

压缩成ZIP

+// * @param is,out,filename +// * @return +// * @author hcy +// * @Date 2023/2/23 18:29 +// +// +// public static void toZip(InputStream is, ZipOutputStream zos,String fileName) throws RuntimeException { +// long start = System.currentTimeMillis(); +// try { +// byte[] buf = new byte[BUFFER_SIZE]; +// zos.putNextEntry(new ZipEntry(fileName)); +// int len; +// FileInputStream is1 = (FileInputStream) is; +// while ((len = is1.read(buf)) != -1) { +// zos.write(buf, 0, len); +// } +// zos.finish(); +// zos.closeEntry(); +// is1.close(); +// +// long end = System.currentTimeMillis(); +// System.out.println("压缩完成,耗时:" + (end - start) + " ms"); +// } catch (Exception e) { +// throw new RuntimeException("zip error from ZipUtils", e); +// } finally { +// if (zos != null) { +// try { +// zos.close(); +// } catch (IOException e) { +// e.printStackTrace(); +// } +// } +// } +// } +//} diff --git a/src/main/java/com/api/chaoyang/he/hcy_xintiantongxin/projectorder/service/ExportExcelAVPNService.java b/src/main/java/com/api/chaoyang/he/hcy_xintiantongxin/projectorder/service/ExportExcelAVPNService.java new file mode 100644 index 0000000..aa2a8df --- /dev/null +++ b/src/main/java/com/api/chaoyang/he/hcy_xintiantongxin/projectorder/service/ExportExcelAVPNService.java @@ -0,0 +1,20 @@ +package com.api.chaoyang.he.hcy_xintiantongxin.projectorder.service; + +import javax.ws.rs.core.Response; + +/** + *

用于导出AVPN--excel

+ * @Author hcy + * @Date 2023/2/18 14:59 + */ +public interface ExportExcelAVPNService { + + /** + *

传入数据id,查询当前数据id对应的数据库数据,然后插入到excel表单中,返回response

+ * @param ids :数据id,用逗号分割 + * @return Response + * @author hcy + * @Date 2023/2/18 15:04 + */ + public Response exportExcelAVPN(String ids,String AVPNFileName); +} diff --git a/src/main/java/com/api/chaoyang/he/hcy_xintiantongxin/projectorder/service/ExportExcelL3NSService.java b/src/main/java/com/api/chaoyang/he/hcy_xintiantongxin/projectorder/service/ExportExcelL3NSService.java new file mode 100644 index 0000000..2331eb7 --- /dev/null +++ b/src/main/java/com/api/chaoyang/he/hcy_xintiantongxin/projectorder/service/ExportExcelL3NSService.java @@ -0,0 +1,20 @@ +package com.api.chaoyang.he.hcy_xintiantongxin.projectorder.service; + +import javax.ws.rs.core.Response; + +/** + *

用于处理导出L3NS.xlsx业务处理

+ * @Author hcy + * @Date 2023/2/18 15:11 + */ +public interface ExportExcelL3NSService { + + /** + *

传入数据id,查询当前数据id对应的数据库数据,然后插入到excel表单中,返回response

+ * @param ids :数据id,用逗号隔开 + * @return Response + * @author hcy + * @Date 2023/2/18 15:13 + */ + public Response exportExcelL3NSService(String ids,String L3NSFileName); +} diff --git a/src/main/java/com/api/chaoyang/he/hcy_xintiantongxin/projectorder/service/ExportExcelOtherService.java b/src/main/java/com/api/chaoyang/he/hcy_xintiantongxin/projectorder/service/ExportExcelOtherService.java new file mode 100644 index 0000000..3fc526c --- /dev/null +++ b/src/main/java/com/api/chaoyang/he/hcy_xintiantongxin/projectorder/service/ExportExcelOtherService.java @@ -0,0 +1,26 @@ +package com.api.chaoyang.he.hcy_xintiantongxin.projectorder.service; + +import javax.ws.rs.core.Response; + +/** + *

用于导出other--excel业务处理

+ * @Author hcy + * @Date 2023/2/18 14:59 + */ +public interface ExportExcelOtherService { + + /** + *

传入数据id,查询当前数据id对应的数据库数据,然后插入到excel表单中,返回InputStream

+ * @param ids :数据id,用逗号分割 + * @return InputStream + * @author hcy + * @Date 2023/2/18 15:04 + */ + public Response exportExcelOther(String ids,String otherFileName); + + + + + + +} diff --git a/src/main/java/com/api/chaoyang/he/hcy_xintiantongxin/projectorder/service/impl/ExportExcelAVPNServiceImpl.java b/src/main/java/com/api/chaoyang/he/hcy_xintiantongxin/projectorder/service/impl/ExportExcelAVPNServiceImpl.java new file mode 100644 index 0000000..8ad13b8 --- /dev/null +++ b/src/main/java/com/api/chaoyang/he/hcy_xintiantongxin/projectorder/service/impl/ExportExcelAVPNServiceImpl.java @@ -0,0 +1,678 @@ +package com.api.chaoyang.he.hcy_xintiantongxin.projectorder.service.impl; + +import aiyh.utils.Util; + +import com.api.chaoyang.he.hcy_xintiantongxin.projectorder.service.ExportExcelAVPNService; +import org.apache.commons.io.IOUtils; +import org.apache.log4j.Logger; +import org.apache.poi.ss.usermodel.*; +import org.apache.poi.ss.util.CellRangeAddress; +import org.apache.poi.xssf.usermodel.XSSFWorkbook; +import weaver.conn.RecordSet; + +import javax.ws.rs.core.MediaType; +import javax.ws.rs.core.Response; +import javax.ws.rs.core.StreamingOutput; +import java.io.ByteArrayInputStream; +import java.io.ByteArrayOutputStream; +import java.io.InputStream; +import java.nio.charset.StandardCharsets; +import java.text.SimpleDateFormat; +import java.util.*; + +public class ExportExcelAVPNServiceImpl implements ExportExcelAVPNService { + + private final Logger logger = Util.getLogger(); + + public Response exportExcelAVPN(String ids,String AVPNName) { + logger.info("ExportExcelAVPNServiceImpl-----开始"); + Response build = null; + Response.ResponseBuilder header = null; + try { + //查询到 uf_avpn_export AVPN导出表中的一条数据的ids + RecordSet rs = new RecordSet(); + StreamingOutput output = null; + + String sql_AVPN_db = "select * from uf_avpn_export where id = ?"; + rs.executeQuery(sql_AVPN_db, ids); + + //创建一个工作簿 + Workbook workbook = new XSSFWorkbook(); + String[] dbFiled = new String[10]; + String mainId = ""; + + while (rs.next()) { + //查询到uf_avpn_export表的id作为查询明细表的mainid + mainId = rs.getString("id"); + String pd_nameId = rs.getString("pd_name");//uf_pd_base_inf 得到的pd_name是字段的id + RecordSet recordSet = new RecordSet(); + String getPd_nameByIdSql = "select pd_name from uf_pd_base_inf where id =?"; + boolean b1 = recordSet.executeQuery(getPd_nameByIdSql, pd_nameId); + + logger.info("查询pd_namesql语句是否成功==" + b1); + if (recordSet.next()) { + String pd_name = recordSet.getString("pd_name");//查询到pd_name的值 + dbFiled[0] = pd_name; + } + String billing_model = rs.getString("billing_model"); + if (billing_model.equals("0")){ + billing_model = "Assignment Model Billing in China"; + } + dbFiled[1] = billing_model; + String customer_name = rs.getString("customer_name"); + dbFiled[2] = customer_name; + String ecrm_opportunity = rs.getString("ecrm_opportunity"); + dbFiled[3] = ecrm_opportunity; + String igloo = rs.getString("igloo"); + dbFiled[4] = igloo; + String terms = rs.getString("terms"); + dbFiled[5] = terms; + String att_lead_pricer = rs.getString("att_lead_pricer"); + dbFiled[6] = att_lead_pricer; + String requestjustificationoptional = rs.getString("requestjustificationoptional"); + dbFiled[7] = requestjustificationoptional; + String specialrequesttosstoptional = rs.getString("specialrequesttosstoptional"); + dbFiled[8] = specialrequesttosstoptional; + String sst_contact = rs.getString("sst_contact"); + dbFiled[9] = sst_contact; + } + //表单字段 + String[] tableFiled = new String[]{"Service Type", "Billing Model", "Customer Name", "ECRM Opportunity#", "Igloo #", "Contract Term (in months)", "AT&T Lead Pricer", "Request Justification (optional)", "Special Request to SST (Optional)", "SST Contact"}; + //明细表字段 + String[] mergerDetailTableFiled = new String[]{"Site ID", "Description", "Bandwidth", "OTC in RMB", "MRC in RMB"}; + + //创建一个工作表sheet + Sheet sheet = workbook.createSheet(); + workbook.setSheetName(0, "AVPN表单"); + sheet.autoSizeColumn(1, true); + //写入数据 //写入1-11行第一列 第二列数据 + for (int rowNum = 1; rowNum < 11; rowNum++) { + Row row = sheet.createRow(rowNum); + Cell cell0 = row.createCell(0); + cell0.setCellStyle(this.setWordStyle(workbook, true)); + cell0.setCellValue(tableFiled[rowNum - 1]); + Cell cell1 = row.createCell(1); + cell1.setCellStyle(setWordStyle(workbook, true)); + cell1.setCellValue(dbFiled[rowNum - 1]); + } + Row row12 = sheet.createRow(12);//第13行 + Cell cell12_11 = row12.createCell(11); + cell12_11.setCellStyle(setWordStyle(workbook, true)); + cell12_11.setCellValue("Default Assignment Model-Billing in China in RMB"); + Cell cell12_12 = row12.createCell(12); + cell12_12.setCellStyle(setNolyBorderStyle(workbook)); + sheet.addMergedRegion(new CellRangeAddress(12, 12, 11, 12)); + + //设置14行到15行前5列内容 + Row row13 = sheet.createRow(13); + Row row14 = sheet.createRow(14); + for (int colNum = 0; colNum < 5; colNum++) { + Cell cell = row13.createCell(colNum); + cell.setCellStyle(setWordStyle(workbook, true)); + cell.setCellValue(mergerDetailTableFiled[colNum]); + Cell cell1 = row14.createCell(colNum); + cell1.setCellStyle(setWordStyle(workbook, true)); + cell1.setCellValue(mergerDetailTableFiled[colNum]); + sheet.addMergedRegion(new CellRangeAddress(13, 14, colNum, colNum)); + } + + + + //设置14行第六列到第13列的内容 + String[] mergerDetailTableFiled02 = new String[]{"Discount Requested (%)", "Discount SST approved (%)", "Net Price to AT&T Customer", "Royalty to SST without Tax(contra-revenue)"}; + Cell cell13_5 = row13.createCell(5); + cell13_5.setCellStyle(setWordStyle(workbook, true)); + cell13_5.setCellValue(mergerDetailTableFiled02[0]); + Cell cell113_6 = row13.createCell(6); + cell113_6.setCellStyle(setWordStyle(workbook, true)); + cell113_6.setCellValue(mergerDetailTableFiled02[0]); + sheet.addMergedRegion(new CellRangeAddress(13, 13, 5, 6)); + + + Cell cell13_7 = row13.createCell(7); + cell13_7.setCellStyle(setWordStyle(workbook, true)); + cell13_7.setCellValue(mergerDetailTableFiled02[1]); + Cell cell13_8 = row13.createCell(8); + cell13_8.setCellStyle(setWordStyle(workbook, true)); + cell13_8.setCellValue(mergerDetailTableFiled02[1]); + sheet.addMergedRegion(new CellRangeAddress(13, 13, 7, 8)); + + Cell cell13_9 = row13.createCell(9); + cell13_9.setCellStyle(setWordStyle(workbook, true)); + cell13_9.setCellValue(mergerDetailTableFiled02[2]); + Cell cell13_10 = row13.createCell(10); + cell13_10.setCellStyle(setWordStyle(workbook, true)); + cell13_10.setCellValue(mergerDetailTableFiled02[2]); + sheet.addMergedRegion(new CellRangeAddress(13, 13, 9, 10)); + + Cell cell13_11 = row13.createCell(11); + cell13_11.setCellStyle(setWordStyle(workbook, true)); + cell13_11.setCellValue(mergerDetailTableFiled02[3]); + Cell cell13_12 = row13.createCell(12); + cell13_12.setCellStyle(setWordStyle(workbook, true)); + cell13_12.setCellValue(mergerDetailTableFiled02[3]); + sheet.addMergedRegion(new CellRangeAddress(13, 13, 11, 12)); + + + //设置15行第六列到第13列的内容 + String[] mergerDetailTableFiled03 = new String[]{"OTC", "MRC", "OTC", "MRC", "OTC in RMB", "MRC in RMB", "OTC in RMB", "MRC in RMB"}; + for (int colNum = 5; colNum < 13; colNum++) { + Cell cell = row14.createCell(colNum); + for (int num = 0; num < 8; num++) { + cell.setCellStyle(setWordStyle(workbook, true)); + cell.setCellValue(mergerDetailTableFiled03[num]); + } + } + + + List> siteMap = new ArrayList<>();//用来存放site的类型和每个site的状态 + + String getSiteSql = "select site ,count(site) siteNum from uf_avpn_export_dt1 where mainId =? group by site ;"; + RecordSet rs02 = new RecordSet(); + boolean b = rs02.executeQuery(getSiteSql, mainId); + logger.info("查询site,以及site的数量的sql语句===" + b); + + while (rs02.next()) { + HashMap map = new HashMap<>(); + String site = rs02.getString("site"); + String siteNum = rs02.getString("siteNum"); + map.put(site, siteNum); + siteMap.add(map);//将site的类型和每个site的类型的个数放到siteList数组中,用来循环遍历再放入单元格中 + } + int firstCow = 15;//从第15行开始写入明细表,固定死 + int finalyCow = 0; + + + Double sum9 = 0D; + Double sum10 = 0D; + Double sum11 = 0D; + Double sum12 = 0D; + for (Map map : siteMap) { + Set siteKeySet = map.keySet(); + List> detailDateList = new ArrayList(); + int cowLength = 0;//每一个site类型的数据的长度 + for (String s1 : siteKeySet) { + cowLength = Integer.parseInt(map.get(s1));//每一个site类型的数据的长度 + String getDetailDataSql = "select * from uf_avpn_export_dt1 where mainId =? and site = ?"; + rs02.executeQuery(getDetailDataSql, mainId, s1); + while (rs02.next()) { + String site = rs02.getString("site");//Site ID + String itemId = rs02.getString("Item");//Description + String getItemValueSql = "select item from uf_pd_item_inf where id =?"; + RecordSet recordSet1 = new RecordSet(); + boolean b2 = recordSet1.executeQuery(getItemValueSql, itemId); + logger.info("查询item值sql是否执行成功=" + b2); + String item = "";//从数据库中查询到item的值 + if (recordSet1.next()) { + item = recordSet1.getString("Item"); + } + + String categoryId = rs02.getString("Category");//Bandwidth + String getCategoryByIdSql = "select category from uf_pd_category_inf where id = ?"; + boolean b3 = recordSet1.executeQuery(getCategoryByIdSql, categoryId); + logger.info("查询categorySql是否执行成功==" + b3); + String category = ""; + if (recordSet1.next()) { + category = recordSet1.getString("category"); + } + String otc_price = rs02.getString("otc_price");//OTC in RMB + String mrc_price = rs02.getString("mrc_price");//MRC in RMB + String otcdiscountrequest = rs02.getString("otcdiscountrequest");//Discount Requested (%) OTC + String mrcdiscountrequest = rs02.getString("mrcdiscountrequest");//Discount Requested (%) MRC + String otcdiscountapproved = rs02.getString("otcdiscountapproved");//Discount SST approved (%) OTC + String mrcdiscountapproved = rs02.getString("mrcdiscountapproved");//Discount SST approved (%)MRC + String otc_tariff = rs02.getString("otc_tariff");//Net Price to AT&T Customer(OTC in RMB) + String mrc_tariff = rs02.getString("mrc_tariff");//Net Price to AT&T Customer(MRC in RMB) + String otc_scale = rs02.getString("otc_scale");//Royalty to SST without Tax (contra-revenue)(OTC in RMB) + String mrc_scale = rs02.getString("mrc_scale");//Royalty to SST without Tax (contra-revenue)(MRC in RMB) + ArrayList list = new ArrayList<>(); + list.add(site);//list.add(site); + list.add(item); + list.add(category); + list.add(otc_price); + list.add(mrc_price); + list.add(otcdiscountrequest); + list.add(mrcdiscountrequest); + list.add(otcdiscountapproved); + list.add(mrcdiscountapproved); + list.add(otc_tariff); + list.add(mrc_tariff); + list.add(otc_scale); + list.add(mrc_scale); + detailDateList.add(list); + } + } + Double amount9 = 0D;//用来统计每一个site种类的 Grand-Total(RMB) + Double amount10 = 0D; + Double amount11 = 0D; + Double amount12 = 0D; + //得到list类型的数据、有得到每种site类型的数据长度 + //开始向excel中导入明细表中的数据 + int i = 0;//用它来增加detailDateList的下标 + for (int cowNum = firstCow; cowNum < firstCow + cowLength; cowNum++) { + Row row = sheet.createRow(cowNum); + for (int colNum = 0; colNum < 13; colNum++) { + if (colNum == 9) { + String s = String.valueOf(detailDateList.get(i).get(colNum)); + if (s!=""){ + Double value = Double.valueOf(s); + amount9 = Double.valueOf(amount9) + value; + sum9 += value; + Cell cell = row.createCell(colNum); + cell.setCellType(CellType.NUMERIC); + cell.setCellStyle(setCellToNumber(workbook)); + cell.setCellValue(value); + }else{ + Cell cell = row.createCell(colNum); + cell.setCellStyle(setNolyBorderStyle(workbook)); + } + } else if (colNum == 10) { + String s = String.valueOf(detailDateList.get(i).get(colNum)); + if (s!=""){ + Double value = Double.valueOf(s); + amount10 = amount10 + value; + sum10 += value; + + Cell cell = row.createCell(colNum); + cell.setCellType(CellType.NUMERIC); + cell.setCellStyle(setCellToNumber(workbook)); + cell.setCellValue(value); + }else { + Cell cell = row.createCell(colNum); + cell.setCellType(CellType.NUMERIC); + cell.setCellStyle(setCellToNumber(workbook)); + } + } else if (colNum == 11) { + String s = String.valueOf(detailDateList.get(i).get(colNum)); + if (s!=""){ + Double value = Double.valueOf(s); + amount11 = amount11 + value; + sum11 += value; + + Cell cell = row.createCell(colNum); + cell.setCellType(CellType.NUMERIC); + cell.setCellStyle(setCellToNumber(workbook)); + cell.setCellValue(value); + }else { + Cell cell = row.createCell(colNum); + cell.setCellStyle(setNolyBorderStyle(workbook)); + } + } else if (colNum == 12) { + String s = String.valueOf(detailDateList.get(i).get(colNum)); + if (s!=""){ + Double value = Double.valueOf(s); + amount12 = amount12 + value; + sum12 += value; + Cell cell = row.createCell(colNum); + cell.setCellType(CellType.NUMERIC); + cell.setCellStyle(setCellToNumber(workbook)); + cell.setCellValue(value); + }else { + Cell cell = row.createCell(colNum); + cell.setCellStyle(setNolyBorderStyle(workbook)); + } + } + + if (colNum == 5 || colNum == 6 || colNum == 7 || colNum == 8) { + Cell cell = row.createCell(colNum); + String s = String.valueOf(detailDateList.get(i).get(colNum)); + if (s!=""){ + Double value = Double.valueOf(s); + cell.setCellStyle(setWordStyle(workbook)); + cell.setCellValue( (int)(value*100) + "%"); + }else { + cell.setCellStyle(setNolyBorderStyle(workbook)); + } + } + else if (colNum == 0||colNum==1||colNum==2){ + Cell cell = row.createCell(colNum); + String value = String.valueOf(detailDateList.get(i).get(colNum)); + if (value!=""){ + cell.setCellStyle(setWordStyle(workbook)); + cell.setCellValue(value); + }else { + cell.setCellStyle(setNolyBorderStyle(workbook)); + } + + }else if (colNum == 3||colNum==4){ + String s = String.valueOf(detailDateList.get(i).get(colNum)); + if (s!=""){ + Double value = Double.valueOf(s); + Cell cell = row.createCell(colNum); + cell.setCellType(CellType.NUMERIC); + cell.setCellStyle(setCellToNumber(workbook)); + cell.setCellValue(value); + }else { + Cell cell = row.createCell(colNum); + cell.setCellStyle(setNolyBorderStyle(workbook)); + } + } + } + i++; + } + //合并单元格 + int lastCow = firstCow + cowLength; + + if (cowLength > 1) { + sheet.addMergedRegion(new CellRangeAddress(firstCow, lastCow - 1, 0, 0)); + } + //开始写入Sub-Total(RMB) + Row rowSubTotal = sheet.createRow(lastCow); + for (int colNum = 8; colNum < 13; colNum++) { + if (colNum == 8) { + Cell cellSubToTal = rowSubTotal.createCell(colNum); + cellSubToTal.setCellStyle(setNolyWordStyle(workbook, true)); + cellSubToTal.setCellValue("Sub-Total(RMB)"); + } else if (colNum == 9) { + Cell cellSubToTal = rowSubTotal.createCell(colNum); + cellSubToTal.setCellStyle(setNolyWordStyle(workbook, true)); + cellSubToTal.setCellValue(amount9); + } else if (colNum == 10) { + Cell cellSubToTal = rowSubTotal.createCell(colNum); + cellSubToTal.setCellStyle(setNolyWordStyle(workbook, true)); + cellSubToTal.setCellValue(amount10); + } else if (colNum == 11) { + Cell cellSubToTal = rowSubTotal.createCell(colNum); + cellSubToTal.setCellStyle(setNolyWordStyle(workbook, true)); + cellSubToTal.setCellValue(amount11); + } else if (colNum == 12) { + Cell cellSubToTal = rowSubTotal.createCell(colNum); + cellSubToTal.setCellStyle(setNolyWordStyle(workbook, true)); + cellSubToTal.setCellValue(amount12); + } + } + + firstCow = firstCow + cowLength + 1; + finalyCow = firstCow; + }//处理插入数据以及合并单元格 + //处理明细表最后一行的统计情况 + Row row_Grand_Total_RMB = sheet.createRow(finalyCow); + for (int colNum = 8; colNum < 13; colNum++) { + if (colNum == 8) { + Cell cell = row_Grand_Total_RMB.createCell(colNum); + cell.setCellStyle(setNolyWordStyle(workbook,true)); + cell.setCellValue("Grand-Total(RMB)"); + } else if (colNum == 9) { + Cell cell = row_Grand_Total_RMB.createCell(colNum); + cell.setCellStyle(setNolyWordStyle(workbook,true)); + cell.setCellValue(sum9); + } else if (colNum == 10) { + Cell cell = row_Grand_Total_RMB.createCell(colNum); + cell.setCellStyle(setNolyWordStyle(workbook,true)); + cell.setCellValue(sum10); + } else if (colNum == 11) { + Cell cell = row_Grand_Total_RMB.createCell(colNum); + cell.setCellStyle(setNolyWordStyle(workbook,true)); + cell.setCellValue(sum11); + } else if (colNum == 12) { + Cell cell = row_Grand_Total_RMB.createCell(colNum); + cell.setCellStyle(setNolyWordStyle(workbook,true)); + cell.setCellValue(sum12); + } + } + + //输入最下面的固定值 + String[] lastStringLeft = new String[]{ + "Notes:", + "1.This is NOT AT&T Pricing Approval. Forward this SST quote to your Lead ICB Pricer to issue the official Rate Letter", + "2.Access price must be quoted by SST, request SST as \"access provider\" in Igloo. Do NOT use quote from other access providers", + "3.Discount is only applicable to the demand set listed below, any changes in bandwidth/design/billing model, need to re-submit to SST and AT&T Pricer for approval", "" + + "4.Under in-country billing, AT&T must follow the discount% offered by SST. Do NOT deviate from the SST quoted discount.", + "5.SST can support repeatable discount for the same solution design(port/CDR/CPE) of same contract term which was approved already. Local Loop part are non-repeatable.", + "6.For ICB only - Royalty in columns L and M are contra-revenue,ICB to verify if BCRL captured these amount.", + "7.Save this SST approved quote to eCRM (without release) for record.", + "8.The quotation shall be exclusive of any applicable taxes and Customer shall pay all the taxes and charges relating to the payment if any. The VAT rate for CPE and related modules and license are 16%, the rest is 6%.", + "9.Thank you for considering SST, this engagement may be subject to a credit check, we appreciate your cooperation and look forward to doing business in the near future." + }; + int lastLineTag = finalyCow + 2;//固定值Note所在的行 + int k = 0;//用来增加lastStringLeft的下标 + for (int rowNum = lastLineTag; rowNum < lastLineTag + 10; rowNum++) { + Row row = sheet.createRow(rowNum); + Cell cell = row.createCell(0); + cell.setCellStyle(setNolyWordStyle(workbook,true)); + sheet.addMergedRegion(new CellRangeAddress(rowNum, rowNum, 0, 11)); + cell.setCellStyle(setTotalStyle(workbook,"微软雅黑",true,false,HorizontalAlignment.LEFT, VerticalAlignment.CENTER,false)); + cell.setCellValue(lastStringLeft[k]); + k++; + } + sheet.autoSizeColumn(0,true); + sheet.setColumnWidth(0,sheet.getColumnWidth(0)*8/10); + // 设置自动列宽 + for (int num = 1; num < 13; num++) { + sheet.autoSizeColumn(num,true); + sheet.setColumnWidth(num, (sheet.getColumnWidth(num))); + } + + + InputStream inputStream = workbookConvertorStream(workbook); + byte[] bytes = IOUtils.toByteArray(inputStream); + output = outputStream -> { + outputStream.write(bytes); + outputStream.close(); + }; + header = Response.ok(output,MediaType.APPLICATION_OCTET_STREAM) + .type("application/xlsx") + .header("Content-Disposition", + "attachment; filename=\""+ new String(AVPNName.getBytes("GBK"), StandardCharsets.ISO_8859_1)+"\""); + + } catch (Exception e) { + e.printStackTrace(); + logger.error("导出excel错误:" + Util.getErrString(e)); + } + build = header.build(); + return build; + } + + /** + *

设置每个单元格样式:包含字体类型,字体是否加粗,是否包含边框,元素水平方向的位置,元素垂直方向的位置,是否设置元素的数据格式,

+ * @param + * @return + * @author hcy + * @Date 2023/2/13 18:08 + */ + public static CellStyle setTotalStyle(Workbook workbook,String type,boolean setBold,boolean setBorder,HorizontalAlignment horizontalDirection,VerticalAlignment verticalAlignmentDirection ,boolean setDataFormat){ + //new一个cellStyle用于设置每一个单元格样式 + CellStyle cellStyle = workbook.createCellStyle(); + Font font = workbook.createFont(); + //颜色 + font.setColor(Font.COLOR_NORMAL); + //设置字体大小 + font.setFontHeightInPoints((short) 10); + //字体 + font.setFontName(type); + //设置字体是否加粗 + font.setBold(setBold); + //将字体样式渲染cellStyle对象中 + cellStyle.setFont(font); + if (setBorder == true){ + //设置样式对象,这里仅设置了边框属性 + cellStyle.setBorderBottom(BorderStyle.THIN); //下边框 + cellStyle.setBorderLeft(BorderStyle.THIN);//左边框 + cellStyle.setBorderTop(BorderStyle.THIN);//上边框 + cellStyle.setBorderRight(BorderStyle.THIN);//右边框 + } + + //水平居中 + cellStyle.setAlignment(horizontalDirection); + //垂直居中 + cellStyle.setVerticalAlignment(verticalAlignmentDirection); + + //此处设置数据格式 + if(setDataFormat == true){ + DataFormat dataFormat = workbook.createDataFormat(); + cellStyle.setDataFormat(dataFormat.getFormat("0.00_ ")); + } + + return cellStyle; + } + /** + *

返回系统当前日期时间

+ * @param + * @return String 当前日期 + * @author hcy + */ + public String getCurrentTime(){ + SimpleDateFormat dateFormat = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss"); + Date date = new Date(); + String currentTime = dateFormat.format(date); + return currentTime; + } + + /** + * 设置每个单元格的样式,并且加粗字体,设置边框 + * + * @param workbook + * @return + */ + public static CellStyle setWordStyle(Workbook workbook, Boolean setBold) { + // 设置字体 + CellStyle cellStyle = workbook.createCellStyle(); + + //设置样式对象,这里仅设置了边框属性 + + cellStyle.setBorderBottom(BorderStyle.THIN); //下边框 + + cellStyle.setBorderLeft(BorderStyle.THIN);//左边框 + + cellStyle.setBorderTop(BorderStyle.THIN);//上边框 + + cellStyle.setBorderRight(BorderStyle.THIN);//右边框 + + Font font = workbook.createFont(); + //颜色 + font.setColor(Font.COLOR_NORMAL); + //设置字体大小 + font.setFontHeightInPoints((short) 10); + //字体 + font.setFontName("微软雅黑"); + font.setBold(setBold); + cellStyle.setFont(font); + + return cellStyle; + } + + /** + * 只设置字体样式 + * + * @param workbook + * @return + */ + public static CellStyle setWordStyle(Workbook workbook) { + // 设置字体 + CellStyle cellStyle = workbook.createCellStyle(); + //设置样式对象,这里仅设置了边框属性 + cellStyle.setBorderBottom(BorderStyle.THIN); //下边框 + + cellStyle.setBorderLeft(BorderStyle.THIN);//左边框 + + cellStyle.setBorderTop(BorderStyle.THIN);//上边框 + + cellStyle.setBorderRight(BorderStyle.THIN);//右边框 + Font font = workbook.createFont(); + //颜色 + font.setColor(Font.COLOR_NORMAL); + //设置字体大小 + font.setFontHeightInPoints((short) 10); + //字体 + font.setFontName("微软雅黑"); + cellStyle.setFont(font); + return cellStyle; + } + + + /** + * 只设置字体样式 + * + * @param workbook + * @return + */ + public static CellStyle setNolyWordStyle(Workbook workbook,Boolean setBold) { + // 设置字体 + CellStyle cellStyle = workbook.createCellStyle(); + Font font = workbook.createFont(); + //颜色 + font.setColor(Font.COLOR_NORMAL); + //设置字体大小 + font.setFontHeightInPoints((short) 10); + //字体 + font.setFontName("微软雅黑"); + font.setBold(setBold); + cellStyle.setFont(font); + DataFormat dataFormat = workbook.createDataFormat();//此处设置数据格式 + cellStyle.setDataFormat(dataFormat.getFormat("0.00_ ")); + return cellStyle; + } + + /** + * 只设置字体样式 + * + * @param workbook + * @return + */ + public static CellStyle setNolyBorderStyle(Workbook workbook) { + // 设置字体 + CellStyle cellStyle = workbook.createCellStyle(); + //设置样式对象,这里仅设置了边框属性 + cellStyle.setBorderBottom(BorderStyle.THIN); //下边框 + + cellStyle.setBorderLeft(BorderStyle.THIN);//左边框 + + cellStyle.setBorderTop(BorderStyle.THIN);//上边框 + + cellStyle.setBorderRight(BorderStyle.THIN);//右边框 + + return cellStyle; + } + + + + /** + * SXSSFWorkbook 转 InputStream + * @param workbook + * @return + */ + public static InputStream workbookConvertorStream(Workbook workbook) { + InputStream in = null; + try{ + //临时缓冲区 + ByteArrayOutputStream out = new ByteArrayOutputStream(); + //创建临时文件 + workbook.write(out); + byte [] bookByteAry = out.toByteArray(); + in = new ByteArrayInputStream(bookByteAry); + } + catch (Exception e){ + e.printStackTrace(); + } + return in; + } + + /** + * 设置单元格格式为数值型 + * @param workbook + * @return + */ + public static CellStyle setCellToNumber(Workbook workbook){ + // 设置字体 + CellStyle cellStyle = workbook.createCellStyle(); + //设置样式对象,这里仅设置了边框属性 + cellStyle.setBorderBottom(BorderStyle.THIN); //下边框 + + cellStyle.setBorderLeft(BorderStyle.THIN);//左边框 + + cellStyle.setBorderTop(BorderStyle.THIN);//上边框 + + cellStyle.setBorderRight(BorderStyle.THIN);//右边框 + Font font = workbook.createFont(); + //颜色 + font.setColor(Font.COLOR_NORMAL); + //设置字体大小 + font.setFontHeightInPoints((short) 10); + //字体 + font.setFontName("微软雅黑"); + cellStyle.setFont(font); + DataFormat dataFormat = workbook.createDataFormat();//此处设置数据格式 + cellStyle.setDataFormat(dataFormat.getFormat("0.00_ ")); + return cellStyle; + } +} diff --git a/src/main/java/com/api/chaoyang/he/hcy_xintiantongxin/projectorder/service/impl/ExportExcelL3NSServiceImpl.java b/src/main/java/com/api/chaoyang/he/hcy_xintiantongxin/projectorder/service/impl/ExportExcelL3NSServiceImpl.java new file mode 100644 index 0000000..6ff06c2 --- /dev/null +++ b/src/main/java/com/api/chaoyang/he/hcy_xintiantongxin/projectorder/service/impl/ExportExcelL3NSServiceImpl.java @@ -0,0 +1,571 @@ +package com.api.chaoyang.he.hcy_xintiantongxin.projectorder.service.impl; + +import aiyh.utils.Util; + +import com.api.chaoyang.he.hcy_xintiantongxin.projectorder.service.ExportExcelL3NSService; +import org.apache.commons.io.IOUtils; +import org.apache.log4j.Logger; +import org.apache.poi.ss.usermodel.*; +import org.apache.poi.ss.util.CellRangeAddress; +import org.apache.poi.xssf.usermodel.XSSFWorkbook; +import weaver.conn.RecordSet; + +import javax.ws.rs.core.MediaType; +import javax.ws.rs.core.Response; +import javax.ws.rs.core.StreamingOutput; +import java.io.ByteArrayInputStream; +import java.io.ByteArrayOutputStream; +import java.io.IOException; +import java.io.InputStream; +import java.nio.charset.StandardCharsets; +import java.text.SimpleDateFormat; +import java.util.*; + +public class ExportExcelL3NSServiceImpl implements ExportExcelL3NSService { + + private final Logger logger = Util.getLogger(); + + public Response exportExcelL3NSService(String ids,String L3NSFileName) { + Response build = null; + Response.ResponseBuilder header = null; + try { + //查询到 uf_L3NS_exportt AVPN导出表中的一条数据的ids + RecordSet rs = new RecordSet(); + StreamingOutput output = null; + + + String sql_L3NS_db = "select * from uf_L3NS_exportt where id = ?"; + boolean b = rs.executeQuery(sql_L3NS_db, ids); + logger.info("是否查询uf_L3NS_exportt=="+b); + + //创建一个工作簿 + XSSFWorkbook workbook = new XSSFWorkbook(); + String[] dbFiled = new String[13]; + String[] tableFiled = new String[]{"Service Type", "Billing Model", "Customer Name", "ROME Opportunity #", "ROME WR#", "Request Type", "Original SST Order NO", "Request Justification", "Special Request to SST", "Target Service Provision date","ATT Order number:","SST Pre-Sales Contact","Date of SST Approval"}; + + String mainId = ""; + + //得到主表数据,用来写入excel中的固定值 + while (rs.next()) { + //查询到uf_avpn_export表的id作为查询明细表的mainid + mainId = rs.getString("id"); + + + String pd_nameId = rs.getString("pd_name");//uf_pd_base_inf 得到的pd_name是字段的id + RecordSet recordSet = new RecordSet(); + String getPd_nameByIdSql = "select pd_name from uf_pd_base_inf where id =?"; + boolean b1 = recordSet.executeQuery(getPd_nameByIdSql, pd_nameId); + + logger.info("查询pd_namesql语句是否成功==" + b1); + if (recordSet.next()) { + String pd_name = recordSet.getString("pd_name");//查询到pd_name的值 + dbFiled[0] = pd_name; + } + String billingmodel = rs.getString("billingmodel");//Billing Model===billingmodel + if (billingmodel.equals("0")){ + billingmodel = "Custom Subcontract"; + }else if (billingmodel == null){ + billingmodel = ""; + } + dbFiled[1] = billingmodel; + String customer_name = rs.getString("customer_name");//Customer Name===customer_name + dbFiled[2] = customer_name; + String rome_opportunity = rs.getString("rome_opportunity");//ROME Opportunity #====rome_opportunity + dbFiled[3] = rome_opportunity; + String rome_wr = rs.getString("rome_wr");//ROME WR#====rome_wr + dbFiled[4] = rome_wr; + String request_type = rs.getString("request_type");//Request Type====request_type + dbFiled[5] = request_type; + String original_sst_order_no = rs.getString("original_sst_order_no");//Original SST Order NO====original_sst_order_no + dbFiled[6] = original_sst_order_no; + String requestjustificationoptional = rs.getString("requestjustificationoptional");//Request Justification====requestjustificationoptional + dbFiled[7] = requestjustificationoptional; + String specialrequesttosstoptional = rs.getString("specialrequesttosstoptional");//Special Request to SST====specialrequesttosstoptional + dbFiled[8] = specialrequesttosstoptional; + String targetserviceprovisiondate = rs.getString("targetserviceprovisiondate");//Target Service Provision date====targetserviceprovisiondate + dbFiled[9] = targetserviceprovisiondate; + String attordernumber = rs.getString("attordernumber");//ATT Order number:====attordernumber + dbFiled[10] = attordernumber; + String sstpresalescontact = rs.getString("sstpresalescontact");//SST Pre-Sales Contact====sstpresalescontact + dbFiled[11] = sstpresalescontact; + String dateofsstapproval = rs.getString("dateofsstapproval");//Date of SST Approval====dateofsstapproval + dbFiled[12] = dateofsstapproval; + } + + //开始写入固定值 + Sheet sheet = workbook.createSheet(); + workbook.setSheetName(0, "L3NS表单"); + sheet.autoSizeColumn(1, true); + + for (int cowNum=1;cowNum<14;cowNum++){ + Row row = sheet.createRow(cowNum); + Cell cell0 = row.createCell(0); + cell0.setCellStyle(setWordStyle(workbook,true)); + cell0.setCellValue(tableFiled[cowNum-1]); + Cell cell1 = row.createCell(1); + cell1.setCellStyle(setWordStyle(workbook,true)); + cell1.setCellValue(dbFiled[cowNum-1]); + } + + Row row14 = sheet.createRow(14);//写入15行数据 + Cell cell14_0 = row14.createCell(0); + Cell cell114_1 = row14.createCell(1); + cell14_0.setCellStyle(setWordStyle(workbook,true)); + cell14_0.setCellValue("This Quote is valid for 180 days from \"Date of SST approval\""); + cell114_1.setCellStyle(setWordStyle(workbook,true)); + cell114_1.setCellValue("This Quote is valid for 180 days from \"Date of SST approval\""); + sheet.addMergedRegion(new CellRangeAddress(14, 14, 0, 1)); + + +// 写入18行,19行数据 +// Site ID Description Bandwidth OTC in RMB MRC in RMB + String[] detailFileds = new String[]{"Site ID", "Description","Bandwidth", "OTC in RMB", "MRC in RMB"}; + Row row17 = sheet.createRow(17); + Row row18 = sheet.createRow(18); + for (int colNum =0;colNum<5;colNum++){ + Cell cell = row17.createCell(colNum); + cell.setCellStyle(setWordStyle(workbook)); + cell.setCellStyle(setWordStyle(workbook,true)); + cell.setCellValue(detailFileds[colNum]); + } + for (int colNum =0;colNum<5;colNum++){ + Cell cell = row18.createCell(colNum); + cell.setCellStyle(setWordStyle(workbook)); + cell.setCellStyle(setWordStyle(workbook,true)); + cell.setCellValue(detailFileds[colNum]); + } + sheet.addMergedRegion(new CellRangeAddress(17, 18, 0, 0)); + sheet.addMergedRegion(new CellRangeAddress(17, 18, 1, 1)); + sheet.addMergedRegion(new CellRangeAddress(17, 18, 2, 2)); + sheet.addMergedRegion(new CellRangeAddress(17, 18, 3, 3)); + sheet.addMergedRegion(new CellRangeAddress(17, 18, 4, 4)); + +// Relief Requested (%) Relief SST approved (%) Tariff to SST (include VAT) 6-11列 +// OTC MRC OTC MRC OTC in RMB MRC in RMB + String[] detailFileds01 = new String[]{"Relief Requested (%)","Relief Requested (%)","Relief SST approved (%)","Relief SST approved (%)","Tariff to SST (include VAT)","Tariff to SST (include VAT)",""}; + String[] detailFileds02 = new String[]{"OTC","MRC","OTC","MRC","OTC in RMB","MRC in RMB"}; + int i=0; + int j = 0; + for(int colNum=5;colNum<11;colNum++){ + Cell cell17 = row17.createCell(colNum); + Cell cell18 = row18.createCell(colNum); + cell17.setCellValue(detailFileds01[i]); + cell17.setCellStyle(setWordStyle(workbook,true)); +// cell17.setCellStyle(setCellStyleFrame(workbook)); + + cell18.setCellValue(detailFileds02[j]); + cell18.setCellStyle(setWordStyle(workbook,true)); +// cell18.setCellStyle(setCellStyleFrame(workbook)); + i++; + j++; + } + //合并18行,19行 + sheet.addMergedRegion(new CellRangeAddress(17, 17, 5, 6)); + sheet.addMergedRegion(new CellRangeAddress(17, 17, 7, 8)); + sheet.addMergedRegion(new CellRangeAddress(17, 17, 9, 10)); + + + //开始写入20开始一直往下的动态表格中的内容 +// + + List> siteMap = new ArrayList<>();//用来存放site的类型和每个site的状态 + String getSiteSql = "select site ,count(site) siteNum from uf_L3NS_exportt_dt1 where mainId =? group by site ;"; + RecordSet rs02 = new RecordSet(); + boolean b1 = rs02.executeQuery(getSiteSql, mainId); + logger.info("查询site,以及site的数量的sql语句===" + b1); + while (rs02.next()) { + HashMap map = new HashMap<>(); + String site = rs02.getString("site"); + String siteNum = rs02.getString("siteNum"); + map.put(site, siteNum); + siteMap.add(map);//将site的类型和每个site的类型的个数放到siteList数组中,用来循环遍历再放入单元格中 + } + + int firstCow = 19;//从第15行开始写入明细表,固定死 + int finalyCow = 0; + Double sum10 = 0D;//用来统计所有site种类的Grand-Total (RMB) #REF! + Double sum9 = 0D; + for (Map map : siteMap) { + + Set siteKeySet = map.keySet(); + List> detailDateList = new ArrayList(); + int cowLength = 0;//每一个site类型的数据的长度 + for (String s1 : siteKeySet) { + cowLength = Integer.parseInt(map.get(s1));//每一个site类型的数据的长度 + String getDetailDataSql = "select * from uf_L3NS_exportt_dt1 where mainId =? and site = ?"; + rs02.executeQuery(getDetailDataSql,mainId,s1); + while(rs02.next()){ + //明细表数据 + String site = rs02.getString("site");//Site ID + String itemId = rs02.getString("Item");//Description + String getItemValueSql = "select item from uf_pd_item_inf where id =?";//uf_pd_item_inf + RecordSet recordSet1 = new RecordSet(); + boolean b2 = recordSet1.executeQuery(getItemValueSql, itemId); + logger.info("查询item值sql是否执行成功=" + b2); + String item = "";//从数据库中查询到item的值 + if (recordSet1.next()) { + item = recordSet1.getString("Item"); + } + String categoryId = rs02.getString("Category");//Bandwidth + String getCategoryByIdSql = "select category from uf_pd_category_inf where id = ?";//uf_pd_category_inf + boolean b3 = recordSet1.executeQuery(getCategoryByIdSql, categoryId); + logger.info("查询categorySql是否执行成功==" + b3); + String category = ""; + if (recordSet1.next()) { + category = recordSet1.getString("category"); + } + String otc_price = rs02.getString("otc_price");//OTC in RMB + String mrc_price = rs02.getString("mrc_price");//MRC in RMB + String otc_relief_requested = rs02.getString("otc_relief_requested");//Relief Requested (%)OTC + String mrc_relief_requested = rs02.getString("mrc_relief_requested");//Relief Requested (%)MRC + String otc_relief_approved = rs02.getString("otc_relief_approved");//Relief SST approved (%)OTC + String mrc_relief_approved = rs02.getString("mrc_relief_approved");//Relief SST approved (%)MRC + String otc_tariff = rs02.getString("otc_tariff");//Tariff to SST (include VAT)(OTC in RMB) + String mrc_tariff = rs02.getString("mrc_tariff");//Tariff to SST (include VAT)(MRC in RMB) + + ArrayList list = new ArrayList<>(); + list.add(site); + list.add(item); + list.add(category); + list.add(otc_price); + list.add(mrc_price); + list.add(otc_relief_requested); + list.add(mrc_relief_requested); + list.add(otc_relief_approved); + list.add(mrc_relief_approved); + list.add(otc_tariff); + list.add(mrc_tariff); + detailDateList.add(list); + } + } + Double amount10 = 0D;//用来统计每一个site种类的 Sub-Total + Double amount9 = 0D; + + //得到list类型的数据、有得到每种site类型的数据长度 + //开始向excel中导入明细表中的数据 + int k = 0;//用它来增加detailDateList的下标 + for (int cowNum = firstCow; cowNum < firstCow + cowLength; cowNum++) { + Row row = sheet.createRow(cowNum); + for (int colNum = 0; colNum < 11; colNum++) { + if (colNum == 10) { + String s = String.valueOf(detailDateList.get(k).get(colNum)); + if (s != ""){ + Double value = Double.valueOf(s); + amount10 = amount10 + value; + sum10 += value; + Cell cell = row.createCell(colNum); + cell.setCellStyle(setCellToNumber(workbook)); + cell.setCellValue(value); + }else { + Cell cell = row.createCell(colNum); + cell.setCellStyle(setNolyBorderStyle(workbook)); + } + }else if (colNum == 9){ + String s = String.valueOf(detailDateList.get(k).get(colNum)); + if (s != "") { + Double value = Double.valueOf(s); + amount9 = amount9 + value; + sum9 += value; + Cell cell = row.createCell(colNum); + cell.setCellStyle(setCellToNumber(workbook)); + cell.setCellValue(value); + }else { + Cell cell = row.createCell(colNum); + cell.setCellStyle(setNolyBorderStyle(workbook)); + } + } + if (colNum == 5 || colNum == 6 || colNum == 7 || colNum == 8) { + Cell cell = row.createCell(colNum); + String s = String.valueOf(detailDateList.get(k).get(colNum)); + if (s!=""){ + Double value = Double.valueOf(s); + cell.setCellStyle(setWordStyle(workbook)); + cell.setCellValue((int)(value * 100) + "%"); + }else { + cell.setCellStyle(setNolyBorderStyle(workbook)); + } + } else if (colNum == 3 || colNum==4){ + String s = String.valueOf(detailDateList.get(k).get(colNum)); + if (s != ""){ + Double value = Double.valueOf(s); + Cell cell = row.createCell(colNum); + cell.setCellStyle(setCellToNumber(workbook)); + cell.setCellValue(value); + }else { + Cell cell = row.createCell(colNum); + cell.setCellStyle(setNolyBorderStyle(workbook)); + } + } + else if (colNum == 0||colNum==1||colNum==2){ + Cell cell = row.createCell(colNum); + String value = String.valueOf(detailDateList.get(k).get(colNum)); + if (value!=""){ + cell.setCellStyle(setWordStyle(workbook)); + cell.setCellValue(value); + }else { + cell.setCellStyle(setNolyBorderStyle(workbook)); + } + + } + } + k++; + } + //合并单元格 + int lastCow = firstCow + cowLength; + + if (cowLength > 1) { + sheet.addMergedRegion(new CellRangeAddress(firstCow, lastCow - 1, 0, 0)); + } + //开始写入Sub-Total(RMB) + Row rowSubTotal = sheet.createRow(lastCow); + Cell cellSubToTal10 = rowSubTotal.createCell(10); + cellSubToTal10.setCellStyle(setNolyWordStyle(workbook,true)); + cellSubToTal10.setCellValue(amount10); + + Cell cellSubToTal9 = rowSubTotal.createCell(9); + cellSubToTal9.setCellStyle(setNolyWordStyle(workbook,true)); + cellSubToTal9.setCellValue(amount9); + + Cell cellSubToTal8 = rowSubTotal.createCell(8); + cellSubToTal8.setCellStyle(setNolyWordStyle(workbook,true)); + cellSubToTal8.setCellValue("Sub-Total"); + + + firstCow = firstCow + cowLength + 1; + finalyCow = firstCow; + + } + Row rowFinalyCow = sheet.createRow(finalyCow); + Cell cellFinalyCow_10 = rowFinalyCow.createCell(10); + cellFinalyCow_10.setCellStyle(setNolyWordStyle(workbook,true)); + cellFinalyCow_10.setCellValue(sum10); + Cell cellFinalyCow_9 = rowFinalyCow.createCell(9); + cellFinalyCow_9.setCellStyle(setNolyWordStyle(workbook,true)); + cellFinalyCow_9.setCellValue(sum9); + Cell cellFinalyCow_8 = rowFinalyCow.createCell(8); + cellFinalyCow_8.setCellStyle(setNolyWordStyle(workbook,true)); + cellFinalyCow_8.setCellValue("Grand-Total (RMB)"); + + + //输入最下面的固定值 + String[] lastStringright = new String[]{ + "Notes:", + "1.This form should be submitted by Lead ICB via a ROME WR to \"AP Pricing Team\". Do NOT send this direct to SST.", + "2.Fill in full Site Address or at least provide Name of City.", + "3.Tariff relief requested should be calculated by lead ICB. Do not fill in target AVPN discount as \"Relief Requested\".", + "4.VPN Tariff is port base pricing, no charges on COS or COS profile.", + "5.AT&T GAM will place order to SST on no longer than 12 months term for Custom Subcontract, regardless of the commitment term between end customer and AT&T.", + "6.China VAT is irrecoverable cost to AT&T under custom subcontracting billing. Ttariff and Access price listed below is VAT inclusive. ICB has to cater for this cost in deal financials.", + "7.Tariff Relief is only applicable to the demand set listed below, any changes in bandwidth/design/billing model, need to re-submit to SST for approval;", + }; + int lastLineTag = finalyCow + 2;//固定值Note所在的行 + int h=0; + for (int rowNum=lastLineTag;rowNum { + outputStream.write(bytes); + outputStream.close(); + }; + + header = Response.ok(output, MediaType.APPLICATION_OCTET_STREAM) + .type("application/xlsx") + .header("Content-Disposition", + "attachment; filename=\""+ new String(L3NSFileName.getBytes("GBK"), StandardCharsets.ISO_8859_1)+"\""); + } catch (IOException e) { + logger.error("导出excel错误:" + Util.getErrString(e)); + e.printStackTrace(); + } + build = header.build(); + return build; + } + + + + + /** + *

返回系统当前日期时间

+ * @param + * @return String 当前日期 + * @author hcy + */ + public String getCurrentTime(){ + SimpleDateFormat dateFormat = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss"); + Date date = new Date(); + String currentTime = dateFormat.format(date); + return currentTime; + } + /** + * 设置每个单元格的样式,并且加粗字体,设置边框 + * + * @param workbook + * @return + */ + public static CellStyle setWordStyle(Workbook workbook, Boolean setBold) { + // 设置字体 + CellStyle cellStyle = workbook.createCellStyle(); + + //设置样式对象,这里仅设置了边框属性 + + cellStyle.setBorderBottom(BorderStyle.THIN); //下边框 + + cellStyle.setBorderLeft(BorderStyle.THIN);//左边框 + + cellStyle.setBorderTop(BorderStyle.THIN);//上边框 + + cellStyle.setBorderRight(BorderStyle.THIN);//右边框 + + Font font = workbook.createFont(); + //颜色 + font.setColor(Font.COLOR_NORMAL); + //设置字体大小 + font.setFontHeightInPoints((short) 10); + //字体 + font.setFontName("微软雅黑"); + font.setBold(setBold); + cellStyle.setFont(font); + + return cellStyle; + } + + /** + * 只设置字体样式 + * + * @param workbook + * @return + */ + public static CellStyle setWordStyle(Workbook workbook) { + // 设置字体 + CellStyle cellStyle = workbook.createCellStyle(); + //设置样式对象,这里仅设置了边框属性 + cellStyle.setBorderBottom(BorderStyle.THIN); //下边框 + + cellStyle.setBorderLeft(BorderStyle.THIN);//左边框 + + cellStyle.setBorderTop(BorderStyle.THIN);//上边框 + + cellStyle.setBorderRight(BorderStyle.THIN);//右边框 + Font font = workbook.createFont(); + //颜色 + font.setColor(Font.COLOR_NORMAL); + //设置字体大小 + font.setFontHeightInPoints((short) 10); + //字体 + font.setFontName("微软雅黑"); + cellStyle.setFont(font); + return cellStyle; + } + + + /** + * 只设置字体样式 + * + * @param workbook + * @return + */ + public static CellStyle setNolyWordStyle(Workbook workbook,Boolean setBold) { + // 设置字体 + CellStyle cellStyle = workbook.createCellStyle(); + Font font = workbook.createFont(); + //颜色 + font.setColor(Font.COLOR_NORMAL); + //设置字体大小 + font.setFontHeightInPoints((short) 10); + //字体 + font.setFontName("微软雅黑"); + font.setBold(setBold); + cellStyle.setFont(font); + DataFormat dataFormat = workbook.createDataFormat();//此处设置数据格式 + cellStyle.setDataFormat(dataFormat.getFormat("0.00_ ")); + return cellStyle; + } + + /** + * 只设置字体样式 + * + * @param workbook + * @return + */ + public static CellStyle setNolyBorderStyle(Workbook workbook) { + // 设置字体 + CellStyle cellStyle = workbook.createCellStyle(); + //设置样式对象,这里仅设置了边框属性 + cellStyle.setBorderBottom(BorderStyle.THIN); //下边框 + + cellStyle.setBorderLeft(BorderStyle.THIN);//左边框 + + cellStyle.setBorderTop(BorderStyle.THIN);//上边框 + + cellStyle.setBorderRight(BorderStyle.THIN);//右边框 + + return cellStyle; + } + + + + /** + * SXSSFWorkbook 转 InputStream + * @param workbook + * @return + */ + public static InputStream workbookConvertorStream(Workbook workbook) { + InputStream in = null; + try{ + //临时缓冲区 + ByteArrayOutputStream out = new ByteArrayOutputStream(); + //创建临时文件 + workbook.write(out); + byte [] bookByteAry = out.toByteArray(); + in = new ByteArrayInputStream(bookByteAry); + } + catch (Exception e){ + e.printStackTrace(); + } + return in; + } + + /** + * 设置单元格格式为数值型 + * @param workbook + * @return + */ + public static CellStyle setCellToNumber(Workbook workbook){ + // 设置字体 + CellStyle cellStyle = workbook.createCellStyle(); + //设置样式对象,这里仅设置了边框属性 + cellStyle.setBorderBottom(BorderStyle.THIN); //下边框 + + cellStyle.setBorderLeft(BorderStyle.THIN);//左边框 + + cellStyle.setBorderTop(BorderStyle.THIN);//上边框 + + cellStyle.setBorderRight(BorderStyle.THIN);//右边框 + Font font = workbook.createFont(); + //颜色 + font.setColor(Font.COLOR_NORMAL); + //设置字体大小 + font.setFontHeightInPoints((short) 10); + //字体 + font.setFontName("微软雅黑"); + cellStyle.setFont(font); + DataFormat dataFormat = workbook.createDataFormat();//此处设置数据格式 + cellStyle.setDataFormat(dataFormat.getFormat("0.00_ ")); + return cellStyle; + } +} diff --git a/src/main/java/com/api/chaoyang/he/hcy_xintiantongxin/projectorder/service/impl/ExportExcelOtherServiceImpl.java b/src/main/java/com/api/chaoyang/he/hcy_xintiantongxin/projectorder/service/impl/ExportExcelOtherServiceImpl.java new file mode 100644 index 0000000..a5d0d02 --- /dev/null +++ b/src/main/java/com/api/chaoyang/he/hcy_xintiantongxin/projectorder/service/impl/ExportExcelOtherServiceImpl.java @@ -0,0 +1,113 @@ +package com.api.chaoyang.he.hcy_xintiantongxin.projectorder.service.impl; + +import aiyh.utils.Util; + +import com.api.chaoyang.he.hcy_xintiantongxin.exportotherexcel.SheetCMRPOI; +import com.api.chaoyang.he.hcy_xintiantongxin.exportotherexcel.SheetCostPOI; +import com.api.chaoyang.he.hcy_xintiantongxin.exportotherexcel.SheetQuotationPOI; +import com.api.chaoyang.he.hcy_xintiantongxin.projectorder.service.ExportExcelOtherService; +import org.apache.commons.io.IOUtils; +import org.apache.log4j.Logger; +import org.apache.poi.ss.usermodel.Workbook; +import org.apache.poi.xssf.usermodel.XSSFWorkbook; + +import javax.ws.rs.core.MediaType; +import javax.ws.rs.core.Response; +import javax.ws.rs.core.StreamingOutput; +import java.io.ByteArrayInputStream; +import java.io.ByteArrayOutputStream; +import java.io.IOException; +import java.io.InputStream; +import java.nio.charset.StandardCharsets; +import java.text.SimpleDateFormat; +import java.util.Date; + +public class ExportExcelOtherServiceImpl implements ExportExcelOtherService { + + /** + *获取其他产品uf_other_export表中的数据,渲染到sheet1---CMR中 + */ + private final SheetCMRPOI sheetCMRPOI = new SheetCMRPOI(); + /** + * 获取其他产品uf_other_export表中的数据,渲染到sheet2---Quotation中 + */ + private final SheetQuotationPOI sheetQuotationPOI = new SheetQuotationPOI(); + /** + * 获取其他产品uf_other_export表中的数据,渲染到sheet3---Cost中 + */ + private final SheetCostPOI sheetCostPOI = new SheetCostPOI(); + + /** + * 日志 + */ + private final Logger logger = Util.getLogger(); + + public Response exportExcelOther(String ids,String otherFileName) { + logger.info("ExportExcelOtherServiceImpl----开始"); + Response build = null; + Response.ResponseBuilder header = null; + StreamingOutput output = null; + String[] split = ids.split(","); + + //创建一个工作簿 + Workbook workbook = new XSSFWorkbook(); + //创建一个工作表sheet + + sheetCMRPOI.setSheetCMR(workbook,split);//创建第一个sheet1---sheet_CMR,并向sheet中渲染内容 + sheetQuotationPOI.setQuotationSheet(workbook,split);//创建第二个sheet2---sheet_Quotation,并向sheet中渲染内容 + sheetCostPOI.getSheetCost(workbook,split);//创建第三个sheet3---sheet_Cost,并向sheet中渲染内容 + try { + InputStream inputStream = workbookConvertorStream(workbook); + byte[] bytes = IOUtils.toByteArray(inputStream); + output = outputStream -> { + outputStream.write(bytes); + outputStream.close(); + }; + header = Response.ok(output, MediaType.APPLICATION_OCTET_STREAM) + .type("application/xlsx") + .header("Content-Disposition", + "attachment; filename=\""+ new String(otherFileName.getBytes("GBK"), StandardCharsets.ISO_8859_1)+"\""); + + } catch (IOException e) { + e.printStackTrace(); + } + + build = header.build(); + return build; + } + + + + /** + *

返回系统当前日期时间

+ * @param + * @return String 当前日期 + * @author hcy + */ + public String getCurrentTime(){ + SimpleDateFormat dateFormat = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss"); + Date date = new Date(); + return dateFormat.format(date); + } + /** + * SXSSFWorkbook 转 InputStream + * @param workbook + * @return + */ + public static InputStream workbookConvertorStream(Workbook workbook) { + InputStream in = null; + try{ + //临时缓冲区 + ByteArrayOutputStream out = new ByteArrayOutputStream(); + //创建临时文件 + workbook.write(out); + byte [] bookByteAry = out.toByteArray(); + in = new ByteArrayInputStream(bookByteAry); + } + catch (Exception e){ + e.printStackTrace(); + } + return in; + } + +} diff --git a/src/main/java/weaver/chaoyang/he/fengtianfangzhi/djc/tayota/boshoku/action/TbSheetAction.java b/src/main/java/weaver/chaoyang/he/fengtianfangzhi/djc/tayota/boshoku/action/TbSheetAction.java new file mode 100644 index 0000000..65b70e5 --- /dev/null +++ b/src/main/java/weaver/chaoyang/he/fengtianfangzhi/djc/tayota/boshoku/action/TbSheetAction.java @@ -0,0 +1,51 @@ +package weaver.chaoyang.he.fengtianfangzhi.djc.tayota.boshoku.action; + + +import aiyh.utils.Util; +import org.apache.log4j.Logger; +import weaver.chaoyang.he.fengtianfangzhi.djc.tayota.boshoku.service.TbSheetService; +import weaver.chaoyang.he.fengtianfangzhi.djc.tayota.boshoku.service.impl.TbSheetServiceImpl; +import weaver.interfaces.workflow.action.Action; +import weaver.soa.workflow.request.DetailTable; +import weaver.soa.workflow.request.DetailTableInfo; +import weaver.soa.workflow.request.RequestInfo; + +import java.util.List; +import java.util.Map; + +/** + *

询价单调达担当节点后附加操作

+ * @Author jiacheng.deng + * @Date 2022/12/27 14:41 + */ +public class TbSheetAction implements Action { + + private static TbSheetService tbSheetService = new TbSheetServiceImpl(); + private final Logger log = Util.getLogger(); + + /** + *

重写execute,获取明细数据

+ * @param requestInfo + * @return null + * @author jiacheng.deng + */ + @Override + public String execute(RequestInfo requestInfo) { + + try { + DetailTableInfo detailTableInfo = requestInfo.getDetailTableInfo(); + DetailTable[] detailTable = detailTableInfo.getDetailTable(); + List> detailData = tbSheetService.getDetailData(requestInfo); + for (Map stringObjectMap : detailData) { + String chbm = (String) stringObjectMap.get("chbm"); + if("".equals(chbm)){ + tbSheetService.insertTbDetailDataToLedger(stringObjectMap,requestInfo); + } + } + }catch (Exception e){ + log.error(Util.getErrString(e)); + } + + return null; + } +} diff --git a/src/main/java/weaver/chaoyang/he/fengtianfangzhi/djc/tayota/boshoku/dto/TbDetailData.java b/src/main/java/weaver/chaoyang/he/fengtianfangzhi/djc/tayota/boshoku/dto/TbDetailData.java new file mode 100644 index 0000000..6f8f8d6 --- /dev/null +++ b/src/main/java/weaver/chaoyang/he/fengtianfangzhi/djc/tayota/boshoku/dto/TbDetailData.java @@ -0,0 +1,60 @@ +package weaver.chaoyang.he.fengtianfangzhi.djc.tayota.boshoku.dto; + +import lombok.Getter; +import lombok.Setter; +import lombok.ToString; + +@Getter +@Setter +@ToString +public class TbDetailData { + + + /** 存货编码 */ + public String chbm; + + /** 控制明细只读字段 */ + public int kzmxzdzd; + + /** 品类 */ + public int pl; + + /** 品名 */ + public String pm; + + /** 品牌 */ + public String pp; + + /** 规格型号 */ + public String ggxh; + + /** 计量单位 */ + public String jldw; + + /** 存货属性 */ + public int chzx; + + /** 未税单价*/ + public float wsdj; + + /** 税率 */ + public int sl; + + /** 含税单价 */ + public float hsdj; + + /** 供应商 */ + public String gys; + + /** 纳期 */ + public int ddhfqwnqt; + + /** 说明 */ + public String bz1; + + /** 附件*/ + public String fj; + + + +} diff --git a/src/main/java/weaver/chaoyang/he/fengtianfangzhi/djc/tayota/boshoku/mapper/TbSheetMapper.java b/src/main/java/weaver/chaoyang/he/fengtianfangzhi/djc/tayota/boshoku/mapper/TbSheetMapper.java new file mode 100644 index 0000000..afd13b8 --- /dev/null +++ b/src/main/java/weaver/chaoyang/he/fengtianfangzhi/djc/tayota/boshoku/mapper/TbSheetMapper.java @@ -0,0 +1,38 @@ +package weaver.chaoyang.he.fengtianfangzhi.djc.tayota.boshoku.mapper; + +import aiyh.utils.annotation.recordset.Insert; +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; + + +@SqlMapper +public interface TbSheetMapper { + + @Select("select id,chbm,kzmxzdzd,pl,pm,pp,ggxh,jldw,chzx,wsdj,sl,hsdj,ddhfqwnqt,bz1,fj from formtable_main_35_dt1 where mainid = #{mainid}") + List> getDetailDatas(@ParamMapper("mainid") String mainId); + + @Insert("insert into uf_chtz_tbtj(chbm,kzmxzdzd,pl,pm,pp,ggxh,jldw,chzx,wsdj,sl,hsdj,gys,ddhfqwnqt,bz1,fj) values(#{chbm},#{kzmxzdzd},#{pl},#{pm},#{pp},#{ggxh},#{jldw},#{chzx},#{wsdj},#{sl},#{hsdj},#{gys},#{ddhfqwnqt},#{bz1},#{fj})") + void insertDetailData(@ParamMapper("chbm") String chbm, + @ParamMapper("kzmxzdzd") int kzmxzdzd, + @ParamMapper("pl") int pl, + @ParamMapper("pm") String pm, + @ParamMapper("pp") String pp, + @ParamMapper("ggxh") String ggxh, + @ParamMapper("jldw") String jldw, + @ParamMapper("chzx") int chzx, + @ParamMapper("wsdj") float wsdj, + @ParamMapper("sl") int sl, + @ParamMapper("hsdj") float hsdj, + @ParamMapper("gys") String gys, + @ParamMapper("ddhfqwnqt") int ddhfqwnqt, + @ParamMapper("bz1") String bz1, + @ParamMapper("fj") String fj); + + @Select("select id from formtable_main_35 where requestid = #{requestid}") + String getMainTableId(@ParamMapper("requestid") String requestId); + +} diff --git a/src/main/java/weaver/chaoyang/he/fengtianfangzhi/djc/tayota/boshoku/service/TbSheetService.java b/src/main/java/weaver/chaoyang/he/fengtianfangzhi/djc/tayota/boshoku/service/TbSheetService.java new file mode 100644 index 0000000..8a26db6 --- /dev/null +++ b/src/main/java/weaver/chaoyang/he/fengtianfangzhi/djc/tayota/boshoku/service/TbSheetService.java @@ -0,0 +1,17 @@ +package weaver.chaoyang.he.fengtianfangzhi.djc.tayota.boshoku.service; + +import weaver.soa.workflow.request.RequestInfo; + +import java.util.List; +import java.util.Map; + +public interface TbSheetService { + + + List> getDetailData(RequestInfo requestInfo); + + void insertTbDetailDataToLedger(Map stringObjectMap,RequestInfo requestInfo); + + String getMainTableId(String requestId); + +} diff --git a/src/main/java/weaver/chaoyang/he/fengtianfangzhi/djc/tayota/boshoku/service/impl/TbSheetServiceImpl.java b/src/main/java/weaver/chaoyang/he/fengtianfangzhi/djc/tayota/boshoku/service/impl/TbSheetServiceImpl.java new file mode 100644 index 0000000..33688ae --- /dev/null +++ b/src/main/java/weaver/chaoyang/he/fengtianfangzhi/djc/tayota/boshoku/service/impl/TbSheetServiceImpl.java @@ -0,0 +1,111 @@ +package weaver.chaoyang.he.fengtianfangzhi.djc.tayota.boshoku.service.impl; + +import aiyh.utils.Util; +import com.alibaba.fastjson.JSON; +import org.apache.log4j.Logger; +import weaver.chaoyang.he.fengtianfangzhi.djc.tayota.boshoku.mapper.TbSheetMapper; +import weaver.chaoyang.he.fengtianfangzhi.djc.tayota.boshoku.service.TbSheetService; +import weaver.conn.RecordSet; +import weaver.soa.workflow.request.Property; +import weaver.soa.workflow.request.RequestInfo; + +import java.util.ArrayList; +import java.util.HashMap; +import java.util.List; +import java.util.Map; + +/** + *

Action逻辑处理

+ * @Author jiacheng.deng + * @Date 2022/12/27 14:42 + */ +public class TbSheetServiceImpl implements TbSheetService { + private final Logger log = Util.getLogger(); + + TbSheetMapper tbSheetMapper = Util.getMapper(TbSheetMapper.class); + + /** + *

获取明细数据

+ * @param requestInfo + * @return list + * @author jiacheng.deng + */ + @Override + public List> getDetailData(RequestInfo requestInfo) { + + String mainId = this.getMainTableId(requestInfo.getRequestid()); + log.info("main table id is :" + mainId); + List> detailDatas = tbSheetMapper.getDetailDatas(mainId); + log.info(JSON.toJSONString(detailDatas)); + return detailDatas; + } + + + /** + *

将明细数据插入台账

+ * @param stringObjectMap,requestInfo + * @return void + * @author jiacheng.deng + */ + @Override + public void insertTbDetailDataToLedger(Map stringObjectMap,RequestInfo requestInfo) { + + List list = new ArrayList<>(); + + Map wfMainTableInfo = this.getWfMainTableInfo(requestInfo); + String gys = wfMainTableInfo.get("gys"); + log.info("main table gys is :" + gys); + + String chbm = "12345"; + + list.add(chbm); + list.add(stringObjectMap.get("kzmxzdzd")); + list.add(stringObjectMap.get("pl")); + list.add(stringObjectMap.get("pm")); + list.add(stringObjectMap.get("pp")); + list.add(stringObjectMap.get("ggxh")); + list.add(stringObjectMap.get("jldw")); + list.add(stringObjectMap.get("chzx")); + list.add(stringObjectMap.get("wsdj")); + list.add(stringObjectMap.get("sl")); + list.add(stringObjectMap.get("hsdj")); + list.add(gys); + list.add(stringObjectMap.get("ddhfqwnqt")); + list.add(stringObjectMap.get("bz1")); + list.add(stringObjectMap.get("fj")); + + String stringsql = "insert into uf_chtz_tbtj(chbm,kzmxzdzd,pl,pm,pp,ggxh,jldw,chzx,wsdj,sl,hsdj,gys,ddhfqwnqt,bz1,fj) values(?,?,?,?,?,?,?,?,?,?,?,?,?,?,?)"; + RecordSet recordSet = new RecordSet(); + + boolean b = recordSet.executeUpdate(stringsql, list); + + log.info("recordSet是否执行:" + b); + + } + + /** + *

获取主表id

+ * @param requestId + * @return mainTableId + * @author jiacheng.deng + */ + @Override + public String getMainTableId(String requestId) { + String mainTableId = tbSheetMapper.getMainTableId(requestId); + return mainTableId; + } + + /** + * 获取流程主表数据 + * + * @param requestInfo 流程信息对象 + * @return Map key 字段名 value 字段值 + */ + public Map getWfMainTableInfo(RequestInfo requestInfo) { + Map map = new HashMap<>(); + for (Property property : requestInfo.getMainTableInfo().getProperty()) { + map.put(property.getName(), property.getValue()); + } + return map; + } +} diff --git a/src/main/java/weaver/chaoyang/he/fengtianfangzhi/tbsheet/action/TBSheetAction.java b/src/main/java/weaver/chaoyang/he/fengtianfangzhi/tbsheet/action/TBSheetAction.java new file mode 100644 index 0000000..5cae4eb --- /dev/null +++ b/src/main/java/weaver/chaoyang/he/fengtianfangzhi/tbsheet/action/TBSheetAction.java @@ -0,0 +1,130 @@ +package weaver.chaoyang.he.fengtianfangzhi.tbsheet.action; + +import aiyh.utils.Util; +import org.apache.log4j.Logger; +import weaver.conn.RecordSet; +import weaver.interfaces.workflow.action.Action; +import weaver.soa.workflow.request.RequestInfo; + +import java.util.ArrayList; +import java.util.HashMap; +import java.util.List; +import java.util.Map; + +public class TBSheetAction implements Action { + public Logger logger = Util.getLogger(); + @Override + public String execute(RequestInfo requestInfo) { + String requestid = requestInfo.getRequestid(); + String sql = "select id,gys from formtable_main_35 where requestId = ?"; + RecordSet recordSet = new RecordSet(); + boolean b = recordSet.executeQuery(sql, requestid); + logger.info("sql是否执行=="+b); + String mainId = ""; + String gys = ""; + if (recordSet.next()){ + mainId = recordSet.getString("id"); + gys = recordSet.getString("gys"); + } + + String detailSql = "select * from formtable_main_35_dt1 where mainId = ?"; + boolean b1 = recordSet.executeQuery(detailSql, mainId); + logger.info("b1是否执行=="+b1); + + List> listMap = new ArrayList<>(); + while (recordSet.next()){ + Map map = new HashMap<>(); + /** 存货编码 */ + String chbm = recordSet.getString("chbm"); + map.put("chbm",chbm); + /** 控制明细只读字段 */ + String kzmxzdzd = recordSet.getString("kzmxzdzd"); + map.put("kzmxzdzd",kzmxzdzd); + /** 品类 */ + String pl = recordSet.getString("pl"); + map.put("pl",pl); + /** 品名 */ + String pm = recordSet.getString("pm"); + map.put("pm",pm); + /** 品牌 */ + String pp = recordSet.getString("pp"); + map.put("pp",pp); + /** 规格型号 */ + String ggxh = recordSet.getString("ggxh"); + map.put("ggxh",ggxh); + /** 计量单位 */ + String jldw = recordSet.getString("jldw"); + map.put("jldw",jldw); + /** 存货属性 */ + String chzx = recordSet.getString("chzx"); + map.put("chzx",chzx); + /** 未税单价*/ + String wsdj = recordSet.getString("wsdj"); + map.put("wsdj",wsdj); + /** 税率 */ + String sl = recordSet.getString("sl"); + map.put("sl",sl); + /** 含税单价 */ + String hsdj = recordSet.getString("hsdj"); + map.put("hsdj",hsdj); +// /** 供应商 */ +// String gys = recordSet.getString("gys"); +// map.put("gys",gys); + /** 纳期 */ + String ddhfqwnqt = recordSet.getString("ddhfqwnqt"); + map.put("ddhfqwnqt",ddhfqwnqt); + /** 说明 */ + String bz11 = recordSet.getString("bz1"); + map.put("bz11",bz11); + /**附件*/ + String fj = recordSet.getString("fj"); + map.put("fj",fj); + /** + * id + */ + String id = recordSet.getString("id"); + map.put("gys",gys); + map.put("id",id); + + listMap.add(map); + } + + + + for (Map map : listMap) { + String chbm = String.valueOf(map.get("chbm")); + if (chbm.equals("")){ + List list = new ArrayList<>(); + String stringsql = "insert into uf_chtz_tbtj(chbm,pl,pm,pp,ggxh,jldw,chzx,wsdj,sl,hsdj,nqt,gys,sm,fj) values(?,?,?,?,?,?,?,?,?,?,?,?,?,?)"; + + chbm = "12345"; + list.add(chbm);//chbm-chbm + list.add(map.get("pl"));//pl-pl + list.add(map.get("pm"));//pm-pm + list.add(map.get("pp"));//pp-pp + list.add(map.get("ggxh"));//ggxh-ggxh + list.add(map.get("jldw"));//jldw-jldw + list.add(map.get("chzx"));//chzx-chzx + list.add(map.get("wsdj"));//wsdj-wsdj + list.add(map.get("sl"));//sl-sl + list.add(map.get("hsdj"));//hsdj-hsdj + list.add(map.get("qwnq"));//nqt-qwnq + list.add(map.get("gys"));//gys-gys + list.add(map.get("bz1"));//sm-bz1 + list.add(map.get("fj"));//fj-fj + + boolean b2 = recordSet.executeUpdate(stringsql, list); + logger.info("b2是否执行=="+b2); + String id = String.valueOf(map.get("id")); + if (b2){ + String afterSuccessInsertSql = "insert into formtable_main_35_dt1 (chbm) values (?) where id = ?"; + boolean b3 = recordSet.executeUpdate(afterSuccessInsertSql, chbm, id); + logger.info("b3是否执行=="+b3); + } + + } + } + + return Action.FAILURE_AND_CONTINUE; + } +} diff --git a/src/main/java/weaver/chaoyang/he/formmode/customjavacode/modeexpand/ChangeState.java b/src/main/java/weaver/chaoyang/he/formmode/customjavacode/modeexpand/ChangeState.java new file mode 100644 index 0000000..ef8960f --- /dev/null +++ b/src/main/java/weaver/chaoyang/he/formmode/customjavacode/modeexpand/ChangeState.java @@ -0,0 +1,21 @@ +package weaver.chaoyang.he.formmode.customjavacode.modeexpand; + +import aiyh.utils.Util; +import org.apache.log4j.Logger; +import weaver.formmode.customjavacode.AbstractModeExpandJavaCodeNew; + +import java.util.Map; + +public class ChangeState extends AbstractModeExpandJavaCodeNew { + private Logger logger = Util.getLogger(); + @Override + public Map doModeExpand(Map map) { + + for (Map.Entry entry : map.entrySet()) { + String key = entry.getKey(); + Object value = entry.getValue(); + logger.info(key+":"+value); + } + return null; + } +} diff --git a/src/main/java/weaver/chaoyang/he/formmode/customjavacode/modeexpand/ModeExpandTemplate.java b/src/main/java/weaver/chaoyang/he/formmode/customjavacode/modeexpand/ModeExpandTemplate.java new file mode 100644 index 0000000..6630187 --- /dev/null +++ b/src/main/java/weaver/chaoyang/he/formmode/customjavacode/modeexpand/ModeExpandTemplate.java @@ -0,0 +1,43 @@ +package weaver.chaoyang.he.formmode.customjavacode.modeexpand; + +import aiyh.utils.Util; +import org.apache.log4j.Logger; +import weaver.formmode.customjavacode.AbstractModeExpandJavaCodeNew; +import weaver.hrm.User; +import weaver.soa.workflow.request.RequestInfo; + +import java.util.HashMap; +import java.util.Map; + +public class ModeExpandTemplate extends AbstractModeExpandJavaCodeNew { + private Logger logger = Util.getLogger(); + @Override + public Map doModeExpand(Map param) { + +// for (Map.Entry entry : map.entrySet()) { +// String key = entry.getKey(); +// Object value = entry.getValue(); +// logger.info(key+":"+value); +// } +// return null; + + Map result = new HashMap(); + try { + User user = (User)param.get("user"); + int billid = -1;//数据id + int modeid = -1;//模块id + RequestInfo requestInfo = (RequestInfo)param.get("RequestInfo"); + if(requestInfo!=null){ + billid = weaver.general.Util.getIntValue(requestInfo.getRequestid()); + modeid = weaver.general.Util.getIntValue(requestInfo.getWorkflowid()); + if(billid>0&&modeid>0){ + //------请在下面编写业务逻辑代码------ + } + } + } catch (Exception e) { + result.put("errmsg","自定义出错信息"); + result.put("flag", "false"); + } + return result; + } +} diff --git a/src/main/java/weaver/chaoyang/he/formmode/interfaces/impl/CheckFieldTemplate.java b/src/main/java/weaver/chaoyang/he/formmode/interfaces/impl/CheckFieldTemplate.java new file mode 100644 index 0000000..8a07e92 --- /dev/null +++ b/src/main/java/weaver/chaoyang/he/formmode/interfaces/impl/CheckFieldTemplate.java @@ -0,0 +1,70 @@ +package weaver.chaoyang.he.formmode.interfaces.impl; + +import aiyh.utils.Util; +import org.apache.log4j.Logger; +import weaver.file.ExcelParseForPOI; +import weaver.formmode.interfaces.ImportPreInterfaceForPOIAction; +import weaver.hrm.User; +import java.util.List; +import java.util.Map; + +/** + *

在excel导入前校验字段是否符合要求

+ * hcy + * 2023/4/13 8:50 + */ +public class CheckFieldTemplate implements ImportPreInterfaceForPOIAction { + + //日志 + private final Logger logger = Util.getLogger(); + //sql + private final CheckFieldTemplateMapper checkFieldTemplateMap = Util.getMapper(CheckFieldTemplateMapper.class); + + @Override + public String checkImportData(Map param, User user, ExcelParseForPOI excelParse) { + + + //从配置表中查询到数据 + List> configData = checkFieldTemplateMap.getConfigurationTable(); + logger.info("configData===="+configData); + int rowSum = excelParse.getRowSum("1", 2,Util.getIntValue(Util.null2String(configData.get(0).get("bgjtnyl")))); + logger.info("rowSum==="+rowSum); + //获取建模表单里面所有的数据 + List> dbDataMapList = checkFieldTemplateMap.getDBDataMapList(); + logger.info("dbDataMapList===="+dbDataMapList); + + logger.info("dbDataMapList===="+dbDataMapList); + for (Map configDatum : configData) { + int colNum = Util.getIntValue(Util.null2String(configDatum.get("bgjtnyl")));//具体那一列 + logger.info("colNum==="+colNum); + String targetValue = Util.null2String(configDatum.get("dyjmbdjtzdsjkm"));//建模表单中具体哪个字段名称 + logger.info("targetValue==="+targetValue); +// int rowSum = excelParse.getRowSum("1", 100,colNum); + + for (int i = 2; i < 2+rowSum; i++) { + //获取第 sheetindex 个sheet的第row行第col列的单元格的值 (下标都是从1开始) + String value = excelParse.getValue("1", i, colNum); + logger.info("value==="+value); + //开始比较数据是否正确 + boolean compareBool = compareValue(dbDataMapList,value,targetValue); + logger.info("compareBool==="+compareBool); + if (!compareBool) { + //书写校验逻辑 返回空则表示校验通过,否则验证不通过,不允许导入 + return "第"+i+"行第"+(colNum) + "列的数据不符合要求"; + } + } + } + + return ""; + } + + private Boolean compareValue(List> dbDataMapList, String value,String targetValue) { + for (Map map : dbDataMapList) { + String targetValueString = Util.null2String(map.get(targetValue)); + if (targetValueString.equals(value)){ + return true; + } + } + return false; + } +} diff --git a/src/main/java/weaver/chaoyang/he/formmode/interfaces/impl/CheckFieldTemplateMapper.java b/src/main/java/weaver/chaoyang/he/formmode/interfaces/impl/CheckFieldTemplateMapper.java new file mode 100644 index 0000000..81419e3 --- /dev/null +++ b/src/main/java/weaver/chaoyang/he/formmode/interfaces/impl/CheckFieldTemplateMapper.java @@ -0,0 +1,18 @@ +package weaver.chaoyang.he.formmode.interfaces.impl; + +import aiyh.utils.annotation.recordset.Select; +import aiyh.utils.annotation.recordset.SqlMapper; + +import java.util.List; +import java.util.Map; + +@SqlMapper +public interface CheckFieldTemplateMapper { + + @Select("select * from uf_dept") + List> getDBDataMapList(); + + + @Select("select * from uf_exceldrzddypzb_dt1 where mainid in (select id from uf_exceldrzddypzb where wybs = 'fw001') ") + List> getConfigurationTable(); +} diff --git a/src/main/java/weaver/chaoyang/he/formmode/interfaces/impl/ExportFieldTransTemplate.java b/src/main/java/weaver/chaoyang/he/formmode/interfaces/impl/ExportFieldTransTemplate.java new file mode 100644 index 0000000..3668697 --- /dev/null +++ b/src/main/java/weaver/chaoyang/he/formmode/interfaces/impl/ExportFieldTransTemplate.java @@ -0,0 +1,66 @@ +package weaver.chaoyang.he.formmode.interfaces.impl; + +import com.alibaba.fastjson.JSON; +import org.apache.log4j.Logger; +import weaver.conn.RecordSet; +import weaver.formmode.interfaces.ExportFieldTransAction; +import weaver.general.BaseBean; +import weaver.general.Util; +import weaver.hrm.User; + +import java.util.Map; + +/** + *

TBTJ-询价单明细台账更新到处状态

+ * @Author hcy + * @Date 2023/1/31 13:09 + */ +public class ExportFieldTransTemplate implements ExportFieldTransAction{ + + private Logger logger = aiyh.utils.Util.getLogger(); + + @Override + public String getTransValue(Map param,User user) { + // 获取当前登录人员ID + Integer userId = user.getUID(); + logger.info(JSON.toJSONString(param)); + // 获取模块ID + Integer modeId = Util.getIntValue(param.get("modeid").toString()); + //表单id + Integer formId = Util.getIntValue(param.get("formid").toString()); + //当前字段id + String fieldid = Util.null2String(param.get("fieldid")); + //查询列表id + String customid = Util.null2String(param.get("customid")); + //当前列名称(明细表会有d_前缀) + String columnname = Util.null2String(param.get("columnname")); + //当前列数据 + String value = Util.null2String(param.get("value")); + + Map data1 = (Map) param.get("data"); + String mxid = String.valueOf(data1.get("d_mxid")); + String mainId = String.valueOf(data1.get("id")); + this.updateValueIntoDB(mainId,mxid); + //当前行数据 + Map data = (Map) param.get("data"); + + new BaseBean().writeLog(userId+" "+modeId+" "+formId+" "+fieldid+" "+customid+" "+columnname+" "+value); + + return value; + } + + /** + *

update导出状态为已导出

+ * @param mainId,id + * @return + * @author hcy + */ + public void updateValueIntoDB(String mainId,String mxid){ +// String updateSql = "update formtable_main_99_dt1 set dczt = ? where mainId = ? and mxid = ?"; + String updateSql = "update uf_xjdmx_dt1 set dczt = ? where mainId = ? and mxid = ?"; + + RecordSet recordSet = new RecordSet(); + boolean b = recordSet.executeUpdate(updateSql, "0", mainId,mxid); + logger.info("updateSql是否导出=="+b); + } +} diff --git a/src/main/java/weaver/chaoyang/he/formmode/interfaces/impl/ExportFieldTransTemplate_copy.java b/src/main/java/weaver/chaoyang/he/formmode/interfaces/impl/ExportFieldTransTemplate_copy.java new file mode 100644 index 0000000..1ff0d6e --- /dev/null +++ b/src/main/java/weaver/chaoyang/he/formmode/interfaces/impl/ExportFieldTransTemplate_copy.java @@ -0,0 +1,64 @@ +package weaver.chaoyang.he.formmode.interfaces.impl; + +import com.alibaba.fastjson.JSON; +import org.apache.log4j.Logger; +import weaver.conn.RecordSet; +import weaver.formmode.interfaces.ExportFieldTransAction; +import weaver.general.BaseBean; +import weaver.general.Util; +import weaver.hrm.User; + +import java.util.Map; + +/** + *

TBTJ-询价单明细台账更新到处状态

+ * @Author hcy + * @Date 2023/1/31 13:09 + */ +public class ExportFieldTransTemplate_copy implements ExportFieldTransAction{ + + private Logger logger = aiyh.utils.Util.getLogger(); + + @Override + public String getTransValue(Map param,User user) { + // 获取当前登录人员ID + Integer userId = user.getUID(); + logger.info(JSON.toJSONString(param)); + // 获取模块ID + Integer modeId = Util.getIntValue(param.get("modeid").toString()); + //表单id + Integer formId = Util.getIntValue(param.get("formid").toString()); + //当前字段id + String fieldid = Util.null2String(param.get("fieldid")); + //查询列表id + String customid = Util.null2String(param.get("customid")); + //当前列名称(明细表会有d_前缀) + String columnname = Util.null2String(param.get("columnname")); + //当前列数据 + String value = Util.null2String(param.get("value")); + + Map data1 = (Map) param.get("data"); + String mxid = String.valueOf(data1.get("d_mxid")); + String mainId = String.valueOf(data1.get("id")); + this.updateValueIntoDB(mainId,mxid); + //当前行数据 + Map data = (Map) param.get("data"); + + new BaseBean().writeLog(userId+" "+modeId+" "+formId+" "+fieldid+" "+customid+" "+columnname+" "+value); + + return value; + } + + /** + *

update导出状态为已导出

+ * @param mainId,id + * @return + * @author hcy + */ + public void updateValueIntoDB(String mainId,String mxid){ + String updateSql = "update formtable_main_99_dt1 set dczt = ? where mainId = ? and mxid = ?"; + RecordSet recordSet = new RecordSet(); + boolean b = recordSet.executeUpdate(updateSql, "0", mainId,mxid); + logger.info("updateSql是否导出=="+b); + } +} diff --git a/src/main/java/weaver/chaoyang/he/hcy_aphangxin/deleteinvoicenotap/mapper/DeleteInvoiceNotApMapper.java b/src/main/java/weaver/chaoyang/he/hcy_aphangxin/deleteinvoicenotap/mapper/DeleteInvoiceNotApMapper.java new file mode 100644 index 0000000..83cb1f7 --- /dev/null +++ b/src/main/java/weaver/chaoyang/he/hcy_aphangxin/deleteinvoicenotap/mapper/DeleteInvoiceNotApMapper.java @@ -0,0 +1,46 @@ +package weaver.chaoyang.he.hcy_aphangxin.deleteinvoicenotap.mapper; + +import aiyh.utils.annotation.recordset.Delete; +import aiyh.utils.annotation.recordset.Insert; +import aiyh.utils.annotation.recordset.Select; +import aiyh.utils.annotation.recordset.SqlMapper; + +import java.util.List; +import java.util.Map; + +@SqlMapper +public interface DeleteInvoiceNotApMapper { + + /** + *

查询到发票用途为非AP的数据id

+ * @return List 包含数据id的list集合 + * @author hcy + 2023/3/21 10:09 + */ + @Select("select id from fnainvoiceledger where fpyt = 1") + List selectIdByNotAP(); + + /** + *

根据数据id查询到数据

+ * @param idNotAPList id组成的List集合 + * @return List> data + * @author hcy + * 2023/3/21 10:19 + */ + @Select("select * from fnainvoiceledger where id in ($t{idNotAPList})") + List> selectDataById(List idNotAPList); + + @Insert("insert into fnabackup (billingDate,invoiceCode,invoiceNumber," + + "invoiceType,seller,purchaser,invoiceServiceYype,priceWithoutTax,taxRate," + + "tax,taxIncludedPrice,authenticity,reimbursementDate,reimbursePerson,requestId,userid_new," + + "invoiceSource_new,checkcode,status,card_id_new,encrypt_code_new,openid_new,wechatstatus,imageID,purchaserTaxNo," + + "salesTaxNo,entryTime,company_seal,form_type,form_name,kind,ciphertext,category,imageDocId,checkStatus," + + "updateOperate,cloudId,codeConfirm,numberConfirm,receiptor,reviewer,issuer,province,city,travel_tax,fylx," + + "purp,iele,orf,hxjksflr,fpyt) " + + "values (?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?)") + boolean backupData(List dataList); + + @Delete("delete from fnainvoiceledger where id = #{id}") + boolean deleteDataById(String id); + +} diff --git a/src/main/java/weaver/chaoyang/he/hcy_aphangxin/deleteinvoicenotap/service/DeleteInvoiceNotApService.java b/src/main/java/weaver/chaoyang/he/hcy_aphangxin/deleteinvoicenotap/service/DeleteInvoiceNotApService.java new file mode 100644 index 0000000..11499cc --- /dev/null +++ b/src/main/java/weaver/chaoyang/he/hcy_aphangxin/deleteinvoicenotap/service/DeleteInvoiceNotApService.java @@ -0,0 +1,12 @@ +package weaver.chaoyang.he.hcy_aphangxin.deleteinvoicenotap.service; + +import java.util.List; + +public interface DeleteInvoiceNotApService { + + List selectIdByNotAP(); + + boolean backupdate(List idNotAPList); + + boolean deleteDataById(List idNotAPList); +} diff --git a/src/main/java/weaver/chaoyang/he/hcy_aphangxin/deleteinvoicenotap/service/impl/DeleteInvoiceNotApServiceImpl.java b/src/main/java/weaver/chaoyang/he/hcy_aphangxin/deleteinvoicenotap/service/impl/DeleteInvoiceNotApServiceImpl.java new file mode 100644 index 0000000..3a2e369 --- /dev/null +++ b/src/main/java/weaver/chaoyang/he/hcy_aphangxin/deleteinvoicenotap/service/impl/DeleteInvoiceNotApServiceImpl.java @@ -0,0 +1,75 @@ +package weaver.chaoyang.he.hcy_aphangxin.deleteinvoicenotap.service.impl; + +import aiyh.utils.Util; +import weaver.chaoyang.he.hcy_aphangxin.deleteinvoicenotap.mapper.DeleteInvoiceNotApMapper; +import weaver.chaoyang.he.hcy_aphangxin.deleteinvoicenotap.service.DeleteInvoiceNotApService; +import weaver.conn.RecordSet; + +import java.util.ArrayList; +import java.util.List; +import java.util.Map; + +public class DeleteInvoiceNotApServiceImpl implements DeleteInvoiceNotApService { + + + private final DeleteInvoiceNotApMapper deleteInvoiceNotApMapper = Util.getMapper(DeleteInvoiceNotApMapper.class); + @Override + public List selectIdByNotAP() { + return deleteInvoiceNotApMapper.selectIdByNotAP(); + } + + /** + *

备份数据

+ * @param idNotAPList 需要备份数据的id + * @return boolean + * @author hcy + * 2023/3/21 10:15 + */ + public boolean backupdate(List idNotAPList) { + RecordSet recordSet = new RecordSet(); + for (String id : idNotAPList) { + String backupDataSql = "INSERT INTO fnabackup (billingdate,\t\n" + + "invoicenumber,\t\n" + + "invoicecode,\n" + + "invoicetype,\t\n" + + "taxincludedprice,pricewithouttax,\t\n" + + "tax,\n" + + "purchaser,purchasertaxno,\t\n" + + "seller,salestaxno,purp,hxjksflr,checkStatus,status,authenticity,fpyt,taxrate\n" + + ") SELECT \n" + + "billingdate,\t\n" + + "invoicenumber,\t\n" + + "invoicecode,\n" + + "invoicetype,\t\n" + + "taxincludedprice,pricewithouttax,\t\n" + + "tax,\n" + + "purchaser,purchasertaxno,\t\n" + + "seller,salestaxno,purp,hxjksflr,checkStatus,status,authenticity,fpyt,taxrate\n" + + " FROM fnainvoiceledger WHERE id = ?"; + boolean backupBool = recordSet.executeUpdate(backupDataSql, id); + if (!backupBool){ + return false; + } + } + //开始备份数据 + return true; + } + + /** + *

根据数据id删除数据

+ * @param idNotAPList 数据id + * @return boolean 是否删除成功 + * @author hcy + * 2023/3/21 10:31 + */ + public boolean deleteDataById(List idNotAPList) { + for (String id : idNotAPList) { + boolean deleteBool = deleteInvoiceNotApMapper.deleteDataById(id); + if (!deleteBool){ + return false; + } + } + return true; + + } +} diff --git a/src/main/java/weaver/chaoyang/he/hcy_aphangxin/deleteinvoicenotap/web/DeleteInvoiceNotApAction.java b/src/main/java/weaver/chaoyang/he/hcy_aphangxin/deleteinvoicenotap/web/DeleteInvoiceNotApAction.java new file mode 100644 index 0000000..ae63675 --- /dev/null +++ b/src/main/java/weaver/chaoyang/he/hcy_aphangxin/deleteinvoicenotap/web/DeleteInvoiceNotApAction.java @@ -0,0 +1,34 @@ +package weaver.chaoyang.he.hcy_aphangxin.deleteinvoicenotap.web; + +import aiyh.utils.Util; +import org.apache.log4j.Logger; +import weaver.chaoyang.he.hcy_aphangxin.deleteinvoicenotap.service.DeleteInvoiceNotApService; +import weaver.chaoyang.he.hcy_aphangxin.deleteinvoicenotap.service.impl.DeleteInvoiceNotApServiceImpl; +import weaver.interfaces.schedule.BaseCronJob; + +import java.util.List; + +public class DeleteInvoiceNotApAction extends BaseCronJob { + + private final DeleteInvoiceNotApService deleteInvoiceNotAPservice = new DeleteInvoiceNotApServiceImpl(); + + private final Logger logger = Util.getLogger(); + public void execute() { + //第一步查询fnainvoiceledger中每一条数据中发票用途是否为非AP + List idNotAPList = deleteInvoiceNotAPservice.selectIdByNotAP(); + //第二步:根据第一步查询到的数据id,将想要删除的数据备份到fnabackup表中 + boolean backupBool = deleteInvoiceNotAPservice.backupdate(idNotAPList); + logger.info("数据备份是否成功==="+backupBool); + if (backupBool){ + //第三步:开始删除数据 + boolean deleteBool = deleteInvoiceNotAPservice.deleteDataById(idNotAPList); + if (deleteBool){ + logger.info("数据删除成功"); + }else { + logger.info("数据删除失败"); + } + }else{ + logger.info("数据备份失败,请重新操作"); + } + } +} diff --git a/src/main/java/weaver/chaoyang/he/hcy_dingxinjituan/sendfilebyftp/action/SendFileByFTPAction.java b/src/main/java/weaver/chaoyang/he/hcy_dingxinjituan/sendfilebyftp/action/SendFileByFTPAction.java new file mode 100644 index 0000000..b1e18a4 --- /dev/null +++ b/src/main/java/weaver/chaoyang/he/hcy_dingxinjituan/sendfilebyftp/action/SendFileByFTPAction.java @@ -0,0 +1,196 @@ +package weaver.chaoyang.he.hcy_dingxinjituan.sendfilebyftp.action; + +import aiyh.utils.Util; +import org.apache.log4j.Logger; +import weaver.conn.RecordSet; +import weaver.file.ImageFileManager; +import weaver.integration.util.FTPUtil; +import weaver.interfaces.workflow.action.Action; +import weaver.soa.workflow.request.Property; +import weaver.soa.workflow.request.RequestInfo; +import weaver.workflow.request.RequestManager; + + +import java.io.IOException; +import java.io.InputStream; +import java.util.HashMap; +import java.util.Map; + +public class SendFileByFTPAction implements Action { + //ip + private String SERVER; + + //端口号 + private String PORT; + + //用户名 + private String USERNAME; + + //密码 + private String PASSWORD; + + //上传的指定路径 + private String REMOTEDIRAPTH; + + //日志 + private final Logger logger = Util.getLogger(); + + + + public String execute(RequestInfo requestInfo) { + + RequestManager requestManager = requestInfo.getRequestManager(); + //获取当前流程附件的附件流 + Map wfMainTableInfo = this.getWfMainTableInfo(requestInfo); + String fj = wfMainTableInfo.get("fj"); + RecordSet recordSet = new RecordSet(); + String get_imageFiledId = "select imagefileid,imagefilename from DocImageFile where docid = ? order by versionId"; +// Util.selectImageInfoByDocId() + boolean b = recordSet.executeQuery(get_imageFiledId, fj); + logger.info("get_imageFiledId是否执行===" + b); + recordSet.next(); + String imagefileid = Util.null2String(recordSet.getString("imagefileid")); + String imagefilename = Util.null2String(recordSet.getString("imagefilename")); + logger.info("文件imagefileid为==="+imagefileid+" 文件名称为==="+imagefilename); + int imagefileidInt; + if (!"".equals(imagefileid)) { + imagefileidInt = Integer.parseInt(imagefileid); + } else { + requestManager.setMessageid(String.valueOf(System.currentTimeMillis())); + requestManager.setMessagecontent("附件上传ftp系统失败"); + return Action.FAILURE_AND_CONTINUE; + } + InputStream is = ImageFileManager.getInputStreamById(imagefileidInt); + if (is==null){ + logger.info("文件输入流为空"); + }else{ + logger.info("文件输入流不为空"); + } + + try { + if (is!=null){ + this.uploadFile(is, imagefilename); + }else { + logger.info("附件内容为空"); + requestManager.setMessageid(String.valueOf(System.currentTimeMillis())); + requestManager.setMessagecontent("附件内容为空"); + return Action.FAILURE_AND_CONTINUE; + } + } catch (IOException e) { + e.printStackTrace(); + logger.info("附件上传失败,失败原因==="+e); + requestManager.setMessageid(String.valueOf(System.currentTimeMillis())); + requestManager.setMessagecontent("附件上传ftp系统失败"); + return Action.FAILURE_AND_CONTINUE; + } + return Action.SUCCESS; + } + + //上传文件到指定的ftp + public void uploadFile(InputStream inputStream, String fileName) throws IOException { + // FTPFileUtil fileUtil = new FTPFileUtil(SERVER,Util.getIntValue(PORT,21),USERNAME,PASSWORD); + FTPUtil ftpUtil = new FTPUtil(SERVER,Util.getIntValue(PORT,21),USERNAME,PASSWORD); + + if(!ftpUtil.isConnected()){ + ftpUtil.login(); + } + + boolean isSuccess = ftpUtil.uploadFile(inputStream,fileName,REMOTEDIRAPTH); + + if (isSuccess) { + logger.info("文件上传成功"); + }else{ + logger.info("文件上传失败"); + } + ftpUtil.logout(); +/* + FTPClient ftpClient = new FTPClient(); + ftpClient.setControlEncoding("GBK"); + + try { + ftpClient.connect(SERVER, Integer.parseInt(PORT)); + ftpClient.login(USERNAME, PASSWORD); + ftpClient.enterLocalPassiveMode(); + ftpClient.setFileType(FTP.BINARY_FILE_TYPE); + + ftpClient.changeWorkingDirectory("/"+REMOTEDIRAPTH); + boolean success = ftpClient.storeFile(fileName, inputStream); + logger.info("文件上传是否成功==="+success); + if (success) { + logger.info("文件上传成功"); + } + } catch (Exception e) { + e.printStackTrace(); + logger.info("文件上传失败的原因==="+e); + } finally { + if (inputStream != null) { + inputStream.close(); + } + if (ftpClient.isConnected()) { + ftpClient.logout(); + ftpClient.disconnect(); + } + }*/ + } + + + + + public String getSERVER() { + return SERVER; + } + + public void setSERVER(String SERVER) { + this.SERVER = SERVER; + } + + + public String getUSERNAME() { + return USERNAME; + } + + public void setUSERNAME(String USERNAME) { + this.USERNAME = USERNAME; + } + + public String getPASSWORD() { + return PASSWORD; + } + + public void setPASSWORD(String PASSWORD) { + this.PASSWORD = PASSWORD; + } + + public String getREMOTEDIRAPTH() { + return REMOTEDIRAPTH; + } + + public void setREMOTEDIRAPTH(String REMOTEDIRAPTH) { + this.REMOTEDIRAPTH = REMOTEDIRAPTH; + } + + public String getPORT() { + return PORT; + } + + public void setPORT(String PORT) { + this.PORT = PORT; + } + + /** + * 获取流程主表数据 + * + * @param requestInfo 流程信息对象 + * @return Map key 字段名 value 字段值 + */ + public Map getWfMainTableInfo(RequestInfo requestInfo) { + Map map = new HashMap<>(); + for (Property property : requestInfo.getMainTableInfo().getProperty()) { + map.put(property.getName(), property.getValue()); + } + return map; + } + +} + + diff --git a/src/main/java/weaver/chaoyang/he/hcy_dingxinjituan/sendfilebyftp/action/SendFileByFTPAction_copy.java b/src/main/java/weaver/chaoyang/he/hcy_dingxinjituan/sendfilebyftp/action/SendFileByFTPAction_copy.java new file mode 100644 index 0000000..822e181 --- /dev/null +++ b/src/main/java/weaver/chaoyang/he/hcy_dingxinjituan/sendfilebyftp/action/SendFileByFTPAction_copy.java @@ -0,0 +1,159 @@ +package weaver.chaoyang.he.hcy_dingxinjituan.sendfilebyftp.action; + +import aiyh.utils.Util; +import org.apache.commons.net.ftp.FTP; +import org.apache.commons.net.ftp.FTPClient; +import org.apache.log4j.Logger; +import weaver.conn.RecordSet; +import weaver.file.ImageFileManager; +import weaver.interfaces.workflow.action.Action; +import weaver.soa.workflow.request.Property; +import weaver.soa.workflow.request.RequestInfo; +import weaver.workflow.request.RequestManager; + +import java.io.IOException; +import java.io.InputStream; +import java.util.HashMap; +import java.util.Map; + +public class SendFileByFTPAction_copy implements Action { + //ip + private String SERVER; + + //端口号 + private String PORT; + + //用户名 + private String USERNAME; + + //密码 + private String PASSWORD; + + //上传的指定路径 + private String REMOTEDIRAPTH; + + //日志 + private final Logger logger = Util.getLogger(); + + + + public String execute(RequestInfo requestInfo) { + RequestManager requestManager = requestInfo.getRequestManager(); + + FTPClient ftp = new FTPClient(); + + try { + //连接ftp + if (!"".equals(PORT)){ + ftp.connect(SERVER, Integer.parseInt(PORT)); + } + //登录 + ftp.login(USERNAME, PASSWORD); + ftp.enterLocalPassiveMode(); + ftp.setFileType(FTP.BINARY_FILE_TYPE); + + //获取当前流程附件的附件流 + Map wfMainTableInfo = this.getWfMainTableInfo(requestInfo); + String fj = wfMainTableInfo.get("fj"); + RecordSet recordSet = new RecordSet(); + String get_imageFiledId = "select imagefileid from DocImageFile where docid = ? order by versionId"; + boolean b = recordSet.executeQuery(get_imageFiledId, fj); + logger.info("get_imageFiledId是否执行==="+b); + recordSet.next(); + String imagefileid = Util.null2String(recordSet.getString("imagefileid")); + int imagefileidInt ; + if (!"".equals(imagefileid)){ + imagefileidInt = Integer.parseInt(imagefileid); + }else { + requestManager.setMessageid(String.valueOf(System.currentTimeMillis())); + requestManager.setMessagecontent("附件上传ftp系统失败"); + return Action.FAILURE_AND_CONTINUE; + } + InputStream is = ImageFileManager.getInputStreamById(imagefileidInt); + String remoteFilePath = REMOTEDIRAPTH;//上传路径 + boolean uploaded = ftp.storeFile(remoteFilePath, is);//文件导入 + if (uploaded) { + logger.info("File uploaded successfully"); + } else { + logger.info("File uploaded fail!"); + } + } catch (IOException ex) { + System.out.println("Error: " + ex.getMessage()); + logger.info("Error:"+ex.getMessage()); + ex.printStackTrace(); + requestManager.setMessageid(String.valueOf(System.currentTimeMillis())); + requestManager.setMessagecontent("附件上传ftp系统失败"); + return Action.FAILURE_AND_CONTINUE; + } finally { + try { + ftp.logout(); + ftp.disconnect(); + } catch (IOException ex) { + ex.printStackTrace(); + logger.info("Error:"+ex.getMessage()); + } + } + return Action.SUCCESS; + } + + + + + public String getSERVER() { + return SERVER; + } + + public void setSERVER(String SERVER) { + this.SERVER = SERVER; + } + + + public String getUSERNAME() { + return USERNAME; + } + + public void setUSERNAME(String USERNAME) { + this.USERNAME = USERNAME; + } + + public String getPASSWORD() { + return PASSWORD; + } + + public void setPASSWORD(String PASSWORD) { + this.PASSWORD = PASSWORD; + } + + public String getREMOTEDIRAPTH() { + return REMOTEDIRAPTH; + } + + public void setREMOTEDIRAPTH(String REMOTEDIRAPTH) { + this.REMOTEDIRAPTH = REMOTEDIRAPTH; + } + + public String getPORT() { + return PORT; + } + + public void setPORT(String PORT) { + this.PORT = PORT; + } + + /** + * 获取流程主表数据 + * + * @param requestInfo 流程信息对象 + * @return Map key 字段名 value 字段值 + */ + public Map getWfMainTableInfo(RequestInfo requestInfo) { + Map map = new HashMap<>(); + for (Property property : requestInfo.getMainTableInfo().getProperty()) { + map.put(property.getName(), property.getValue()); + } + return map; + } + +} + + diff --git a/src/main/java/weaver/chaoyang/he/hcy_esteelauder/checkandchangevalue/action/controller/CheckAndChangeValueAction.java b/src/main/java/weaver/chaoyang/he/hcy_esteelauder/checkandchangevalue/action/controller/CheckAndChangeValueAction.java new file mode 100644 index 0000000..3f7bd8c --- /dev/null +++ b/src/main/java/weaver/chaoyang/he/hcy_esteelauder/checkandchangevalue/action/controller/CheckAndChangeValueAction.java @@ -0,0 +1,109 @@ +package weaver.chaoyang.he.hcy_esteelauder.checkandchangevalue.action.controller; + +import aiyh.utils.Util; +import org.apache.log4j.Logger; +import weaver.chaoyang.he.hcy_esteelauder.checkandchangevalue.action.service.CheckAndChangeValueService; +import weaver.chaoyang.he.hcy_esteelauder.checkandchangevalue.action.service.impl.CheckAndChangeValueServiceImpl; +import weaver.interfaces.workflow.action.Action; +import weaver.soa.workflow.request.Cell; +import weaver.soa.workflow.request.DetailTable; +import weaver.soa.workflow.request.RequestInfo; +import weaver.soa.workflow.request.Row; +import weaver.workflow.request.RequestManager; + +import java.util.ArrayList; +import java.util.HashMap; +import java.util.List; +import java.util.Map; + +public class CheckAndChangeValueAction implements Action { + /** + * 校验字段、取uf_OfficeInventory表数据以及进行加减计算 + */ + private final CheckAndChangeValueService checkAndChangeValueService = new CheckAndChangeValueServiceImpl(); + /** + * 日志 + */ + private final Logger logger = Util.getLogger(); + @Override + public String execute(RequestInfo requestInfo) { + RequestManager requestManager = requestInfo.getRequestManager(); + Map>> detailTableValue = getDetailTableValue(requestInfo); + List> detailLists = detailTableValue.get("1"); + logger.info("detailLists==="+detailLists); + Map> checkMaps = checkAndChangeValueService.checkfield(detailLists); + logger.info("checkMaps==="+checkMaps); + if (checkMaps==null || checkMaps.size()==0){ + requestManager.setMessageid(String.valueOf(System.currentTimeMillis())); + requestManager.setMessagecontent("后端代码异常"); + return Action.FAILURE_AND_CONTINUE; + } + //开始校验字段是否符合要求 + for (Map.Entry> entry : checkMaps.entrySet()) { + String key = entry.getKey(); + List values = entry.getValue(); + if (!"".equals(key) && key.equals("lingyong")){ + for (String value : values) { + if (value.equals("false")){ + logger.error("requestid:" + requestInfo.getRequestid() ); + requestManager.setMessageid(String.valueOf(System.currentTimeMillis())); + requestManager.setMessagecontent("领用数量超过库存数量,请核对信息!"); + return Action.FAILURE_AND_CONTINUE; + } + } + }else if (!"".equals(key) && key.equals("tuihuan")){ + for (String value : values) { + if (value.equals("false")){ + logger.error("requestid:" + requestInfo.getRequestid() ); + requestManager.setMessageid(String.valueOf(System.currentTimeMillis())); + requestManager.setMessagecontent("退货数量超过实收数量,请核对信息!"); + return Action.FAILURE_AND_CONTINUE; + } + } + } + + } + //开始更新台账数据 + checkAndChangeValueService.changeDBValue(detailLists); + return Action.SUCCESS; + + } + + + /** + *

获取所有明细数据

+ * + * @return 以明细表需要为键,以明细表数据为值的键值对明细数据信息 + */ + protected Map>> getDetailTableValue(RequestInfo requestInfo) { + DetailTable[] detailTableArr = requestInfo.getDetailTableInfo().getDetailTable(); + Map>> detailDataList = new HashMap<>((int) Math.ceil(detailTableArr.length * 0.75)); + for (DetailTable detailTable : detailTableArr) { + List> detailData = getDetailValue(detailTable); + detailDataList.put(detailTable.getId(), detailData); + } + return detailDataList; + } + + /** + *

根据明细表信息获取明细表数据

+ * + * @param detailTable 明细表对象 + * @return 明细表数据 + */ + private List> getDetailValue(DetailTable detailTable) { + Row[] rowArr = detailTable.getRow(); + List> detailData = new ArrayList<>(rowArr.length); + for (Row row : rowArr) { + Cell[] cellArr = row.getCell(); + Map rowData = new HashMap<>((int) Math.ceil(cellArr.length * 0.75)); + for (Cell cell : cellArr) { + String fieldName = cell.getName(); + String value = cell.getValue(); + rowData.put(fieldName, value); + } + detailData.add(rowData); + } + return detailData; + } +} diff --git a/src/main/java/weaver/chaoyang/he/hcy_esteelauder/checkandchangevalue/action/mapper/CheckAndChangeValueMapper.java b/src/main/java/weaver/chaoyang/he/hcy_esteelauder/checkandchangevalue/action/mapper/CheckAndChangeValueMapper.java new file mode 100644 index 0000000..6bb6825 --- /dev/null +++ b/src/main/java/weaver/chaoyang/he/hcy_esteelauder/checkandchangevalue/action/mapper/CheckAndChangeValueMapper.java @@ -0,0 +1,60 @@ +package weaver.chaoyang.he.hcy_esteelauder.checkandchangevalue.action.mapper; + +import aiyh.utils.annotation.recordset.ParamMapper; +import aiyh.utils.annotation.recordset.Select; +import aiyh.utils.annotation.recordset.SqlMapper; +import aiyh.utils.annotation.recordset.Update; + + +@SqlMapper +public interface CheckAndChangeValueMapper { + + /** + *

根据产品编号查询领用数量

+ * @param id 产品编号 + * @return String 查询到的领用数量 + * @author hcy + * @Date 2023/3/17 10:36 + */ + @Select("select lysl from uf_OfficeInventory where id = #{id}") + String selectLysl(@ParamMapper("id") String id); + + /** + *

更新领用数量

+ * @param lysl 领用数量 + * @param id id + * @return boolean update是否更新成功 + * @author hcy + * @Date 2023/3/17 10:30 + */ + @Update("update uf_OfficeInventory set lysl = #{lysl} where id = #{id}") + boolean updateLysl(@ParamMapper("lysl") String lysl, + @ParamMapper("id") String id); + + + /** + *

根据产品编号查询退还数量

+ * @param id id + * @return String 查询到的退还数量 + * @author hcy + * @Date 2023/3/17 10:36 + */ + @Select("select thsl from uf_OfficeInventory where id = #{id}") + String selectThsl(@ParamMapper("id") String id); + + + /** + *

更新退还数量

+ * @param thsl 退还数量 + * @param id id + * @return boolean update是否更新成功 + * @author hcy + * @Date 2023/3/17 10:30 + */ + @Update("update uf_OfficeInventory set thsl = #{thsl} where id = #{id}") + boolean updaThsl(@ParamMapper("thsl") String thsl, + @ParamMapper("id") String id); + + + +} diff --git a/src/main/java/weaver/chaoyang/he/hcy_esteelauder/checkandchangevalue/action/service/CheckAndChangeValueService.java b/src/main/java/weaver/chaoyang/he/hcy_esteelauder/checkandchangevalue/action/service/CheckAndChangeValueService.java new file mode 100644 index 0000000..8d22684 --- /dev/null +++ b/src/main/java/weaver/chaoyang/he/hcy_esteelauder/checkandchangevalue/action/service/CheckAndChangeValueService.java @@ -0,0 +1,11 @@ +package weaver.chaoyang.he.hcy_esteelauder.checkandchangevalue.action.service; + +import java.util.List; +import java.util.Map; + +public interface CheckAndChangeValueService { + + public Map> checkfield(List> detailLists); + + public void changeDBValue(List> detailLists); +} diff --git a/src/main/java/weaver/chaoyang/he/hcy_esteelauder/checkandchangevalue/action/service/impl/CheckAndChangeValueServiceImpl.java b/src/main/java/weaver/chaoyang/he/hcy_esteelauder/checkandchangevalue/action/service/impl/CheckAndChangeValueServiceImpl.java new file mode 100644 index 0000000..fa7d258 --- /dev/null +++ b/src/main/java/weaver/chaoyang/he/hcy_esteelauder/checkandchangevalue/action/service/impl/CheckAndChangeValueServiceImpl.java @@ -0,0 +1,180 @@ +package weaver.chaoyang.he.hcy_esteelauder.checkandchangevalue.action.service.impl; + +import aiyh.utils.Util; +import org.apache.log4j.Logger; +import weaver.chaoyang.he.hcy_esteelauder.checkandchangevalue.action.mapper.CheckAndChangeValueMapper; +import weaver.chaoyang.he.hcy_esteelauder.checkandchangevalue.action.service.CheckAndChangeValueService; + +import java.util.ArrayList; +import java.util.HashMap; +import java.util.List; +import java.util.Map; +import java.util.stream.Collectors; + +public class CheckAndChangeValueServiceImpl implements CheckAndChangeValueService { + + + private final CheckAndChangeValueMapper checkAndChangeValueMapper = Util.getMapper(CheckAndChangeValueMapper.class); + private final Logger logger = Util.getLogger(); + /** + *

校验字段是否符合流程流转的需求

+ * @param detailLists 明细表所有数据 + * @return boolean 不符合返回false + * @author hcy + * 2023/3/16 15:22 + */ + public Map> checkfield(List> detailLists) { + try { + Map>> detailMap = detailLists.stream().collect(Collectors.groupingBy(items -> items.get("ywlx"))); + List booleanLingYong = new ArrayList<>();//用来存放 false 和 true 校验字段是否属于符合标准 + List booleanTuiHuan = new ArrayList<>();//用来存放 false 和 true 校验字段是否属于符合标准 + + for (Map.Entry>> entry : detailMap.entrySet()) { + String key = Util.null2String(entry.getKey()); + List> value = entry.getValue(); + if (key.equals("0")){ + Map>> cpbh = value.stream().collect(Collectors.groupingBy(items -> items.get("cpbh")));//产品编号 + for (Map.Entry>> cpbhentry : cpbh.entrySet()) { +// String cpbhkey = Util.null2String(cpbhentry.getKey()); + List> cpbhvalue = cpbhentry.getValue(); + double total = 0; + for (Map stringStringMap : cpbhvalue) { + String lythsl = Util.null2String(stringStringMap.get("lythsl"));//领用/退还数量 + if (!"".equals(lythsl)){ + total += Double.parseDouble(lythsl); + } + } + String kcyesl = Util.null2String(value.get(0).get("kcyesl")); + double kcyeslDouble = 0; + if (!"".equals(kcyesl)){ + kcyeslDouble = Double.parseDouble(kcyesl); + } + if (total <= kcyeslDouble){ + booleanLingYong.add("true"); + }else { + booleanLingYong.add("false"); + } + } + }else if (key.equals("1")){ + Map>> cpbh = value.stream().collect(Collectors.groupingBy(items -> items.get("cpbh")));//产品编号 + for (Map.Entry>> cpbhentry : cpbh.entrySet()) { +// String cpbhkey = Util.null2String(cpbhentry.getKey()); + List> cpbhvalue = cpbhentry.getValue(); + double total = 0; + for (Map stringStringMap : cpbhvalue) { + String lythsl = Util.null2String(stringStringMap.get("lythsl"));//领用/退还数量 + if (!lythsl.equals("")){ + total += Double.parseDouble(lythsl); + } + } + String sssl = Util.null2String(cpbhvalue.get(0).get("sssl"));//实收数量 + String kcyesl = Util.null2String(cpbhvalue.get(0).get("kcyesl"));//剩余库存数量 + double ssslDouble = 0; + double kcyeslDouble = 0; + if (!"".equals(sssl)&&!"".equals(kcyesl)){ + ssslDouble = Double.parseDouble(sssl); + kcyeslDouble = Double.parseDouble(kcyesl); + } + double subtractionValue = ssslDouble - kcyeslDouble; + logger.info("subtractionValue==="+subtractionValue); + logger.info("total==="+total); + if (total <= subtractionValue){ + booleanTuiHuan.add("true"); + }else { + booleanTuiHuan.add("false"); + } + } + } + } + Map> booleanMap = new HashMap<>(); + booleanMap.put("lingyong",booleanLingYong); + booleanMap.put("tuihuan", booleanTuiHuan); + return booleanMap; + } catch (NumberFormatException e) { + e.printStackTrace(); + logger.info("checkfield方法异常==="+e); + return null; + } + } + + /** + *

修改uf_OfficeInventory表数据以及进行加减计算

+ * @param detailLists 明细表所有数据 + * @author hcy + * 2023/3/16 15:23 + */ + public void changeDBValue(List> detailLists) { + try { + + Map>> detailMap = detailLists.stream().collect(Collectors.groupingBy(items -> items.get("ywlx"))); + Map lingYongMap = new HashMap<>();//用于存放领用类型的数据 + Map tuiHuanMap = new HashMap<>();//用于存放退还类型的数据 + for (Map.Entry>> entry : detailMap.entrySet()) { + String key = Util.null2String(entry.getKey()); + List> value = entry.getValue(); + if (!("".equals(key)) && key.equals("0")){ + Map>> cpbh = value.stream().collect(Collectors.groupingBy(items -> items.get("cpbh")));//产品编号 + for (Map.Entry>> cpbhentry : cpbh.entrySet()) { + String cpbhkey = Util.null2String(cpbhentry.getKey()); + List> cpbhvalue = cpbhentry.getValue(); + int total = 0; + for (Map stringStringMap : cpbhvalue) { + String lythsl = Util.null2String(stringStringMap.get("lythsl"));//领用/退还数量 + if (!lythsl.equals("")){ + total += Integer.parseInt(lythsl); + } + } + lingYongMap.put(cpbhkey,total); + } + }else if (!("".equals(key)) && key.equals("1")){ + Map>> cpbh = value.stream().collect(Collectors.groupingBy(items -> items.get("cpbh")));//产品编号 + for (Map.Entry>> cpbhentry : cpbh.entrySet()) { + String cpbhkey = Util.null2String(cpbhentry.getKey()); + List> cpbhvalue = cpbhentry.getValue(); + int total = 0; + for (Map stringStringMap : cpbhvalue) { + String lythsl = Util.null2String(stringStringMap.get("lythsl"));//领用/退还数量 + if (!lythsl.equals("")){ + total += Integer.parseInt(lythsl); + } + } + tuiHuanMap.put(cpbhkey,total); + } + } + } + + //开始updte数据库 + for (Map.Entry entry : lingYongMap.entrySet()) { + String key = entry.getKey(); + Integer value = entry.getValue(); + String selectLysl = checkAndChangeValueMapper.selectLysl(key); + int lyslDB = 0; + if (!selectLysl.equals("")){ + lyslDB = Integer.parseInt(selectLysl); + } + //减库存 + boolean updateLysl = checkAndChangeValueMapper.updateLysl(String.valueOf(lyslDB + value),key); + logger.info("减库存是否成功==="+updateLysl); + } + + for (Map.Entry entry : tuiHuanMap.entrySet()) { + String key = entry.getKey(); + Integer value = entry.getValue(); + String selectThsl = checkAndChangeValueMapper.selectThsl(key); + int thslDB = 0; + if (!selectThsl.equals("")){ + thslDB = Integer.parseInt(selectThsl); + } + //增加库存 + String finalThsl = String.valueOf(thslDB + value); + boolean updateThsl = checkAndChangeValueMapper.updaThsl(finalThsl,key); + logger.info("增加库存是否成功"+updateThsl); + } + } catch (Exception e) { + e.printStackTrace(); + logger.info("changeDBValue异常为==="+e); + } + + + } +} diff --git a/src/main/java/weaver/chaoyang/he/hcy_esteelauder/createworkflow/controller/GetDataCreateWorkflowController.java b/src/main/java/weaver/chaoyang/he/hcy_esteelauder/createworkflow/controller/GetDataCreateWorkflowController.java new file mode 100644 index 0000000..16d7e91 --- /dev/null +++ b/src/main/java/weaver/chaoyang/he/hcy_esteelauder/createworkflow/controller/GetDataCreateWorkflowController.java @@ -0,0 +1,149 @@ +package weaver.chaoyang.he.hcy_esteelauder.createworkflow.controller; + +import aiyh.utils.Util; +import org.apache.log4j.Logger; +import weaver.chaoyang.he.hcy_esteelauder.createworkflow.mapper.GetWorkflowDataMapper; +import weaver.chaoyang.he.hcy_esteelauder.createworkflow.service.GetWorkflowDataService; +import weaver.chaoyang.he.hcy_esteelauder.createworkflow.service.impl.GetWorkflowDataServiceImpl; +import weaver.hrm.User; +import weaver.interfaces.schedule.BaseCronJob; + +import java.text.SimpleDateFormat; +import java.util.*; +import java.util.stream.Collectors; + +/** + *

计划任务一段时间收集《office库存领用/退还登记》流程中的数据,用收集到的数据创建《office库存领用/退还汇总签批》流程

+ * @Author hcy + * @Date 2023/3/15 11:45 + */ +public class GetDataCreateWorkflowController extends BaseCronJob { + //获取数据主表的名称 + private String getDataMainTableName; + //获取数据的和主表数据对应的明细表的名称 + private String getDataDetailTableName; + //流程id + private String workflowId; + //配置表的唯一标识 + private String wybs; + //校验日志 + private String datetime; + + + + /** + * 获取《office库存领用/退还申请》流程中的数据 + */ + private final GetWorkflowDataService getWorkflowDataService = (GetWorkflowDataService) new GetWorkflowDataServiceImpl(); + + private final GetWorkflowDataMapper getWorkflowDataMapper = Util.getMapper(GetWorkflowDataMapper.class); + /** + * 日志 + */ + private final Logger logger = Util.getLogger(); + + /** + *

获取流程数据,创建新的流程

+ * @param + * @return + * @author hcy + * @Date 2023/3/15 13:54 + */ + public void execute() { + + try { + String month = this.getlastdayDate(); + //第一步拿到数据 + List> totalData = new ArrayList<>(); + + if (!"".equals(Util.null2String(datetime))){ + totalData = getWorkflowDataService.getTotalData(getDataMainTableName, getDataDetailTableName,datetime); + }else { + totalData = getWorkflowDataService.getTotalData(getDataMainTableName, getDataDetailTableName,month); + } + + logger.info("===totalData==="+totalData); + //这一步是获取权限区分字段名称 + String distinctField = getWorkflowDataMapper.getDistincteField(wybs); + Map>> datas = totalData.stream().collect(Collectors.groupingBy(items -> items.get(distinctField)));//单个流程,过滤数据 + logger.info("===datas===="+datas); + User user = new User(); + //第二步创建流程 + datas.forEach((key,value)->{ + //拿到数据创建流程 + String s = getWorkflowDataService.startWorkflow(workflowId, value, user, "1",wybs,distinctField); + logger.info("============"+s+"============"); + }); + } catch (Exception e) { + e.printStackTrace(); + logger.info("controller层出现问题---问题为:"+e); + } + + + } + + + + /** + *

获取系统当前时间的前一天日期

+ * @param + * @return String + * @author hcy + * @Date 2023/3/16 10:50 + */ + public String getlastdayDate(){ + SimpleDateFormat sdf= new SimpleDateFormat("yyyy-MM-dd"); + Date date = new Date(); + Calendar calendar = Calendar.getInstance(); + calendar.setTime(date); + calendar.add(Calendar.DAY_OF_MONTH, -1); + date = calendar.getTime(); + System.out.println(sdf.format(date)); + return sdf.format(date); + } + + public String getGetDataMainTableName() { + return getDataMainTableName; + } + + public void setGetDataMainTableName(String getDataMainTableName) { + this.getDataMainTableName = getDataMainTableName; + } + + public String getGetDataDetailTableName() { + return getDataDetailTableName; + } + + public void setGetDataDetailTableName(String getDataDetailTableName) { + this.getDataDetailTableName = getDataDetailTableName; + } + + + public String getWorkflowId() { + return workflowId; + } + + public void setWorkflowId(String workflowId) { + this.workflowId = workflowId; + } + + public GetWorkflowDataService getGetWorkflowDataService() { + return getWorkflowDataService; + } + + public String getWybs() { + return wybs; + } + + public void setWybs(String wybs) { + this.wybs = wybs; + } + + public String getDatetime() { + return datetime; + } + + public void setDatetime(String datetime) { + this.datetime = datetime; + } +} diff --git a/src/main/java/weaver/chaoyang/he/hcy_esteelauder/createworkflow/mapper/GetWorkflowDataMapper.java b/src/main/java/weaver/chaoyang/he/hcy_esteelauder/createworkflow/mapper/GetWorkflowDataMapper.java new file mode 100644 index 0000000..05dbadb --- /dev/null +++ b/src/main/java/weaver/chaoyang/he/hcy_esteelauder/createworkflow/mapper/GetWorkflowDataMapper.java @@ -0,0 +1,37 @@ +package weaver.chaoyang.he.hcy_esteelauder.createworkflow.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; + +@SqlMapper +public interface GetWorkflowDataMapper { + + /** + *

内连接主表以及明细表查询出来放入List中

+ * @param mainTableName,detailTableName + * @return List> + * @author hcy + * @Date 2023/3/15 14:47 + */ + + @Select("select * from $t{mainTableName} m inner join $t{detailTableName} d on m.id = d.mainid where LEFT(sqrq,7) = LEFT(#{month},7)") + List> selectTotalData(@ParamMapper("mainTableName") String mainTableName, + @ParamMapper("detailTableName") String detailTableName, + @ParamMapper("month") String month + ); + @Select("select bmmc from uf_dept where id = #{ppbm}") + String selectPpName(@ParamMapper("ppbm")String ppbm); + + @Select("select * from uf_xjlcbdzddypzb uf inner join uf_xjlcbdzddypzb_dt1 ufdt1 on uf.id = ufdt1.mainid where uf.wybs = #{wybs}") + List> selectfromCustomizeTable(@ParamMapper("wybs") String wybs); + + @Select("select qxqfzdsjkmc from uf_xjlcbdzddypzb where wybs = #{wybs}") + String getDistincteField(String wybs); + + @Select("select bmmc from uf_dept where id= #{ppbm}") + String getPpbmValue(String ppbm); +} diff --git a/src/main/java/weaver/chaoyang/he/hcy_esteelauder/createworkflow/service/GetWorkflowDataService.java b/src/main/java/weaver/chaoyang/he/hcy_esteelauder/createworkflow/service/GetWorkflowDataService.java new file mode 100644 index 0000000..c5615d7 --- /dev/null +++ b/src/main/java/weaver/chaoyang/he/hcy_esteelauder/createworkflow/service/GetWorkflowDataService.java @@ -0,0 +1,23 @@ +package weaver.chaoyang.he.hcy_esteelauder.createworkflow.service; + +import weaver.hrm.User; + +import java.util.List; +import java.util.Map; + +public interface GetWorkflowDataService { + + public List> getTotalData(String mainTableName,String detailTableName,String month); + + /** + *

创建一个流程

+ * @param workflowId 流程id + * @param totalDatas:主表数据,明细表数据:数据形式:key:value + * @param user 当前用户信息 + * @param isNextFlow 是否自动提交至下一个节点 0:否 1:是 + * @return String:流程创建是否成功 + * @author hcy + * @Date 2023/3/15 16:42 + */ + public String startWorkflow(String workflowId,List> totalDatas,User user, String isNextFlow,String wybs,String distinctField); +} diff --git a/src/main/java/weaver/chaoyang/he/hcy_esteelauder/createworkflow/service/impl/GetWorkflowDataServiceImpl.java b/src/main/java/weaver/chaoyang/he/hcy_esteelauder/createworkflow/service/impl/GetWorkflowDataServiceImpl.java new file mode 100644 index 0000000..b9b4cdb --- /dev/null +++ b/src/main/java/weaver/chaoyang/he/hcy_esteelauder/createworkflow/service/impl/GetWorkflowDataServiceImpl.java @@ -0,0 +1,157 @@ +package weaver.chaoyang.he.hcy_esteelauder.createworkflow.service.impl; + +import aiyh.utils.Util; +import org.apache.log4j.Logger; +import weaver.chaoyang.he.hcy_esteelauder.createworkflow.mapper.GetWorkflowDataMapper; +import weaver.chaoyang.he.hcy_esteelauder.createworkflow.service.GetWorkflowDataService; +import weaver.hrm.User; +import weaver.workflow.webservices.*; + +import java.text.SimpleDateFormat; +import java.util.*; + +public class GetWorkflowDataServiceImpl implements GetWorkflowDataService { + + private final Logger logger = Util.getLogger(); + private final GetWorkflowDataMapper getWorkflowDataMapper = Util.getMapper(GetWorkflowDataMapper.class); + + @Override + public List> getTotalData(String mainTableName, String detailTableName,String month) { + return getWorkflowDataMapper.selectTotalData(mainTableName, detailTableName,month); + } + + /** + *

创建流程

+ * @param workflowId:流程id + * @return String:流程创建成功与否 + * @author hcy + * 2023/3/15 22:45 + */ + public String startWorkflow(String workflowId, List> totalDatas, User user, String isNextFlow,String wybs,String distinctField) { + + + try { + List> customizeDataList = getWorkflowDataMapper.selectfromCustomizeTable(wybs); + List> mailTableDatas = new ArrayList<>(); + List> detailDataDatas = new ArrayList<>(); + + for (Map map : customizeDataList) { + if (Util.null2String(map.get("sjly")).equals("0")&&Util.null2String(map.get("mbzdsjly")).equals("0")){ + mailTableDatas.add(map); + } + if (Util.null2String(map.get("sjly")).equals("0")&&Util.null2String(map.get("mbzdsjly")).equals("1")){ + detailDataDatas.add(map); + } + if (Util.null2String(map.get("sjly")).equals("1")&&Util.null2String(map.get("mbzdsjly")).equals("1")){ + detailDataDatas.add(map); + } + } + WorkflowRequestTableField[] wrti = new WorkflowRequestTableField[mailTableDatas.size()]; + + //配置表动态处理主表字段 + for (int i = 0; i dataMap = mailTableDatas.get(i); + wrti[i] = new WorkflowRequestTableField(); + String targetField = Util.null2String(dataMap.get("mblczdsjkm")); + wrti[i].setFieldName(targetField); + Object ylczdsjkm = dataMap.get("ylczdsjkm"); + Object sourceField = totalDatas.get(i).get(ylczdsjkm); + wrti[i].setFieldValue(Util.null2String(sourceField)); + wrti[i].setView(true); + wrti[i].setEdit(true); + + } + + WorkflowRequestTableRecord[] wrtri = new WorkflowRequestTableRecord[1];//主字段只有一行数据 + wrtri[0] = new WorkflowRequestTableRecord(); + wrtri[0].setWorkflowRequestTableFields(wrti); + WorkflowMainTableInfo wmi = new WorkflowMainTableInfo(); + wmi.setRequestRecords(wrtri); + //主表end + int detailrows = totalDatas.size();//添加指定条数明细 + + // 添加明细数据 + wrtri = new WorkflowRequestTableRecord[totalDatas.size()];//添加指定条数行明细数据 + //每行明细对应的字段 + + for (int i = 0; i < detailrows; i++) { + //字段信息 + wrti = new WorkflowRequestTableField[detailDataDatas.size()]; + int j=0; + for (Map detailDataData : detailDataDatas) { + wrti[j] = new WorkflowRequestTableField(); + String targetField = Util.null2String(detailDataData.get("mblczdsjkm"));//目标字段,字段名 + wrti[j].setFieldName(targetField);//服务类型 + Object ylczdsjkm = detailDataData.get("ylczdsjkm"); + Object sourceField = totalDatas.get(i).get(ylczdsjkm); + String sourceFieldString = Util.null2String(sourceField); + if (Util.null2String(totalDatas.get(i).get("ywlx")).equals("0")&&Util.null2String(ylczdsjkm).equals("lythsl")){ + sourceFieldString = "-"+sourceFieldString; + } + wrti[j].setFieldValue(sourceFieldString); + wrti[j].setView(true);//字段是否可见 + wrti[j].setEdit(true);//字段是否可编辑 + j++; + } + wrtri[i] = new WorkflowRequestTableRecord(); + wrtri[i].setWorkflowRequestTableFields(wrti); + } + //添加到明细表中 + WorkflowDetailTableInfo WorkflowDetailTableInfo[] = new WorkflowDetailTableInfo[1];//指定明细表的个数,多个明细表指定多个,顺序按照明细的顺序 + WorkflowDetailTableInfo[0] = new WorkflowDetailTableInfo(); + WorkflowDetailTableInfo[0].setWorkflowRequestTableRecords(wrtri); + //添加工作流id + WorkflowBaseInfo wbi = new WorkflowBaseInfo(); + wbi.setWorkflowId(workflowId);//workflowid 流程接口演示流程2016==38 + WorkflowRequestInfo wri = new WorkflowRequestInfo();//流程基本信息 + wri.setCreatorId("1");//创建人id ToDo:这里先写死,稍后再做改写 + wri.setRequestLevel("0");//0 正常,1重要,2紧急 + String ppbmValue = getWorkflowDataMapper.getPpbmValue(Util.null2String(totalDatas.get(0).get(distinctField))); + String workflowTitle = this.getWorkflowTitle(ppbmValue); + wri.setRequestName(workflowTitle);//流程标题 + wri.setWorkflowMainTableInfo(wmi);//添加主字段数据 + wri.setWorkflowDetailTableInfos(WorkflowDetailTableInfo);//添加明细数据 + wri.setWorkflowBaseInfo(wbi); +// wri.setIsnextflow(isNextFlow);//是否提交下一个节点 + WorkflowService workflowService = new WorkflowServiceImpl(); + String requestid =workflowService.doCreateWorkflowRequest(wri,1); + logger.info("===requestid==="+requestid); + if (!requestid.equals("")){ + return "流程创建成功"; + }else { + return "流程创建失败"; + } + } catch (Exception e) { + e.printStackTrace(); + logger.info("流程创建异常===异常信息===="+e); + return "流程创建异常===异常信息===="+e; + } + + + } + + /** + *

获取流程标题

+ * @param pp 品牌名称 + * @return String + * @author hcy + * 2023/3/16 11:27 + */ + public String getWorkflowTitle(String pp){ + + String workflowName = pp + "-" + getSystemDate() + "-" + "office库存领用/退还明细"; + logger.info("workflowName==="+workflowName); + return workflowName; + } + /** + *

获取系统当年份

+ * @return String + * @author hcy + * 2023/3/15 13:52 + */ + public String getSystemDate(){ + Date date = new Date(); + SimpleDateFormat dateFormat = new SimpleDateFormat("yyyy-MM-dd"); + return dateFormat.format(date); + } +} diff --git a/src/main/java/weaver/chaoyang/he/hcy_esteelauder/createworkflow/service/impl/GetWorkflowDataServiceImpl_copy.java b/src/main/java/weaver/chaoyang/he/hcy_esteelauder/createworkflow/service/impl/GetWorkflowDataServiceImpl_copy.java new file mode 100644 index 0000000..ec0c4e0 --- /dev/null +++ b/src/main/java/weaver/chaoyang/he/hcy_esteelauder/createworkflow/service/impl/GetWorkflowDataServiceImpl_copy.java @@ -0,0 +1,274 @@ +package weaver.chaoyang.he.hcy_esteelauder.createworkflow.service.impl;//package weaver.hcy_esteelauder.createworkflow.service.impl; +// +//import aiyh.utils.Util; +//import org.apache.log4j.Logger; +//import weaver.hcy_esteelauder.createworkflow.mapper.GetWorkflowDataMapper; +//import weaver.hcy_esteelauder.createworkflow.service.GetWorkflowDataService; +//import weaver.hrm.User; +//import weaver.workflow.webservices.*; +// +//import java.text.SimpleDateFormat; +//import java.util.Date; +//import java.util.List; +//import java.util.Map; +// +//public class GetWorkflowDataServiceImpl_copy implements GetWorkflowDataService { +// +// private final Logger logger = Util.getLogger(); +// private final GetWorkflowDataMapper getWorkflowDataMapper = Util.getMapper(GetWorkflowDataMapper.class); +// +// @Override +// public List> getTotalData(String mainTableName, String detailTableName,String month) { +// return getWorkflowDataMapper.selectTotalData(mainTableName, detailTableName,month); +// } +// +// /** +// *

创建流程

+// * @param workflowId:流程id +// * @param workflowId:流程id +// * @param workflowId:流程id +// * @return String:流程创建成功与否 +// * @author hcy +// * @Date 2023/3/15 22:45 +// */ +// public String startWorkflow(String workflowId, List> totalDatas, User user, String isNextFlow,String wybs) { +// +// +// try { +//// List> customizeDataList = getWorkflowDataMapper.selectfromCustomizeTable(wybs); +// +// WorkflowRequestTableField[] wrti = new WorkflowRequestTableField[4]; +// +// //字段信息 +// wrti[0] = new WorkflowRequestTableField(); +// wrti[0].setFieldName("sqr"); +// wrti[0].setFieldValue(Util.null2String(String.valueOf(totalDatas.get(0).get("sqr")))); +// wrti[0].setView(true); +// wrti[0].setEdit(true); +// +// wrti[1] = new WorkflowRequestTableField(); +// wrti[1].setFieldName("sqrbm"); +// wrti[1].setFieldValue(Util.null2String(String.valueOf(totalDatas.get(0).get("sqrbm")))); +// wrti[1].setView(true); +// wrti[1].setEdit(true); +// +// wrti[2] = new WorkflowRequestTableField(); +// wrti[2].setFieldName("sqrq"); +// wrti[2].setFieldValue(Util.null2String(String.valueOf(totalDatas.get(0).get("sqrq")))); +// wrti[2].setView(true); +// wrti[2].setEdit(true); +// +// wrti[3] = new WorkflowRequestTableField(); +// wrti[3].setFieldName("ppbm"); +// String ppbmValue = Util.null2String(String.valueOf(totalDatas.get(0).get("ppbm"))); +// if (!ppbmValue.equals("")){ +// wrti[3].setFieldValue(ppbmValue); +// } +// wrti[3].setView(true); +// wrti[3].setEdit(true); +// +// +// WorkflowRequestTableRecord[] wrtri = new WorkflowRequestTableRecord[1];//主字段只有一行数据 +// wrtri[0] = new WorkflowRequestTableRecord(); +// wrtri[0].setWorkflowRequestTableFields(wrti); +// WorkflowMainTableInfo wmi = new WorkflowMainTableInfo(); +// wmi.setRequestRecords(wrtri); +// //主表end +// int detailrows = totalDatas.size();//添加指定条数明细 +// // 添加明细数据 +// wrtri = new WorkflowRequestTableRecord[totalDatas.size()];//添加指定条数行明细数据 +// for (int i = 0; i < detailrows; i++) { +// //每行明细对应的字段 +// wrti = new WorkflowRequestTableField[20]; +// //字段信息 +// //0 +// wrti[0] = new WorkflowRequestTableField(); +// wrti[0].setFieldName("ywlx");//服务类型 +// wrti[0].setFieldValue(String.valueOf(totalDatas.get(i).get("ywlx"))); +// wrti[0].setView(true);//字段是否可见 +// wrti[0].setEdit(true);//字段是否可编辑 +// +// wrti[1] = new WorkflowRequestTableField(); +// wrti[1].setFieldName("pp");//品牌 +// wrti[1].setFieldValue(String.valueOf(totalDatas.get(i).get("ppbm"))); +// wrti[1].setView(true);//字段是否可见 +// wrti[1].setEdit(true);//字段是否可编辑 +// +// wrti[2] = new WorkflowRequestTableField(); +// wrti[2].setFieldName("bm");//部门 +// wrti[2].setFieldValue(String.valueOf(totalDatas.get(i).get("sqrbm"))); +// wrti[2].setView(true);//字段是否可见 +// wrti[2].setEdit(true);//字段是否可编辑 +// +// +// wrti[3] = new WorkflowRequestTableField(); +// wrti[3].setFieldName("stockowner");//stockowner +// wrti[3].setFieldValue(String.valueOf(totalDatas.get(i).get("stockowner"))); +// wrti[3].setView(true);//字段是否可见 +// wrti[3].setEdit(true);//字段是否可编辑 +// +// wrti[4] = new WorkflowRequestTableField(); +// wrti[4].setFieldName("sqr");//申请人 +// wrti[4].setFieldValue(String.valueOf(totalDatas.get(i).get("sqr"))); +// wrti[4].setView(true);//字段是否可见 +// wrti[4].setEdit(true);//字段是否可编辑 +// +// wrti[5] = new WorkflowRequestTableField(); +// wrti[5].setFieldName("cs");//城市 +// wrti[5].setFieldValue(String.valueOf(totalDatas.get(i).get("cs"))); +// wrti[5].setView(true);//字段是否可见 +// wrti[5].setEdit(true);//字段是否可编辑 +// +// wrti[6] = new WorkflowRequestTableField(); +// wrti[6].setFieldName("stocklocation");//stocklocation +// wrti[6].setFieldValue(String.valueOf(totalDatas.get(i).get("stocklocation"))); +// wrti[6].setView(true);//字段是否可见 +// wrti[6].setEdit(true);//字段是否可编辑 +// +// wrti[7] = new WorkflowRequestTableField(); +// wrti[7].setFieldName("hgbh");//货柜编号 +// wrti[7].setFieldValue(String.valueOf(totalDatas.get(i).get("hgbh"))); +// wrti[7].setView(true);//字段是否可见 +// wrti[7].setEdit(true);//字段是否可编辑 +// +// wrti[8] = new WorkflowRequestTableField(); +// wrti[8].setFieldName("cpbh");//产品编号 +// wrti[8].setFieldValue(String.valueOf(totalDatas.get(i).get("cpbh"))); +// wrti[8].setView(true);//字段是否可见 +// wrti[8].setEdit(true);//字段是否可编辑 +// +// wrti[9] = new WorkflowRequestTableField(); +// wrti[9].setFieldName("ddbh");//订单编号 +// wrti[9].setFieldValue(String.valueOf(totalDatas.get(i).get("ddbh"))); +// wrti[9].setView(true);//字段是否可见 +// wrti[9].setEdit(true);//字段是否可编辑 +// +// wrti[10] = new WorkflowRequestTableField(); +// wrti[10].setFieldName("zwms");//中文描述 +// wrti[10].setFieldValue(String.valueOf(totalDatas.get(i).get("zwms"))); +// wrti[10].setView(true);//字段是否可见 +// wrti[10].setEdit(true);//字段是否可编辑 +// +// wrti[11] = new WorkflowRequestTableField(); +// wrti[11].setFieldName("kcyesl");//剩余库存 +// wrti[11].setFieldValue(String.valueOf(totalDatas.get(i).get("kcyesl"))); +// wrti[11].setView(true);//字段是否可见 +// wrti[11].setEdit(true);//字段是否可编辑 +// +// wrti[12] = new WorkflowRequestTableField(); +// wrti[12].setFieldName("lythrq");//领用/退还日期 +// wrti[12].setFieldValue(String.valueOf(totalDatas.get(i).get("lythrq"))); +// wrti[12].setView(true);//字段是否可见 +// wrti[12].setEdit(true);//字段是否可编辑 +// +// wrti[13] = new WorkflowRequestTableField(); +// wrti[13].setFieldName("dqrq");//到期日期 +// wrti[13].setFieldValue(String.valueOf(totalDatas.get(i).get("dqrq"))); +// wrti[13].setView(true);//字段是否可见 +// wrti[13].setEdit(true);//字段是否可编辑 +// +// wrti[14] = new WorkflowRequestTableField(); +// wrti[14].setFieldName("lythsl");//领用退还数量 +// if (Util.null2String(totalDatas.get(i).get("ywlx")).equals("1")){ +// wrti[14].setFieldValue(String.valueOf("-"+totalDatas.get(i).get("lythsl"))); +// }else if (Util.null2String(totalDatas.get(i).get("ywlx")).equals("0")){ +// wrti[14].setFieldValue(String.valueOf(totalDatas.get(i).get("lythsl"))); +// } +// wrti[14].setView(true);//字段是否可见 +// wrti[14].setEdit(true);//字段是否可编辑 +// +// +// wrti[15] = new WorkflowRequestTableField(); +// wrti[15].setFieldName("cplx");//产品类型 +// wrti[15].setFieldValue(String.valueOf(totalDatas.get(i).get("cplx"))); +// wrti[15].setView(true);//字段是否可见 +// wrti[15].setEdit(true);//字段是否可编辑 +// +// wrti[16] = new WorkflowRequestTableField(); +// wrti[16].setFieldName("kdzjxx");//快递/转交信息 +// wrti[16].setFieldValue(String.valueOf(totalDatas.get(i).get("kdzjxx"))); +// wrti[16].setView(true);//字段是否可见 +// wrti[16].setEdit(true);//字段是否可编辑 +// +// wrti[17] = new WorkflowRequestTableField(); +// wrti[17].setFieldName("cpyt");//产品用途 +// wrti[17].setFieldValue(String.valueOf(totalDatas.get(i).get("cpyt"))); +// wrti[17].setView(true);//字段是否可见 +// wrti[17].setEdit(true);//字段是否可编辑 +// +// wrti[18] = new WorkflowRequestTableField(); +// wrti[18].setFieldName("sssl");//实收数量 +// wrti[18].setFieldValue(String.valueOf(totalDatas.get(i).get("sssl"))); +// wrti[18].setView(true);//字段是否可见 +// wrti[18].setEdit(true);//字段是否可编辑 +// +// wrti[19] = new WorkflowRequestTableField(); +// wrti[19].setFieldName("bz");//备注 +// wrti[19].setFieldValue(String.valueOf(totalDatas.get(i).get("bz"))); +// wrti[19].setView(true);//字段是否可见 +// wrti[19].setEdit(true);//字段是否可编辑 +// +// wrtri[i] = new WorkflowRequestTableRecord(); +// wrtri[i].setWorkflowRequestTableFields(wrti); +// } +// //添加到明细表中 +// WorkflowDetailTableInfo WorkflowDetailTableInfo[] = new WorkflowDetailTableInfo[1];//指定明细表的个数,多个明细表指定多个,顺序按照明细的顺序 +// WorkflowDetailTableInfo[0] = new WorkflowDetailTableInfo(); +// WorkflowDetailTableInfo[0].setWorkflowRequestTableRecords(wrtri); +// //添加工作流id +// WorkflowBaseInfo wbi = new WorkflowBaseInfo(); +// wbi.setWorkflowId(workflowId);//workflowid 流程接口演示流程2016==38 +// WorkflowRequestInfo wri = new WorkflowRequestInfo();//流程基本信息 +// wri.setCreatorId("1");//创建人id ToDo:这里先写死,稍后再做改写 +// wri.setRequestLevel("0");//0 正常,1重要,2紧急 +// String workflowTitle = this.getWorkflowTitle(Util.null2String(String.valueOf(totalDatas.get(0).get("ppbm")))); +// wri.setRequestName(workflowTitle);//流程标题 +// wri.setWorkflowMainTableInfo(wmi);//添加主字段数据 +// wri.setWorkflowDetailTableInfos(WorkflowDetailTableInfo);//添加明细数据 +// wri.setWorkflowBaseInfo(wbi); +//// wri.setIsnextflow(isNextFlow);//是否提交下一个节点 +// WorkflowService workflowService = new WorkflowServiceImpl(); +// String requestid =workflowService.doCreateWorkflowRequest(wri,1); +// logger.info("===requestid==="+requestid); +// if (!requestid.equals("")){ +// return "流程创建成功"; +// }else { +// return "流程创建失败"; +// } +// } catch (Exception e) { +// e.printStackTrace(); +// logger.info("流程创建异常===异常信息===="+e); +// return "流程创建异常===异常信息===="+e; +// } +// +// +// } +// +// /** +// *

获取流程标题

+// * @param pp 品牌名称 +// * @return String +// * @author hcy +// * @Date 2023/3/16 11:27 +// */ +// public String getWorkflowTitle(String pp){ +// String ppName = getWorkflowDataMapper.selectPpName(pp); +// String workflowName = ppName + "-" + getSystemDate() + "-" + "office库存领用/退还明细"; +// logger.info("workflowName==="+workflowName); +// return workflowName; +// } +// /** +// *

获取系统当年份

+// * @param +// * @return String +// * @author hcy +// * @Date 2023/3/15 13:52 +// */ +// public String getSystemDate(){ +// Date date = new Date(); +// SimpleDateFormat dateFormat = new SimpleDateFormat("yyyy-MM-dd"); +// return dateFormat.format(date); +// } +// +// +//} diff --git a/src/main/java/weaver/chaoyang/he/hcy_fengtianfangzhi/rollbackmoneytoworkflow/acton/RollbackMoneyToWorkflowAction.java b/src/main/java/weaver/chaoyang/he/hcy_fengtianfangzhi/rollbackmoneytoworkflow/acton/RollbackMoneyToWorkflowAction.java new file mode 100644 index 0000000..5b6c2e7 --- /dev/null +++ b/src/main/java/weaver/chaoyang/he/hcy_fengtianfangzhi/rollbackmoneytoworkflow/acton/RollbackMoneyToWorkflowAction.java @@ -0,0 +1,119 @@ +package weaver.chaoyang.he.hcy_fengtianfangzhi.rollbackmoneytoworkflow.acton; + +import aiyh.utils.Util; +import org.apache.log4j.Logger; +import org.jetbrains.annotations.NotNull; +import weaver.conn.RecordSet; +import weaver.interfaces.workflow.action.Action; +import weaver.soa.workflow.request.Cell; +import weaver.soa.workflow.request.DetailTable; +import weaver.soa.workflow.request.RequestInfo; +import weaver.soa.workflow.request.Row; + +import java.util.ArrayList; +import java.util.HashMap; +import java.util.List; +import java.util.Map; + +/** + *

对公付款申请(一般采购)明细表二:验收入库单中的已申请金额/未申请金额计算后需要反填到验收入库单中

+ * @Author hcy + * @Date 2023/1/30 19:57 + */ +public class RollbackMoneyToWorkflowAction implements Action { + + private Logger logger = Util.getLogger(); + + @Override + public String execute(RequestInfo requestInfo) { + try { + Map>> detailTableValue = this.getDetailTableValue(requestInfo); + + List> lists = detailTableValue.get("2");//获取到明细表2中的所有数据 + logger.info("lists=="+ lists); + for (Map list : lists) { + String ysrkdh = Util.null2String(list.get("ysrkdh"));//验收入库单号字段 + logger.info("验收入库单号==="+ysrkdh); + String bcfkjehs = Util.null2String(list.get("bcfkjehs"));//本次付款金额(含税) + logger.info("本次付款金额(含税)---bcfkjehs==="+bcfkjehs); + String selectValueSql = "select hszje,ysqje from uf_ysrkd where id=?"; + RecordSet recordSet = new RecordSet(); + boolean b = recordSet.executeQuery(selectValueSql, ysrkdh); + logger.info("b是否执行==="+b); + Double hszjeTotal = 0.0;//wszje 含税总金额 + Double ysqjeTotal = 0.0;//ysqje 已申请金额 + Double wsqjeTotal = 0.0;//wsqje 未申请金额 + if (recordSet.next()) { + String hszje = Util.null2String(recordSet.getString("hszje"));//hszje 含税总金额 + String ysqje = Util.null2String(recordSet.getString("ysqje"));// ysqje 已申请金额 + + logger.info("含税总金额---hszje==="+ysqje); + if (!"".equals(ysqje) && !"".equals(bcfkjehs)){ + Double ysqjeDouble = Double.parseDouble(ysqje); + Double bcfkjehsDouble = Double.parseDouble(bcfkjehs); + ysqjeTotal = ysqjeDouble + bcfkjehsDouble; + } + if (!"".equals(hszje)) { + hszjeTotal = Double.parseDouble(hszje); + } + + } + logger.info("hszjeTotal==="+ysqjeTotal); + + String updateYsqje_Sql = "update uf_ysrkd set ysqje = ? where id = ?"; + boolean b1 = recordSet.executeUpdate(updateYsqje_Sql, ysqjeTotal, ysrkdh); + logger.info("b1是否执行==="+b1); + + //开始更新未申请金额 = 含税总金额 - 已申请金额 :wsqje = hszje - ysqje + wsqjeTotal = hszjeTotal - ysqjeTotal; + String updateWsqje_sql = "update uf_ysrkd set wsqje = ? where id = ?"; + boolean b2 = recordSet.executeUpdate(updateWsqje_sql, wsqjeTotal, ysrkdh); + logger.info("b2是否执行==="+b2); + } + } catch (NumberFormatException e) { + e.printStackTrace(); + logger.info("NumberFormatException==="+e); + } + return Action.SUCCESS; + } + + + + /** + *

获取所有明细数据

+ * + * @return 以明细表需要为键,以明细表数据为值的键值对明细数据信息 + */ + protected Map>> getDetailTableValue(RequestInfo requestInfo) { + DetailTable[] detailTableArr = requestInfo.getDetailTableInfo().getDetailTable(); + Map>> detailDataList = new HashMap<>((int) Math.ceil(detailTableArr.length * 0.75)); + for (DetailTable detailTable : detailTableArr) { + List> detailData = getDetailValue(detailTable); + detailDataList.put(detailTable.getId(), detailData); + } + return detailDataList; + } + + /** + *

根据明细表信息获取明细表数据

+ * + * @param detailTable 明细表对象 + * @return 明细表数据 + */ + @NotNull + private List> getDetailValue(DetailTable detailTable) { + Row[] rowArr = detailTable.getRow(); + List> detailData = new ArrayList<>(rowArr.length); + for (Row row : rowArr) { + Cell[] cellArr = row.getCell(); + Map rowData = new HashMap<>((int) Math.ceil(cellArr.length * 0.75)); + for (Cell cell : cellArr) { + String fieldName = cell.getName(); + String value = cell.getValue(); + rowData.put(fieldName, value); + } + detailData.add(rowData); + } + return detailData; + } +} diff --git a/src/main/java/weaver/chaoyang/he/hcy_fengtianfangzhi/update_lqts/action/UpdateLqtsAction.java b/src/main/java/weaver/chaoyang/he/hcy_fengtianfangzhi/update_lqts/action/UpdateLqtsAction.java new file mode 100644 index 0000000..e43a010 --- /dev/null +++ b/src/main/java/weaver/chaoyang/he/hcy_fengtianfangzhi/update_lqts/action/UpdateLqtsAction.java @@ -0,0 +1,83 @@ +package weaver.chaoyang.he.hcy_fengtianfangzhi.update_lqts.action; + +import aiyh.utils.Util; +import org.apache.log4j.Logger; +import weaver.conn.RecordSet; +import weaver.interfaces.schedule.BaseCronJob; + +import java.text.ParseException; +import java.text.SimpleDateFormat; +import java.util.Date; + + +/** + *

调用进项发票信息获取接口,将返回值回写到发票台账

+ * @Author hcy + * @Date 2023/1/30 15:49 + */ +public class UpdateLqtsAction extends BaseCronJob { + + private Logger logger = Util.getLogger(); + @Override + public void execute() { + try { + RecordSet recordSet = new RecordSet(); + String getDB_Sql = "select * from uf_clgm_dt1"; + boolean b = recordSet.executeQuery(getDB_Sql); + logger.info("getDB_Sql---b---是否执行==="+b); + + while (recordSet.next()){ + String sjnq = recordSet.getString("sjnq");//实际纳期 + String id = recordSet.getString("id"); + logger.info("实际纳期==="+sjnq); + String currentTime = this.getCurrentTime();//系统当前日期 + long daySub = getDaySub(currentTime, sjnq); + RecordSet recordSet1 = new RecordSet(); + String update_lqts_Sql ="update uf_clgm_dt1 set lqts = ? where id = ?"; + boolean b1 = recordSet1.executeUpdate(update_lqts_Sql, daySub, id); + logger.info("b1是否执行=="+b1); + } + } catch (Exception e) { + e.printStackTrace(); + logger.info("Exception==="+e); + } + } + + /** + *

日期相减得到的天数

+ * @param beginDateStr,endDateStr + * @return long + * @author hcy + */ + public static long getDaySub(String beginDateStr, String endDateStr) { + + long day = 0; + SimpleDateFormat format = new SimpleDateFormat("yyyy-MM-dd"); + Date beginDate; + Date endDate; + try { + beginDate = format.parse(beginDateStr); + endDate = format.parse(endDateStr); + day = (endDate.getTime() - beginDate.getTime()) / (24 * 60 * 60 * 1000); + } catch (ParseException e) { + e.printStackTrace(); + } + System.out.println("day:" + day); + + return day; + } + + /** + *

返回系统当前日期时间

+ * @param + * @return String 当前日期 + * @author hcy + */ + public String getCurrentTime(){ + SimpleDateFormat dateFormat = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss"); + Date date = new Date(); + String currentTime = dateFormat.format(date); + return currentTime; + } + +} diff --git a/src/main/java/weaver/chaoyang/he/hcy_fengtianfangzhi/updatepdfname/action/UpdatePDFNameAction.java b/src/main/java/weaver/chaoyang/he/hcy_fengtianfangzhi/updatepdfname/action/UpdatePDFNameAction.java new file mode 100644 index 0000000..3a995ad --- /dev/null +++ b/src/main/java/weaver/chaoyang/he/hcy_fengtianfangzhi/updatepdfname/action/UpdatePDFNameAction.java @@ -0,0 +1,132 @@ +package weaver.chaoyang.he.hcy_fengtianfangzhi.updatepdfname.action; + +import aiyh.utils.Util; +import org.apache.log4j.Logger; +import weaver.conn.RecordSet; +import weaver.interfaces.workflow.action.Action; +import weaver.soa.workflow.request.*; + +import java.text.SimpleDateFormat; +import java.util.*; + + +/** + *

配置节点后附加操作,用于修改流程存为文档pdf的名称

+ * @Author hcy + * @Date 2023/4/8 0:23 + */ +public class UpdatePDFNameAction implements Action { + /** + * 日志 + */ + private Logger logger = Util.getLogger(); + + public String execute(RequestInfo requestInfo) { + Map mainTableMap = this.getMainTableValue(requestInfo);//yczwzd + String docid = mainTableMap.get("yczwzd");//隐藏正文字段 ---用于存放主文书(定期品)和注文书(临期品)的pdf字段 是DocImageFile中的docid + logger.info("docid=="+docid); + String imagefilename = this.getImagefilename(mainTableMap); + logger.info("修改的文件名称==="+imagefilename); + RecordSet recordSet = new RecordSet(); + String selectpdfSql = "select imagefilename from DocImageFile where docid = ?"; + recordSet.executeQuery(selectpdfSql, docid); + recordSet.next(); + String imagefilename1 = Util.null2String(recordSet.getString("imagefilename")); + logger.info("修改前的文件名称为==="+imagefilename1); + if (!"".equals(imagefilename1)&&imagefilename1.endsWith(".pdf")){ + String updatePdfNameSql = "update DocImageFile set imagefilename = ? where docid = ?"; + boolean updateFileName = recordSet.executeUpdate(updatePdfNameSql, imagefilename, docid); + logger.info("修改文件名称是否成功"+updateFileName); + } + return Action.SUCCESS; + } + + private String getImagefilename(Map mainTableDataMap) { + + //订单编号 :sqdh + //供应商 : gys + //申请人部门 : sqrbm + String sqdh = mainTableDataMap.get("sqdh");//订单编号 + String gys = mainTableDataMap.get("gys");//供应商 + String sqrbm = mainTableDataMap.get("sqrbm");//申请人部门 + RecordSet recordSet1 = new RecordSet(); + String getGysValueSql = "select gysqm from uf_gyszsjxx where id=?"; + recordSet1.executeQuery(getGysValueSql,gys); + recordSet1.next(); + String gysValue = recordSet1.getString("gysqm");//供应商的值 + String getSqrbmSql = "select departmentname from hrmdepartment where id = ?"; + recordSet1.executeQuery(getSqrbmSql,sqrbm); + recordSet1.next(); + String departmentname = recordSet1.getString("departmentname");//申请人部门 + return sqdh+"_"+gysValue+"_"+departmentname+"_"+this.getSystemDate()+".pdf"; + } + + + /** + *

获取系统当年份

+ * @return String + * @author hcy + * 2023/3/15 13:52 + */ + public String getSystemDate(){ + Date date = new Date(); + SimpleDateFormat dateFormat = new SimpleDateFormat("yyyy-MM-dd"); + return dateFormat.format(date); + } + + /** + *

获取流程主表数据

+ * + * @return 流程主表数据 + */ + protected Map getMainTableValue(RequestInfo requestInfo) { +// 获取主表数据 + Property[] propertyArr = requestInfo.getMainTableInfo().getProperty(); + if (null == propertyArr) { + return Collections.emptyMap(); + } + Map mainTable = new HashMap<>((int) Math.ceil(propertyArr.length * 1.4)); + for (Property property : propertyArr) { + String fieldName = property.getName(); + String value = property.getValue(); + mainTable.put(fieldName, value); + } + return mainTable; + } + /** + *

获取所有明细数据

+ * + * @return 以明细表需要为键,以明细表数据为值的键值对明细数据信息 + */ + protected Map>> getDetailTableValue(RequestInfo requestInfo) { + DetailTable[] detailTableArr = requestInfo.getDetailTableInfo().getDetailTable(); + Map>> detailDataList = new HashMap<>((int) Math.ceil(detailTableArr.length * 0.75)); + for (DetailTable detailTable : detailTableArr) { + List> detailData = getDetailValue(detailTable); + detailDataList.put(detailTable.getId(), detailData); + } + return detailDataList; + } + + /** + *

根据明细表信息获取明细表数据

+ * + * @param detailTable 明细表对象 + * @return 明细表数据 + */ + private List> getDetailValue(DetailTable detailTable) { + Row[] rowArr = detailTable.getRow(); + List> detailData = new ArrayList<>(rowArr.length); + for (Row row : rowArr) { + Cell[] cellArr = row.getCell(); + Map rowData = new HashMap<>((int) Math.ceil(cellArr.length * 0.75)); + for (Cell cell : cellArr) { + String fieldName = cell.getName(); + String value = cell.getValue(); + rowData.put(fieldName, value); + } + detailData.add(rowData); + } + return detailData; + } +} diff --git a/src/main/java/weaver/chaoyang/he/hcy_pcn/noticeaftersigned/action/NoticeAfterSigned.java b/src/main/java/weaver/chaoyang/he/hcy_pcn/noticeaftersigned/action/NoticeAfterSigned.java new file mode 100644 index 0000000..51e8384 --- /dev/null +++ b/src/main/java/weaver/chaoyang/he/hcy_pcn/noticeaftersigned/action/NoticeAfterSigned.java @@ -0,0 +1,225 @@ +package weaver.chaoyang.he.hcy_pcn.noticeaftersigned.action; + +import aiyh.utils.httpUtil.ResponeVo; +import aiyh.utils.httpUtil.util.HttpUtils; +import org.apache.log4j.Logger; +import weaver.conn.RecordSet; +import weaver.interfaces.workflow.action.Action; +import weaver.soa.workflow.request.Cell; +import weaver.soa.workflow.request.DetailTable; +import weaver.soa.workflow.request.RequestInfo; +import weaver.soa.workflow.request.Row; +import weaver.workflow.request.RequestManager; +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.ArrayList; +import java.util.HashMap; +import java.util.List; +import java.util.Map; + +public class NoticeAfterSigned implements Action { + + + private String uniqueCode;//唯一标识 + private String apikey; + private String accountMessageTableName; //台账数据表名 + private String statusName; //状态名 + private String updateFieldName; //更新标识字段 + private String valueUpdateFiledName;//明细字段名 + private String detailkey;//哪个明细表 + + private final Logger log = aiyh.utils.Util.getLogger(); + private final DealWithMapping dealWithMapping = new DealWithMapping(); + + @Override + public String execute(RequestInfo requestInfo) { + log.info("NoticeAfterSigned begin;requestid:" + requestInfo.getRequestid()); + RequestManager requestManager = requestInfo.getRequestManager(); + try{ + + String tableName = requestManager.getBillTableName(); + String requestid = requestInfo.getRequestid(); + RecordSet rs = new RecordSet(); + String sql = "select * from " + tableName + " where requestid = ?"; + Map params = new HashMap<>();//请求体 + dealWithMapping.setMainTable(tableName); + if (rs.executeQuery(sql,requestid) && rs.next()) { + RequestMappingConfig conf = dealWithMapping.treeDealWithUniqueCode(uniqueCode); + String requestUrl = conf.getRequestUrl();//目标url + log.info("获取到的url为:"+requestUrl); + + //请求头 + HashMap headers = new HashMap<>(); + headers.put("Accept", MediaType.APPLICATION_JSON); + headers.put("Content-Type", "application/json"); + headers.put("apikey", apikey); + HttpUtils httpUtils = new HttpUtils(); + + //请求体 + List> li = new ArrayList<>(); //定义一个map元素的List集合用来存放 + List requestListParam = dealWithMapping.getRequestListParam(rs, conf); + for (Object requestParam : requestListParam) { + params = (Map) requestParam; + log.info("得到的请求体内容为:"+params); + try { + ResponeVo responeVo = httpUtils.apiPost(requestUrl, params, headers); + log.info("接口返回值===="+responeVo); + int code = responeVo.getCode(); + log.info("状态码为:code===="+code); + Map m = new HashMap<>(); + m.put("status",""); + + if (code == 200){ + Map entityMap = responeVo.getEntityMap(); + int errcode = (int)entityMap.get("errcode"); + int status = 4; + //根据状态码更新台账合同状态 + if (errcode==200){ + status = 0; + }else if (errcode==1000089){ + status = 1; + }else if (errcode==1000090){ + status = 2; + }else if (errcode==1000091){ + status = 3; + } + m.put("status",status); + li.add(m); + + }else { + requestManager.setMessageid(String.valueOf(System.currentTimeMillis())); + requestManager.setMessagecontent("对方接口链接超时"); + return Action.FAILURE_AND_CONTINUE; + } + } catch (IOException e) { + log.info("调用接口异常报错==="+e); + e.printStackTrace(); + } + } + try { + Map>> detailTableValue = this.getDetailTableValue(requestInfo); + + List> values = detailTableValue.get(detailkey); + for(int i = 0;i < values.size();i ++){ + Map m = values.get(i); + String value = m.get(valueUpdateFiledName); + int status = (int) li.get(i).get("status"); + log.info("li===="+li); + String updateSql = "update "+accountMessageTableName+" set "+statusName+"= ? where "+updateFieldName+"= ?"; + log.info("updateSql更新的sql语句"+updateSql); + boolean b = rs.executeUpdate(updateSql, status, value); + log.info("更新合同台账信息===="+b); + } + } catch (Exception e) { + log.info("台账状态更新异常:"+e); + e.printStackTrace(); + } + } + log.info("action done;requestid:" + requestid); + return Action.SUCCESS; + }catch (Exception e1){ + log.error("requestid:" + requestInfo.getRequestid() + ";mesage:" + e1.getMessage() + ";e:" + e1); + requestManager.setMessageid(String.valueOf(System.currentTimeMillis())); + requestManager.setMessagecontent("action 异常,请联系管理员!"); + return Action.FAILURE_AND_CONTINUE; + } + } + + public String getUniqueCode() { + return uniqueCode; + } + + public void setUniqueCode(String uniqueCode) { + this.uniqueCode = uniqueCode; + } + + public String getApikey() { + return apikey; + } + + public void setApikey(String apikey) { + this.apikey = apikey; + } + + public String getAccountMessageTableName() { + return accountMessageTableName; + } + + public void setAccountMessageTableName(String accountMessageTableName) { + this.accountMessageTableName = accountMessageTableName; + } + + public String getStatusName() { + return statusName; + } + + public void setStatusName(String statusName) { + this.statusName = statusName; + } + + public String getUpdateFieldName() { + return updateFieldName; + } + + public void setUpdateFieldName(String updateFieldName) { + this.updateFieldName = updateFieldName; + } + + public String getValueUpdateFiledName() { + return valueUpdateFiledName; + } + + public void setValueUpdateFiledName(String valueUpdateFiledName) { + this.valueUpdateFiledName = valueUpdateFiledName; + } + + public String getDetailkey() { + return detailkey; + } + + public void setDetailkey(String detailkey) { + this.detailkey = detailkey; + } + + /** + *

获取所有明细数据

+ * + * @return 以明细表需要为键,以明细表数据为值的键值对明细数据信息 + */ + protected Map>> getDetailTableValue(RequestInfo requestInfo) { + DetailTable[] detailTableArr = requestInfo.getDetailTableInfo().getDetailTable(); + Map>> detailDataList = new HashMap<>((int) Math.ceil(detailTableArr.length * 0.75)); + for (DetailTable detailTable : detailTableArr) { + List> detailData = getDetailValue(detailTable); + detailDataList.put(detailTable.getId(), detailData); + } + return detailDataList; + } + + /** + *

根据明细表信息获取明细表数据

+ * + * @param detailTable 明细表对象 + * @return 明细表数据 + */ + private List> getDetailValue(DetailTable detailTable) { + Row[] rowArr = detailTable.getRow(); + List> detailData = new ArrayList<>(rowArr.length); + for (Row row : rowArr) { + Cell[] cellArr = row.getCell(); + Map rowData = new HashMap<>((int) Math.ceil(cellArr.length * 0.75)); + for (Cell cell : cellArr) { + String fieldName = cell.getName(); + String value = cell.getValue(); + rowData.put(fieldName, value); + } + detailData.add(rowData); + } + return detailData; + } + + +} diff --git a/src/main/java/weaver/chaoyang/he/hcy_pcn/sendfieldstoothersystem/action/SendFieldsAction.java b/src/main/java/weaver/chaoyang/he/hcy_pcn/sendfieldstoothersystem/action/SendFieldsAction.java new file mode 100644 index 0000000..804c837 --- /dev/null +++ b/src/main/java/weaver/chaoyang/he/hcy_pcn/sendfieldstoothersystem/action/SendFieldsAction.java @@ -0,0 +1,146 @@ +package weaver.chaoyang.he.hcy_pcn.sendfieldstoothersystem.action; + +import aiyh.utils.httpUtil.HttpMultipartFile; +import aiyh.utils.httpUtil.ResponeVo; +import aiyh.utils.httpUtil.util.HttpUtils; +import cn.hutool.crypto.SecureUtil; +import org.apache.commons.codec.binary.Hex; +import org.apache.log4j.Logger; +import weaver.conn.RecordSet; +import weaver.general.Util; +import weaver.interfaces.workflow.action.Action; +import weaver.soa.workflow.request.RequestInfo; +import weaver.xiao.commons.config.entity.MultipartFile; +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.security.SecureRandom; +import java.util.ArrayList; +import java.util.HashMap; +import java.util.List; +import java.util.Map; + +public class SendFieldsAction implements Action { + + private String clientId; //由SBS提供clientId + private String clientSecret; //由SBS提供clientSecret + private final DealWithMapping dealWithMapping = new DealWithMapping(); + private String onlyMark;//用于查询配置表的唯一标识 + private final Logger log = aiyh.utils.Util.getLogger(); + + public String execute(RequestInfo requestInfo) { + String tableName = requestInfo.getRequestManager().getBillTableName(); + String requestId = requestInfo.getRequestid(); + RecordSet rs = new RecordSet(); + String sql = "select * from " + tableName + " where requestid = ?"; + log.info("sql======>" + sql); + String response = ""; + int code; + String data = ""; + dealWithMapping.setMainTable(tableName); + try { + if (rs.executeQuery(sql, requestId) && rs.next()) { + RequestMappingConfig config = dealWithMapping.treeDealWithUniqueCode(onlyMark); + String post_url = config.getRequestUrl(); + // 生成的map数据 + Map mapBodyParam = dealWithMapping.getRequestParam(rs, config); + // 获取多文件数据信息 + List multipartFileList = dealWithMapping.getMultipartFileList(); + List multipartFiles = new ArrayList<>(); + for (MultipartFile multipartFile : multipartFileList) { + HttpMultipartFile multipart + = new HttpMultipartFile(); + multipart.setFileKey(multipartFile.getFileKey()); + multipart.setFileName(multipartFile.getFileName()); + multipart.setFileSize(multipartFile.getFileSize()); + multipart.setStream(multipartFile.getStream()); + multipartFiles.add(multipart); + } + // 请求头 + String timestamp = String.valueOf(System.currentTimeMillis()); + String nonce = this.getRandomNumber(); + HashMap headers = new HashMap<>(); + headers.put("Content-Type", MediaType.MULTIPART_FORM_DATA); + headers.put("X-Timestamp", timestamp); + headers.put("X-Client-Id", clientId); + headers.put("X-Nonce", nonce); + headers.put("user-agent","Mozilla/5.0 (Macintosh; Intel Mac OS X 10_15_7) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/107.0.0.0 Safari/537.36"); + headers.put("X-Sign", this.sign(timestamp, nonce)); + HttpUtils httpUtils = new HttpUtils(); + try { +// httpUtils.uploadFileByInputStream();//调用文件上传的接口 + ResponeVo responeVo = httpUtils.apiPutUploadFiles(post_url, multipartFiles, mapBodyParam, headers); + response = Util.null2String(responeVo.getEntityString()); + code = responeVo.getCode(); + if (code == 200) { + Map entityMap = responeVo.getEntityMap(); + data = String.valueOf(entityMap.get("data")); + if (data.equals("true")) { + return Action.SUCCESS; + } else { + return Action.FAILURE_AND_CONTINUE; + } + } else { + log.info("状态请求失败,对方相应code不为200"); + return Action.FAILURE_AND_CONTINUE; + } + } catch (IOException e) { + log.info("fetch " + post_url + " error!"); + throw e; + } + } + } catch (Exception e) { + log.error("action execute fail! error msg : \n" + aiyh.utils.Util.getErrString(e)); + } + return Action.FAILURE_AND_CONTINUE; + } + + public String getClientId() { + return clientId; + } + + public void setClientId(String clientId) { + this.clientId = clientId; + } + + public String getClientSecret() { + return clientSecret; + } + + public void setClientSecret(String clientSecret) { + this.clientSecret = clientSecret; + } + + public String getOnlyMark() { + return onlyMark; + } + + public void setOnlyMark(String onlyMark) { + this.onlyMark = onlyMark; + } + + /** + * 随机码 + */ + private String getRandomNumber() { + byte[] result = new byte[16]; + SecureRandom secRandom = new SecureRandom(); + secRandom.nextBytes(result); + return Hex.encodeHexString(result); + } + + + /** + * POST签名 + */ + private String sign(String timestamp, String nonce) { + StringBuilder sb = new StringBuilder(); + sb.append(timestamp).append(nonce).append(clientSecret); + log.info("body签名字符串:{},timestamp:{},nonce:{}"); + System.out.println("签名:" + SecureUtil.md5(sb.toString())); + return SecureUtil.md5(sb.toString()); + } + +} diff --git a/src/main/java/weaver/chaoyang/he/hcy_pcn/workflowsetvalue/action/SubmitAtoBAction.java b/src/main/java/weaver/chaoyang/he/hcy_pcn/workflowsetvalue/action/SubmitAtoBAction.java new file mode 100644 index 0000000..8103b5a --- /dev/null +++ b/src/main/java/weaver/chaoyang/he/hcy_pcn/workflowsetvalue/action/SubmitAtoBAction.java @@ -0,0 +1,116 @@ +package weaver.chaoyang.he.hcy_pcn.workflowsetvalue.action; + +import org.apache.log4j.Logger; +import weaver.conn.RecordSet; +import weaver.general.Util; +import weaver.interfaces.workflow.action.Action; +import weaver.soa.workflow.request.Property; +import weaver.soa.workflow.request.RequestInfo; +import weaver.soa.workflow.request.RequestService; + +import java.util.HashMap; +import java.util.Map; +import java.util.Set; + +/** + * 业务需求在A流程归档前增加aciton, + * 将A中的部分字段信息(包括附件), + * 根据requestid更新到B流程中, + * 并且将B流程提交到下一节点。 + */ +public class SubmitAtoBAction implements Action { + + /** + * 目标请求参数字段 + */ + private String targetRequestField; + + /** + * 配置文件唯一标识 + */ + private String uniqueFieldId; + + private final Logger log = aiyh.utils.Util.getLogger(); + + + public String execute(RequestInfo requestInfo) { + + String sql = "select * from uf_lczdzdypzb where wybs = '" + uniqueFieldId +"'"; //查询uf_lczdzdypzb流程字段值对应配置表的数据 + RecordSet rs = new RecordSet(); //创建sql对象 + RecordSet rs02 = new RecordSet();//创建sql02对象 + rs.executeQuery(sql);//执行sql语句 + + Map tableInfo = this.getWfMainTableInfo(requestInfo);//原流程数据 + + String mainId = "";//查询主表中id,用于对应明细表中mainid + String mbzd="";//目标字段 + String yzd = "";//原字段 + String setRule = "";//update中set条件 + Map mapKey = new HashMap<>(); + + if (rs.next()){ + mainId = rs.getString("id");//查询主表中id,用于对应明细表中mainid + log.info("查询主表中id,用于对应明细表中mainid---mainid==="+mainId); + //todo 通过workflowid查数据库表获取表名 + String sql_dt1 = "select ck1.fieldname mbzd, ck.fieldname yzd from uf_lczdzdypzb_dt1 dt left join workflow_field_table_view ck on dt.yzd = ck.id left join workflow_field_table_view ck1 on dt.mbzd = ck1.id where mainid = ?";//查询明细表 + rs02.executeQuery(sql_dt1,mainId);//执行明细表sql语句 + while (rs02.next()){ + mbzd = rs02.getString("mbzd");//目标字段 + yzd = rs02.getString("yzd");//原字段 + mapKey.put(mbzd,yzd); + log.info("明细表执行结果>>>>>>>>>>"+"目标字段="+mbzd+"-----原字段="+yzd); + } + RequestService requestService=new RequestService(); + //todo 获取表名 + String targetRequestId = tableInfo.get(targetRequestField); + String tableName = requestService.getRequest(Util.getIntValue(targetRequestId)).getRequestManager().getBillTableName(); + Set keySet = mapKey.keySet(); + for (String s : keySet) { + String valueYzd = tableInfo.get(mapKey.get(s)); + setRule += s + "= " + "'" + valueYzd + "'" +" ,"; + } + setRule = setRule.substring(0,setRule.length()-1); + log.info("update中set条件,setRule==="+setRule); + + String sqlmbLc = "update "+tableName+" set " + setRule + " where requestid = ?";//update 目标流程 set 目标字段 = 原字段 where requestid = ? ; + rs.executeUpdate(sqlmbLc,targetRequestId); + log.info("更新语句update>>>>>>"+ sqlmbLc +"===requestid="+targetRequestId); + log.info("B流程开始提交"); + boolean b = requestService.nextNodeBySubmit(requestService.getRequest(Util.getIntValue(targetRequestId)), Util.getIntValue(targetRequestId), 1, "action自动提交流程(流程字段赋值)"); + + log.info("B流程提交结束"); + } + return Action.SUCCESS; + } + + + public String getTargetRequestField() { + return targetRequestField; + } + + public void setTargetRequestField(String targetRequestField) { + this.targetRequestField = targetRequestField; + } + + public String getUniqueFieldId() { + return uniqueFieldId; + } + + public void setUniqueFieldId(String uniqueFieldId) { + this.uniqueFieldId = uniqueFieldId; + } + + /** + * 获取流程主表数据 + * + * @param requestInfo 流程信息对象 + * @return Map key 字段名 value 字段值 + */ + public Map getWfMainTableInfo(RequestInfo requestInfo) { + Map map = new HashMap<>(); + for (Property property : requestInfo.getMainTableInfo().getProperty()) { + map.put(property.getName(), property.getValue()); + } + return map; + } +} diff --git a/src/main/java/weaver/chaoyang/he/hcy_pcn/workflowsetvalue/action/SubmitAtoBActionCopy.java b/src/main/java/weaver/chaoyang/he/hcy_pcn/workflowsetvalue/action/SubmitAtoBActionCopy.java new file mode 100644 index 0000000..dc1f8af --- /dev/null +++ b/src/main/java/weaver/chaoyang/he/hcy_pcn/workflowsetvalue/action/SubmitAtoBActionCopy.java @@ -0,0 +1,116 @@ +package weaver.chaoyang.he.hcy_pcn.workflowsetvalue.action; + +import org.apache.log4j.Logger; +import weaver.conn.RecordSet; +import weaver.general.Util; +import weaver.interfaces.workflow.action.Action; +import weaver.soa.workflow.request.Property; +import weaver.soa.workflow.request.RequestInfo; +import weaver.soa.workflow.request.RequestService; + +import java.util.HashMap; +import java.util.Map; +import java.util.Set; + +/** + * 业务需求在A流程归档前增加aciton, + * 将A中的部分字段信息(包括附件), + * 根据requestid更新到B流程中, + * 并且将B流程提交到下一节点。 + */ +public class SubmitAtoBActionCopy implements Action { + + /** + * 目标请求参数字段 + */ + private String targetRequestField; + + /** + * 配置文件唯一标识 + */ + private String uniqueFieldId; + + private final Logger log = aiyh.utils.Util.getLogger(); + + + public String execute(RequestInfo requestInfo) { + + String sql = "select * from uf_lczdzdypzb where wybs = '" + uniqueFieldId +"'"; //查询uf_lczdzdypzb流程字段值对应配置表的数据 + RecordSet rs = new RecordSet(); //创建sql对象 + RecordSet rs02 = new RecordSet();//创建sql02对象 + rs.executeQuery(sql);//执行sql语句 + + Map tableInfo = this.getWfMainTableInfo(requestInfo);//原流程数据 + + String mainId = "";//查询主表中id,用于对应明细表中mainid + String mbzd="";//目标字段 + String yzd = "";//原字段 + String setRule = "";//update中set条件 + Map mapKey = new HashMap<>(); + + if (rs.next()){ + mainId = rs.getString("id");//查询主表中id,用于对应明细表中mainid + log.info("查询主表中id,用于对应明细表中mainid---mainid==="+mainId); + //todo 通过workflowid查数据库表获取表名 + String sql_dt1 = "select ck1.fieldname mbzd, ck.fieldname yzd from uf_lczdzdypzb_dt1 dt left join workflow_field_table_view ck on dt.yzd = ck.id left join workflow_field_table_view ck1 on dt.mbzd = ck1.id where mainid = ?";//查询明细表 + rs02.executeQuery(sql_dt1,mainId);//执行明细表sql语句 + while (rs02.next()){ + mbzd = rs02.getString("mbzd");//目标字段 + yzd = rs02.getString("yzd");//原字段 + mapKey.put(mbzd,yzd); + log.info("明细表执行结果>>>>>>>>>>"+"目标字段="+mbzd+"-----原字段="+yzd); + } + RequestService requestService=new RequestService(); + //todo 获取表名 + String targetRequestId = tableInfo.get(targetRequestField); + String tableName = requestService.getRequest(Util.getIntValue(targetRequestId)).getRequestManager().getBillTableName(); + Set keySet = mapKey.keySet(); + for (String s : keySet) { + String valueYzd = tableInfo.get(mapKey.get(s)); + setRule += s + "= " + "'" + valueYzd + "'" +" ,"; + } + setRule = setRule.substring(0,setRule.length()-1); + log.info("update中set条件,setRule==="+setRule); + + String sqlmbLc = "update "+tableName+" set " + setRule + " where requestid = ?";//update 目标流程 set 目标字段 = 原字段 where requestid = ? ; + rs.executeUpdate(sqlmbLc,targetRequestId); + log.info("更新语句update>>>>>>"+ sqlmbLc +"===requestid="+targetRequestId); + log.info("B流程开始提交"); + boolean b = requestService.nextNodeBySubmit(requestService.getRequest(Util.getIntValue(targetRequestId)), Util.getIntValue(targetRequestId), 1, "action自动提交流程(流程字段赋值)"); + + log.info("B流程提交结束"); + } + return Action.SUCCESS; + } + + + public String getTargetRequestField() { + return targetRequestField; + } + + public void setTargetRequestField(String targetRequestField) { + this.targetRequestField = targetRequestField; + } + + public String getUniqueFieldId() { + return uniqueFieldId; + } + + public void setUniqueFieldId(String uniqueFieldId) { + this.uniqueFieldId = uniqueFieldId; + } + + /** + * 获取流程主表数据 + * + * @param requestInfo 流程信息对象 + * @return Map key 字段名 value 字段值 + */ + public Map getWfMainTableInfo(RequestInfo requestInfo) { + Map map = new HashMap<>(); + for (Property property : requestInfo.getMainTableInfo().getProperty()) { + map.put(property.getName(), property.getValue()); + } + return map; + } +} diff --git a/src/main/java/weaver/chaoyang/he/hcy_yihong/filterinvoice/FilterInvoiceService.java b/src/main/java/weaver/chaoyang/he/hcy_yihong/filterinvoice/FilterInvoiceService.java new file mode 100644 index 0000000..5c6425e --- /dev/null +++ b/src/main/java/weaver/chaoyang/he/hcy_yihong/filterinvoice/FilterInvoiceService.java @@ -0,0 +1,31 @@ +package weaver.chaoyang.he.hcy_yihong.filterinvoice; + +import aiyh.utils.Util; +import com.engine.common.service.BrowserTabService; +import com.engine.common.service.impl.BrowserTabServiceImpl; +import com.engine.core.cfg.annotation.ServiceDynamicProxy; +import com.engine.core.cfg.annotation.ServiceMethodDynamicProxy; +import com.engine.core.impl.aop.AbstractServiceProxy; +import org.apache.log4j.Logger; + +import java.util.Map; + +@ServiceDynamicProxy(target = BrowserTabServiceImpl.class, desc="实现BrowserTabService对象用于过滤除去航信的数据") +public class FilterInvoiceService extends AbstractServiceProxy implements BrowserTabService { + private final Logger logger = Util.getLogger(); + @Override + @ServiceMethodDynamicProxy(desc="过滤除去AP航信的数据") + public Map list(Map map) { + Map result = (Map)executeMethod(map); + logger.info("result==="+result); + return null; + } + + @Override + public Map update(Map map) { + return null; + } + + + //api/common/browsetab/list?type=293&__random__=1677073032544 +} diff --git a/src/main/java/weaver/chaoyang/he/hcy_yihong/sendinvoicevaluestoaccounttable/action/InvoiceValuesToAccountTableAction.java b/src/main/java/weaver/chaoyang/he/hcy_yihong/sendinvoicevaluestoaccounttable/action/InvoiceValuesToAccountTableAction.java new file mode 100644 index 0000000..162e652 --- /dev/null +++ b/src/main/java/weaver/chaoyang/he/hcy_yihong/sendinvoicevaluestoaccounttable/action/InvoiceValuesToAccountTableAction.java @@ -0,0 +1,326 @@ +package weaver.chaoyang.he.hcy_yihong.sendinvoicevaluestoaccounttable.action; + +import aiyh.utils.Util; +import aiyh.utils.httpUtil.ResponeVo; +import aiyh.utils.httpUtil.util.HttpUtils; +import lombok.SneakyThrows; +import org.apache.log4j.Logger; +import weaver.conn.RecordSet; +import weaver.interfaces.schedule.BaseCronJob; +import weaver.wechat.util.Utils; + +import java.io.IOException; +import java.text.DateFormat; +import java.text.ParseException; +import java.text.SimpleDateFormat; +import java.util.*; + +public class InvoiceValuesToAccountTableAction extends BaseCronJob { + + + private Logger logger = Util.getLogger(); + + private String uniqueFieldId; + + private String url;//请求的接口的url + + @SneakyThrows + @Override + public void execute() { + try { + String sql1 = "select taxNo,belongTo from uf_TaxNo_Config"; + RecordSet rs1 = new RecordSet(); + rs1.executeQuery(sql1); + + //获取上一次操作的日期 + String startDay = Util.getCusConfigValue("getDataTime"); + + //获取当前的日期 + Date date = new Date(); + SimpleDateFormat dateFormat = new SimpleDateFormat("yyyy-MM-dd"); + String endDay = dateFormat.format(date); + + while(rs1.next()){ + + String taxNo = Util.null2String(rs1.getString("taxNo")); + String belongTo = Util.null2String(rs1.getString("belongTo")); + + //请求头 + HashMap headers = new HashMap<>(); + headers.put("User-Agent", "Apifox/1.0.0 (https://www.apifox.cn)"); + headers.put("Content-Type", "application/json"); + + String dateAddday3 = dateAdd3(startDay); + logger.info("开始时间往前推3天--dateAddday3==="+dateAddday3); + //设置请求体 + Map body = new HashMap<>(); + body.put("identity",taxNo); + body.put("startDay",dateAddday3); + body.put("endDay",endDay); + HttpUtils httpUtils = new HttpUtils(); + + ResponeVo responeVo = httpUtils.apiPost(url, body, headers); + int code = responeVo.getCode(); + if (code != 200){ + logger.info("对方接口状态码为:"+code+" 程序执行错误"); + continue; + } + Map entityMap = responeVo.getEntityMap(); + List datas = (List)entityMap.get("data"); + if (datas==null ||datas.isEmpty()){ + logger.info("接口返回主表参数为空,请查询税号是否准确"); + continue; + } + Map totalDataMap = new HashMap(); + String invoice_detail_Mainid = "";//用来判断台账表中是否含有相同记录 + for (Object data : datas){ + totalDataMap = (Map)data;//主表数据 + logger.info("主表数据==="+totalDataMap); + //第五步:查询每一个参数在台账主表中是否包含记录,如果包含执行update操作,如果不包含,执行insert操作。 + Object invoiceCode = totalDataMap.get("invoiceCode");//发票代码 + Object invoiceNum = totalDataMap.get("invoiceNum");//发票号码 + + //需求更新:需要在主表数据中选出卖方税号,这里的卖方税号=供应商库uf_gysxx里面的供应商税号 + RecordSet recordSet = new RecordSet(); + String serllerTaxNo = Utils.null2String(totalDataMap.get("sellerTaxNo"));//销方税号 + String sellerName = Utils.null2String(totalDataMap.get("sellerName"));//销方名称 + logger.info("销方税号--serllerTaxNo==="+serllerTaxNo+"--销方名称---sellerName==="+sellerName); + String getuf_gysxx_countId = "select count(id) countId from uf_gysxx where gyssh = ?"; + boolean getuf_gysxx_countId_boolean = recordSet.executeQuery(getuf_gysxx_countId, serllerTaxNo); + logger.info("getuf_gysxx_countId_boolean是否执行"+getuf_gysxx_countId_boolean); + if (getuf_gysxx_countId_boolean&&recordSet.next()) { + String countId = Utils.null2String(recordSet.getString("countId"));//查询到的数据的条数 + int countIdInt=0; + if (!"".equals(countId)){ + countIdInt = Integer.parseInt(countId); + logger.info("数据一共有几条==="+countId); + } + if (countIdInt==0){ + continue; + } +// if ((!countId.equals("1"))){ +// continue; +// } + RecordSet recordSet1 = new RecordSet(); + String getdataFrom_uf_gysxx = "select qfzd,hkyfjkgs from uf_gysxx where gyssh = ? and gysmc = ?"; + boolean getdataFrom_uf_gysxx_boolean = recordSet1.executeQuery(getdataFrom_uf_gysxx, serllerTaxNo, sellerName); + logger.info("getdataFrom_uf_gysxx_boolean是否执行==="+getdataFrom_uf_gysxx_boolean); + if (getdataFrom_uf_gysxx_boolean && recordSet1.next()){ + String qfzd = Utils.null2String(recordSet1.getString("qfzd"));//区分字段 +// String hkyfjkgs = Utils.null2String(recordSet1.getString("hkyfjkgs"));//货款/运费/进口关税 + if ((!qfzd.equals("0"))){ + continue; + } + } + } + + + //查询发票类型对应配置表:将想要转换的发票类型提前转换 + String queryInvoiceType = "select oaTypeValue from uf_InvoiceType_Mapping where interfaceTypeValue = ?";//改一下 + RecordSet rs2 = new RecordSet(); + rs2.executeQuery(queryInvoiceType,totalDataMap.get("invoiceType")); + if (rs2.next()){ + String oaTypeValue = Util.null2String(rs2.getString("oaTypeValue")); + totalDataMap.put("invoiceType",oaTypeValue);//转换发票类型 + logger.info("转换发票类型==="+oaTypeValue); + }else { + continue; +// totalDataMap.put("invoiceType","-1");//如果接口中的发票类型 + } + + //将时间戳转换成yyyy-MM-dd + String invoiceDate = (String)totalDataMap.get("invoiceDate"); + String new_invoiceDate = this.stampToDate(invoiceDate); + totalDataMap.put("invoiceDate",new_invoiceDate); + logger.info("转换后的时间戳====="+new_invoiceDate); + + //查询台账表中是否包含这个数据 + String sql2 = "select id from fnaInvoiceLedger where invoicecode = ? and invoicenumber = ?"; + + rs2.executeQuery(sql2,invoiceCode,invoiceNum); + if (rs2.next()) { + invoice_detail_Mainid = rs2.getString("id"); + logger.info("===invoice_detail_Mainid==="+invoice_detail_Mainid); + }else{ + invoice_detail_Mainid = ""; + } + + String mainId = ""; + String detailID = ""; + String updateSetkey = "";//当台账表中存在一条一样的数据的时候,我们需要设置更新条件 + List updateSetVaule = new ArrayList<>();//用来处理update条件下,?的赋值 + String insertSetKey = "(";//向台账中插入的key + String insertSetValue = "(";//向台账中插入的value + //第四步:通过配置的配置表获得到客户传的参数和台账字段的对应关系 + String sql3 = "select * from uf_fptzdypzbd where wybs = ?";//查询台账配置表 + if (rs2.executeQuery(sql3,uniqueFieldId)&&rs2.next()) { + mainId = rs2.getString("id");//查询发票台账对应配置表的id对应查询明细表的mainid + String sqlDetail1 = "select * from uf_fptzdypzbd_dt1 where mainid = ?"; + RecordSet rs3 = new RecordSet(); + rs3.executeQuery(sqlDetail1,mainId); + + while(rs3.next()){ + String jkhqcs = rs3.getString("jkhqcs");//接口获取主表参数 + String sjkzcs = rs3.getString("sjkzcs");//数据库中主表参数 + String zhlx = rs3.getString("zhlx");//转换类型 + String zdyz = rs3.getString("zdyz");//自定义值 + if (zhlx!=""&&zhlx.equals("0")){ + updateSetkey += sjkzcs + "=" + "?,"; + insertSetKey += sjkzcs + ","; + insertSetValue += "?"+","; + updateSetVaule.add(totalDataMap.get(jkhqcs)); + }else if (zhlx!=""&&zhlx.equals("1")){ + updateSetkey += sjkzcs + "=" + "?,"; + insertSetKey += sjkzcs + ","; + insertSetValue += "?"+","; + updateSetVaule.add(zdyz); + } + } + //拼接 发票归属人 + updateSetkey = updateSetkey + "userid_new=?"; + updateSetVaule.add(Integer.parseInt(belongTo)); + insertSetKey = insertSetKey+"userid_new)"; + insertSetValue = insertSetValue+"?)"; + + + + logger.info("updateSetKey====="+updateSetkey); + logger.info("updateSetVaule====="+updateSetVaule); + logger.info("insertSetKey====="+insertSetKey); + logger.info("insertSetValue====="+insertSetValue); + } + //查询每一个参数在台账主表中是否包含记录,如果包含执行update操作,如果不包含,执行insert操作。 + logger.info("主表数据id---invoice_detail_Mainid==="+invoice_detail_Mainid); + if (!"".equals(Util.null2String(invoice_detail_Mainid))){//执行更新语句 + RecordSet recordSet4 = new RecordSet(); + String getHxjksflrSql = "select * from fnaInvoiceLedger where id = ?"; + boolean getHxjksflrBool = recordSet4.executeQuery(getHxjksflrSql, invoice_detail_Mainid); + logger.info("getHxjksflrBool是否执行==="+getHxjksflrBool); + String isApInvoice = ""; + if (getHxjksflrBool && recordSet4.next()){ + isApInvoice = Util.null2String(recordSet4.getString("hxjksflr"));// 判断这条数据是不是航信接口导入的数据 + logger.info("isApInvoice==="+isApInvoice); + } + + if ("Y".equals(isApInvoice)){ + updateSetVaule.add(invoiceCode); + updateSetVaule.add(invoiceNum); + String sqlUpdate = "update fnaInvoiceLedger set "+updateSetkey +" where invoicecode = ? and invoicenumber = ? "; + Object[] objects = updateSetVaule.toArray(); + logger.info("sqlUpdate更新的update语句====="+sqlUpdate); + boolean b = rs2.executeUpdate(sqlUpdate, objects); + logger.info("主表的更新语句是否更新=="+b); + } + }else{ + Object[] objects = updateSetVaule.toArray(); + String sqlInsert = "insert into fnaInvoiceLedger "+insertSetKey+" values "+insertSetValue; + logger.info("sqlInsert插入的insert语句======"+sqlInsert); + boolean b = rs2.executeUpdate(sqlInsert, objects); + logger.info("主表的插入语句是否插入=="+b); + } + //查询到刚插入的数据的id作为明细表的mainid + String sqlSelectId = "select id from fnaInvoiceLedger where invoicecode=? and invoicenumber=?"; + RecordSet rs3 = new RecordSet(); + rs3.executeQuery(sqlSelectId,invoiceCode,invoiceNum); + if (rs3.next()){ + detailID= Util.null2String(rs3.getString("id")); + logger.info("detailID==="+detailID); + } + //向台账明细表中插入数据操作 + List details = (List)totalDataMap.get("detail");//明细表数据 + logger.info("明细表数据"+details); + String invoiceDetailSql = "delete from fnainvoiceledgerdetail where mainid = ?";//不管明细表中有没有内容一律删掉 + logger.info("不管明细表中有没有内容一律删掉sql语句==="+invoiceDetailSql); + boolean b1 = rs3.executeUpdate(invoiceDetailSql, detailID); + logger.info("删除操作是否成功b1===="+b1); + Map detailsMap = new HashMap<>(); + if (details ==null || details.isEmpty()){ + logger.info("明细表内容为空!跳出明细表出入循环"); + continue; + } + //开始查询配置表获得到客户传的明细表中参数和台账明细表中字段的对应关系 + for (Object detail : details) { + detailsMap = (Map)detail; + String sqlDetail2 = "select * from uf_fptzdypzbd_dt2 where mainid = ?"; + rs3.executeQuery(sqlDetail2,mainId); + String insertDetailSetKey = "(";//insert条件的拼接字符串1 + String insertDetailSetValue = "(";//insert条件的拼接字符串2 + List listDetail = new ArrayList<>();//用来将?赋值 + while (rs3.next()){ + String jkhqmxbzcs = Util.null2String(rs3.getString("jkhqmxbzcs"));//接口获取明细表中参数 + String jkhqmxbzcslx = Util.null2String(rs3.getString("jkhqmxbzcslx"));//接口获取明细表中参数类型 + String sjkzmxbcs = Util.null2String(rs3.getString("sjkzmxbcs"));//数据库中明细表参数 + String sjkzmxbcslx = Util.null2String(rs3.getString("sjkzmxbcslx"));//数据库中明细表参数类型 + insertDetailSetKey += sjkzmxbcs + ","; + insertDetailSetValue += "?,"; + listDetail.add(detailsMap.get(jkhqmxbzcs)); + + } + insertDetailSetKey = insertDetailSetKey + "mainid)"; + insertDetailSetValue = insertDetailSetValue+"?)"; + listDetail.add(detailID); + logger.info("明细表中用来插入的setkey---insertDetailSetKey==="+insertDetailSetKey); + logger.info("明细表中用来插入的setvalue---insertDetailSetValue==="+insertDetailSetValue); + logger.info("用来拼接?的listDetail"+listDetail); + + String insertIntoDetailSql = "insert into fnainvoiceledgerdetail "+insertDetailSetKey+ "values "+insertDetailSetValue ; + logger.info("insertIntoDetailSql明细表的插入语句==="+insertIntoDetailSql); + boolean b = rs3.executeUpdate(insertIntoDetailSql, listDetail); + logger.info("明细表数据插入是否成功===="+b); + } + } + } + //将当前时间设置到配置表中,作为下一次的开始时间 + logger.info("最后更新到配置表中的时间endDay==="+endDay); + Util.insertOrUpdateConfigValue("getDataTime",endDay,"更新同步时间"); + } catch (IOException e) { + e.printStackTrace(); + } catch (NumberFormatException e) { + e.printStackTrace(); + } + } + + /* + * 将时间戳转换为时间 + */ + public static String stampToDate(String s){ + String res; + SimpleDateFormat simpleDateFormat = new SimpleDateFormat("yyyy-MM-dd"); + long lt = new Long(s); + Date date = new Date(lt); + res = simpleDateFormat.format(date); + return res; + } + + public static String dateAdd3(String dateString){ + DateFormat format = new SimpleDateFormat("yyyy-MM-dd"); //定义日期格式化的格式 + Date classDate = null;//把字符串转化成指定格式的日期 + try { + classDate = format.parse(dateString); + } catch (ParseException e) { + e.printStackTrace(); + } + Calendar calendar = Calendar.getInstance(); //使用Calendar日历类对日期进行加减 + calendar.setTime(classDate); + calendar.add(Calendar.DAY_OF_MONTH, -3); + classDate = calendar.getTime();//获取加减以后的Date类型日期 + String lastDate = format.format(classDate); + return lastDate; + } + + public String getUniqueFieldId() { + return uniqueFieldId; + } + + public void setUniqueFieldId(String uniqueFieldId) { + this.uniqueFieldId = uniqueFieldId; + } + + public String getUrl() { + return url; + } + + public void setUrl(String url) { + this.url = url; + } +} \ No newline at end of file diff --git a/src/main/java/weaver/chaoyang/he/hcy_yihong/sendinvoicevaluestoaccounttable/action/InvoiceValuesToAccountTableAction01.java b/src/main/java/weaver/chaoyang/he/hcy_yihong/sendinvoicevaluestoaccounttable/action/InvoiceValuesToAccountTableAction01.java new file mode 100644 index 0000000..2f2f210 --- /dev/null +++ b/src/main/java/weaver/chaoyang/he/hcy_yihong/sendinvoicevaluestoaccounttable/action/InvoiceValuesToAccountTableAction01.java @@ -0,0 +1,246 @@ +package weaver.chaoyang.he.hcy_yihong.sendinvoicevaluestoaccounttable.action; + +import aiyh.utils.Util; +import aiyh.utils.httpUtil.ResponeVo; +import aiyh.utils.httpUtil.util.HttpUtils; +import lombok.SneakyThrows; +import org.apache.log4j.Logger; +import weaver.conn.RecordSet; +import weaver.interfaces.schedule.BaseCronJob; + +import java.io.IOException; +import java.text.SimpleDateFormat; +import java.util.*; + +public class InvoiceValuesToAccountTableAction01 extends BaseCronJob { + + + private Logger logger = Util.getLogger(); + + private String uniqueFieldId; + + private String url;//请求的接口的url + + + @SneakyThrows + @Override + public void execute() { + try { + String sql1 = "select taxNo,belongTo from uf_TaxNo_Config"; + RecordSet rs1 = new RecordSet(); + rs1.executeQuery(sql1); + + //获取上一次操作的日期 + String startDay = Util.getCusConfigValue("getDataTime"); + + //获取当前的日期 + Date date = new Date(); + SimpleDateFormat dateFormat = new SimpleDateFormat("yyyy-MM-dd"); + String endDay = dateFormat.format(date); + + while(rs1.next()){ + + String taxNo = rs1.getString("taxNo"); + String belongTo = rs1.getString("belongTo"); + + //请求头 + HashMap headers = new HashMap<>(); + headers.put("User-Agent", "Apifox/1.0.0 (https://www.apifox.cn)"); + headers.put("Content-Type", "application/json"); + + + //设置请求体 + Map body = new HashMap<>(); + body.put("identity",taxNo); + body.put("startDay",startDay); + body.put("endDay",endDay); + HttpUtils httpUtils = new HttpUtils(); + + ResponeVo responeVo = httpUtils.apiPost(url, body, headers); + int code = responeVo.getCode(); + if (code != 200){ + logger.info("对方接口状态码为:"+code+" 程序执行错误"); + continue; + } + Map entityMap = responeVo.getEntityMap(); + List datas = (List)entityMap.get("data"); + if (datas==null ||datas.isEmpty()){ + logger.info("接口返回主表参数为空,请查询税号是否准确"); + continue; + } + Map totalDataMap = new HashMap(); + String invoice_detail_Mainid = "";//用来判断台账表中是否含有相同记录 + for (Object data : datas){ + totalDataMap = (Map)data;//主表数据 + logger.info("主表数据==="+totalDataMap); + //第五步:查询每一个参数在台账主表中是否包含记录,如果包含执行update操作,如果不包含,执行insert操作。 + Object invoiceCode = totalDataMap.get("invoiceCode");//发票代码 + Object invoiceNum = totalDataMap.get("invoiceNum");//发票号码 + + //查询发票类型对应配置表:将想要转换的发票类型提前转换 + String queryInvoiceType = "select oaTypeValue from uf_InvoiceType_Mapping where interfaceTypeValue = ?";//改一下 + RecordSet rs2 = new RecordSet(); + rs2.executeQuery(queryInvoiceType,totalDataMap.get("invoiceType")); + if (rs2.next()){ + String oaTypeValue = rs2.getString("oaTypeValue"); + totalDataMap.put("invoiceType",oaTypeValue);//转换发票类型 + logger.info("转换发票类型==="+oaTypeValue); + }else { + totalDataMap.put("invoiceType","-1");//如果接口中的发票类型 + } + + //将时间戳转换成yyyy-MM-dd + String invoiceDate = (String)totalDataMap.get("invoiceDate"); + String new_invoiceDate = this.stampToDate(invoiceDate); + totalDataMap.put("invoiceDate",new_invoiceDate); + logger.info("转换后的时间戳====="+new_invoiceDate); + + //查询台账表中是否包含这个数据 + String sql2 = "select id from fnaInvoiceLedger where invoicecode = ? and invoicenumber = ?"; + + rs2.executeQuery(sql2,invoiceCode,invoiceNum); + if (rs2.next()) { + invoice_detail_Mainid = rs2.getString("id"); + } + + String mainId = ""; + String detailID = ""; + String updateSetkey = "";//当台账表中存在一条一样的数据的时候,我们需要设置更新条件 + List updateSetVaule = new ArrayList<>();//用来处理update条件下,?的赋值 + String insertSetKey = "(";//向台账中插入的key + String insertSetValue = "(";//向台账中插入的value + //第四步:通过配置的配置表获得到客户传的参数和台账字段的对应关系 + String sql3 = "select * from uf_fptzdypzbd where wybs = ?";//查询台账配置表 + if (rs2.executeQuery(sql3,uniqueFieldId)&&rs2.next()) { + mainId = rs2.getString("id");//查询发票台账对应配置表的id对应查询明细表的mainid + String sqlDetail1 = "select * from uf_fptzdypzbd_dt1 where mainid = ?"; + RecordSet rs3 = new RecordSet(); + rs3.executeQuery(sqlDetail1,mainId); + while(rs3.next()){ + String jkhqcs = rs3.getString("jkhqcs");//接口获取主表参数 + String jkhqzbcslx = rs3.getString("jkhqzbcslx");//接口获取主表参数类型 + String sjkzcs = rs3.getString("sjkzcs");//数据库中主表参数 + String sjkzzbcslx = rs3.getString("sjkzzbcslx");//数据库中主表参数类型 + updateSetkey += sjkzcs + "=" + "?,"; + insertSetKey += sjkzcs + ","; + insertSetValue += "?"+","; + updateSetVaule.add(totalDataMap.get(jkhqcs)); + } + //拼接 发票归属人 + updateSetkey = updateSetkey + "userid_new=?"; + updateSetVaule.add(Integer.parseInt(belongTo)); + insertSetKey = insertSetKey+"userid_new)"; + insertSetValue = insertSetValue+"?)"; + + logger.info("updateSetKey====="+updateSetkey); + logger.info("updateSetVaule====="+updateSetVaule); + logger.info("insertSetKey====="+insertSetKey); + logger.info("insertSetValue====="+insertSetValue); + } + //查询每一个参数在台账主表中是否包含记录,如果包含执行update操作,如果不包含,执行insert操作。 + if (!"".equals(invoice_detail_Mainid)){//执行更新语句 + updateSetVaule.add(invoiceCode); + updateSetVaule.add(invoiceNum); + String sqlUpdate = "update fnaInvoiceLedger set "+updateSetkey +" where invoicecode = ? and invoicenumber = ? "; + Object[] objects = updateSetVaule.toArray(); + logger.info("sqlUpdate更新的update语句====="+sqlUpdate); + boolean b = rs2.executeUpdate(sqlUpdate, objects); + logger.info("主表的更新语句是否更新=="+b); + }else{ + Object[] objects = updateSetVaule.toArray(); + String sqlInsert = "insert into fnaInvoiceLedger "+insertSetKey+" values "+insertSetValue; + logger.info("sqlInsert插入的insert语句======"+sqlInsert); + boolean b = rs2.executeUpdate(sqlInsert, objects); + logger.info("主表的插入语句是否插入=="+b); + } + //查询到刚插入的数据的id作为明细表的mainid + String sqlSelectId = "select id from fnaInvoiceLedger where invoicecode=? and invoicenumber=?"; + RecordSet rs3 = new RecordSet(); + rs3.executeQuery(sqlSelectId,invoiceCode,invoiceNum); + if (rs3.next()){ + detailID= rs3.getString("id"); + logger.info("detailID==="+detailID); + } + //向台账明细表中插入数据操作 + List details = (List)totalDataMap.get("detail");//明细表数据 + logger.info("明细表数据"+details); + String invoiceDetailSql = "delete from fnainvoiceledgerdetail where mainid = ?";//不管明细表中有没有内容一律删掉 + logger.info("不管明细表中有没有内容一律删掉sql语句==="+invoiceDetailSql); + boolean b1 = rs3.executeUpdate(invoiceDetailSql, detailID); + logger.info("删除操作是否成功b1===="+b1); + Map detailsMap = new HashMap<>(); + if (details ==null || details.isEmpty()){ + logger.info("明细表内容为空!跳出明细表出入循环"); + continue; + } + //开始查询配置表获得到客户传的明细表中参数和台账明细表中字段的对应关系 + for (Object detail : details) { + detailsMap = (Map)detail; + String sqlDetail2 = "select * from uf_fptzdypzbd_dt2 where mainid = ?"; + rs3.executeQuery(sqlDetail2,mainId); + String insertDetailSetKey = "(";//insert条件的拼接字符串1 + String insertDetailSetValue = "(";//insert条件的拼接字符串2 + List listDetail = new ArrayList<>();//用来将?赋值 + while (rs3.next()){ + String jkhqmxbzcs = rs3.getString("jkhqmxbzcs");//接口获取明细表中参数 + String jkhqmxbzcslx = rs3.getString("jkhqmxbzcslx");//接口获取明细表中参数类型 + String sjkzmxbcs = rs3.getString("sjkzmxbcs");//数据库中明细表参数 + String sjkzmxbcslx = rs3.getString("sjkzmxbcslx");//数据库中明细表参数类型 + insertDetailSetKey += sjkzmxbcs + ","; + insertDetailSetValue += "?,"; + listDetail.add(detailsMap.get(jkhqmxbzcs)); + + } + insertDetailSetKey = insertDetailSetKey + "mainid)"; + insertDetailSetValue = insertDetailSetValue+"?)"; + listDetail.add(detailID); + logger.info("明细表中用来插入的setkey---insertDetailSetKey==="+insertDetailSetKey); + logger.info("明细表中用来插入的setvalue---insertDetailSetValue==="+insertDetailSetValue); + logger.info("用来拼接?的listDetail"+listDetail); + + String insertIntoDetailSql = "insert into fnainvoiceledgerdetail "+insertDetailSetKey+ "values "+insertDetailSetValue ; + logger.info("insertIntoDetailSql明细表的插入语句==="+insertIntoDetailSql); + boolean b = rs3.executeUpdate(insertIntoDetailSql, listDetail); + logger.info("明细表数据插入是否成功===="+b); + } + } + } + //将当前时间设置到配置表中,作为下一次的开始时间 + logger.info("最后更新到配置表中的时间endDay==="+endDay); + Util.insertOrUpdateConfigValue("getDataTime",endDay,"更新同步时间"); + } catch (IOException e) { + e.printStackTrace(); + } catch (NumberFormatException e) { + e.printStackTrace(); + } + } + + /* + * 将时间戳转换为时间 + */ + public static String stampToDate(String s){ + String res; + SimpleDateFormat simpleDateFormat = new SimpleDateFormat("yyyy-MM-dd"); + long lt = new Long(s); + Date date = new Date(lt); + res = simpleDateFormat.format(date); + return res; + } + + + public String getUniqueFieldId() { + return uniqueFieldId; + } + + public void setUniqueFieldId(String uniqueFieldId) { + this.uniqueFieldId = uniqueFieldId; + } + + public String getUrl() { + return url; + } + + public void setUrl(String url) { + this.url = url; + } +} \ No newline at end of file diff --git a/src/main/java/weaver/chaoyang/he/hcy_yihong/sendinvoicevaluestoaccounttable/action/InvoiceValuesToAccountTableAction02.java b/src/main/java/weaver/chaoyang/he/hcy_yihong/sendinvoicevaluestoaccounttable/action/InvoiceValuesToAccountTableAction02.java new file mode 100644 index 0000000..317432b --- /dev/null +++ b/src/main/java/weaver/chaoyang/he/hcy_yihong/sendinvoicevaluestoaccounttable/action/InvoiceValuesToAccountTableAction02.java @@ -0,0 +1,301 @@ +package weaver.chaoyang.he.hcy_yihong.sendinvoicevaluestoaccounttable.action; + +import aiyh.utils.Util; +import aiyh.utils.httpUtil.ResponeVo; +import aiyh.utils.httpUtil.util.HttpUtils; +import lombok.SneakyThrows; +import org.apache.log4j.Logger; +import weaver.conn.RecordSet; +import weaver.interfaces.schedule.BaseCronJob; + +import java.io.IOException; +import java.text.SimpleDateFormat; +import java.util.*; + +public class InvoiceValuesToAccountTableAction02 extends BaseCronJob { + + + private Logger logger = Util.getLogger(); + + private String uniqueFieldId; + + private String url;//请求的接口的url + + + @SneakyThrows + @Override + public void execute() { + + //第一步首先获取税号 + //第二步获取开票开始时间 格式:yyyy-MM-dd 开票结束时间 格式:yyyy-MM-dd + + try { + String sql1 = "select taxNo,belongTo from uf_TaxNo_Config"; + RecordSet rs1 = new RecordSet(); + rs1.executeQuery(sql1); + while (rs1.next()){ + //第三步:new一个okhttp这个对象然后获取到客户给我们传的参数 + String taxNo = rs1.getString("taxNo"); + String belongTo = rs1.getString("belongTo"); + + //请求头 + HashMap headers = new HashMap<>(); + headers.put("User-Agent", "Apifox/1.0.0 (https://www.apifox.cn)"); + headers.put("Content-Type", "application/json"); + + + //获取上一次操作的日期 + String startDay = Util.getCusConfigValue("getDataTime"); + + //获取当前的日期 + Date date = new Date(); + SimpleDateFormat dateFormat = new SimpleDateFormat("yyyy-MM-dd"); + String endDay = dateFormat.format(date); + + //设置请求体 + Map body = new HashMap<>(); + body.put("identity",taxNo); + // body.put("startDay",startDay); + body.put("startDay",startDay); + // body.put("endDay",endDay); + body.put("endDay",endDay); + HttpUtils httpUtils = new HttpUtils(); + ResponeVo responeVo = httpUtils.apiPost(url, body, headers); + int code = responeVo.getCode(); + if (code != 200){ + logger.info("对方接口状态码为:"+code+" 程序执行错误"); + continue; + } + Map entityMap = responeVo.getEntityMap(); + logger.info(entityMap); + List datas = (List)entityMap.get("data"); + Map totalDataMap = new HashMap(); + if (datas == null || datas.isEmpty()){ + continue; + } + String invoice_detail_Mainid = "";//用来判断台账表中是否含有相同记录 + for (Object data : datas) { //主循环,数据都在里面 + totalDataMap = (Map)data;//主表数据 + //第五步:查询每一个参数在台账主表中是否包含记录,如果包含执行update操作,如果不包含,执行insert操作。 + Object invoiceCode = totalDataMap.get("invoiceCode");//发票代码 + Object invoiceNum = totalDataMap.get("invoiceNum");//发票号码 + + //查询发票类型对应配置表:将想要转换的发票类型提前转换 + String queryInvoiceType = "select oaTypeValue from uf_InvoiceType_Mapping where interfaceTypeValue = ?";//改一下 + RecordSet rs9 = new RecordSet(); + rs9.executeQuery(queryInvoiceType,totalDataMap.get("invoiceType")); + if (rs9.next()){ + String oaTypeValue = rs9.getString("oaTypeValue"); + totalDataMap.put("invoiceType",oaTypeValue);//转换发票类型 + } + + //将时间戳转换成yyyy-hh-dd + String invoiceDate = (String)totalDataMap.get("invoiceDate"); + String new_invoiceDate = this.stampToDate(invoiceDate); + totalDataMap.put("invoiceDate",new_invoiceDate); + + + RecordSet rs2 = new RecordSet(); + String sql2 = "select id from fnaInvoiceLedger where invoicecode = ? and invoicenumber = ?";//查询台账表中是否包含这个数据 + + rs2.executeQuery(sql2,invoiceCode,invoiceNum); + if (rs2.next()) { + invoice_detail_Mainid = rs2.getString("id"); + } + + String mainId = ""; + String detailID = ""; + //第四步:通过配置的配置表获得到客户传的参数和台账字段的对应关系 + String sql3 = "select * from uf_fptzdypzbd where wybs = ?";//查询台账配置表 + String insertSetKey1 = "(";//insert条件的拼接字符串1 + String insertSetKey2 = "(";//insert条件的拼接字符串2 + String updateSetkey = "";//update条件的拼接字符串 + Map updateMap = new HashMap<>();//update条件的拼接的map + Map updateIntMap = new HashMap<>();//update条件并且字段类型为int的拼接的map + Map updataDoubleMap = new HashMap<>();//update条件并且字段类型为double的拼接的map + RecordSet rs3 = new RecordSet(); + RecordSet rs4 = new RecordSet(); + if (rs3.executeQuery(sql3,uniqueFieldId)&&rs3.next()){ + mainId = rs3.getString("id"); + String sqlDetail1 = "select * from uf_fptzdypzbd_dt1 where mainid = ?"; + rs4.executeQuery(sqlDetail1,mainId); + while (rs4.next()){ + String jkhqcs = rs4.getString("jkhqcs");//接口获取主表参数 + String jkhqzbcslx = rs4.getString("jkhqzbcslx");//接口获取主表参数类型 + String sjkzcs = rs4.getString("sjkzcs");//数据库中主表参数 + String sjkzzbcslx = rs4.getString("sjkzzbcslx");//数据库中主表参数类型 + totalDataMap.put(jkhqcs,String.valueOf(totalDataMap.get(jkhqcs))); + + + if (Integer.valueOf(sjkzzbcslx)==0){ + updateMap.put(sjkzcs,String.valueOf(totalDataMap.get(jkhqcs))); + } else if (Integer.valueOf(sjkzzbcslx)==1){ + if (Integer.valueOf(jkhqzbcslx)==2){ + updateIntMap.put(sjkzcs,Double.valueOf(String.valueOf(totalDataMap.get(jkhqcs))).intValue()); + }else if (Integer.valueOf(jkhqzbcslx)==0){ + updateIntMap.put(sjkzcs, Integer.parseInt(String.valueOf(totalDataMap.get(jkhqcs)))); + } + } else if (Integer.valueOf(sjkzzbcslx)==2){ + updataDoubleMap.put(sjkzcs, Double.valueOf(String.valueOf(totalDataMap.get(jkhqcs)))); + }else if (Integer.valueOf(sjkzzbcslx)==3){ + updateMap.put(sjkzcs,String.valueOf(totalDataMap.get(jkhqcs))); + } + } + + } + updateIntMap.put("userid_new",Integer.parseInt(belongTo)); + //拼接update的set语句 + Set splicingUpdate = updateMap.keySet(); + for (String s : splicingUpdate) { + updateSetkey += s + "= " + "'" + updateMap.get(s) + "'" +" ,"; + insertSetKey1 += s+","; + insertSetKey2 += "'"+updateMap.get(s)+"',"; + } + Set splicingIntUpdate = updateIntMap.keySet(); + for (String s : splicingIntUpdate) { + updateSetkey += s + "= " + updateIntMap.get(s) +" ,"; + insertSetKey1 += s+","; + insertSetKey2 += updateIntMap.get(s)+","; + } + Set splicingDoubleUpdate = updataDoubleMap.keySet(); + for (String s : splicingDoubleUpdate) { + updateSetkey += s + "= " + updataDoubleMap.get(s) +" ,"; + insertSetKey1 += s+","; + insertSetKey2 += updataDoubleMap.get(s)+","; + } + updateSetkey = updateSetkey.substring(0, updateSetkey.length()-1); + insertSetKey1 = insertSetKey1.substring(0,insertSetKey1.length()-1)+")"; + insertSetKey2 = insertSetKey2.substring(0,insertSetKey2.length()-1)+")"; + logger.info("updateSetkey条件的查询结果:"+updateSetkey); + logger.info("insertSetKey1条件的查询结果:"+insertSetKey1); + logger.info("insertSetKey2条件的查询结果:"+insertSetKey2); + //查询每一个参数在台账主表中是否包含记录,如果包含执行update操作,如果不包含,执行insert操作。 + if (!"".equals(invoice_detail_Mainid)){//执行更新语句 + String sqlUpdate = "update fnaInvoiceLedger set "+updateSetkey +" where invoicecode = ? and invoicenumber = ? "; + RecordSet rs5 = new RecordSet(); + rs5.executeUpdate(sqlUpdate,invoiceCode,invoiceNum); + }else{ + String sqlInsert = "insert into fnaInvoiceLedger "+insertSetKey1+" values "+insertSetKey2; + logger.info("主表的查询语句sql====="+sqlInsert); + RecordSet rs6 = new RecordSet(); + rs6.executeUpdate(sqlInsert); + } + + //查询到刚插入的数据的id作为明细表的mainid + String sqlSelectId = "select id from fnaInvoiceLedger where invoicecode=? and invoicenumber=?"; + RecordSet rs10 = new RecordSet(); + rs10.executeQuery(sqlSelectId,invoiceCode,invoiceNum); + if (rs10.next()){ + detailID= rs10.getString("id"); + logger.info("查询到刚插入的数据的id作为明细表的detailID====="+detailID); + } + + //向台账明细表中插入数据操作 + List details = (List)totalDataMap.get("detail");//明细表数据 + String invoiceDetailSql = "delete from fnainvoiceledgerdetail where mainid = ?";//不管明细表中有没有内容一律删掉 + RecordSet rs6 = new RecordSet(); + rs6.executeUpdate(invoiceDetailSql,detailID); + Map detailsMap = new HashMap<>(); + if (details == null || details.isEmpty()){ + continue; + } + for (Object detail : details) { + detailsMap = (Map)detail; + logger.info("查询到的明细表的数据detailsMap"+detailsMap); + String sqlDetail2 = "select * from uf_fptzdypzbd_dt2 where mainid = ?"; + RecordSet rs7 = new RecordSet(); + rs7.executeQuery(sqlDetail2,mainId); + Map updateDetailMap = new HashMap<>();//update条件的拼接的明细表中的map + Map updateDetailIntMap = new HashMap<>();//update条件并且字段类型为int的明细表中拼接的map + Map updateDetailDoubleMap = new HashMap<>();//update条件并且字段类型为double的明细表中拼接的map + String insertDetailSetKey1 = "(";//insert条件的拼接字符串1 + String insertDetailSetKey2 = "(";//insert条件的拼接字符串2 + while(rs7.next()){ + String jkhqmxbzcs = rs7.getString("jkhqmxbzcs");//接口获取明细表中参数 + String jkhqmxbzcslx = rs7.getString("jkhqmxbzcslx");//接口获取明细表中参数类型 + String sjkzmxbcs = rs7.getString("sjkzmxbcs");//数据库中明细表参数 + String sjkzmxbcslx = rs7.getString("sjkzmxbcslx");//数据库中明细表参数类型 + detailsMap.put(jkhqmxbzcs,String.valueOf(detailsMap.get(jkhqmxbzcs))); + + if (Integer.valueOf(sjkzmxbcslx)==0){ + updateDetailMap.put(sjkzmxbcs,detailsMap.get(jkhqmxbzcs)); + }else if (Integer.valueOf(sjkzmxbcslx)==1){ + if(Integer.valueOf(jkhqmxbzcslx)==2){ + updateDetailIntMap.put(sjkzmxbcs,Double.valueOf(detailsMap.get(jkhqmxbzcs)).intValue()); + }else if (Integer.valueOf(jkhqmxbzcslx)==1){ + updateDetailIntMap.put(sjkzmxbcs,Integer.parseInt(detailsMap.get(jkhqmxbzcs))); + } + }else if (Integer.valueOf(sjkzmxbcslx)==2){ + updateDetailDoubleMap.put(sjkzmxbcs,Double.valueOf(detailsMap.get(jkhqmxbzcs))); + } + } + updateDetailIntMap.put("mainid",Integer.parseInt(detailID));//将明细表需要的id给他 + for (Map.Entry entry : updateDetailMap.entrySet()) { + String k = entry.getKey(); + String v = entry.getValue(); + insertDetailSetKey1 += k + ","; + insertDetailSetKey2 += "'"+v+"'"+","; + } + for (Map.Entry entry : updateDetailIntMap.entrySet()) { + String k = entry.getKey(); + Integer v = entry.getValue(); + insertDetailSetKey1 += k + ","; + insertDetailSetKey2 += v + ","; + } + for (Map.Entry entry : updateDetailDoubleMap.entrySet()) { + String k = entry.getKey(); + Double v = entry.getValue(); + insertDetailSetKey1 += k + ","; + insertDetailSetKey2 += v + ","; + } + + insertDetailSetKey1 = insertDetailSetKey1.substring(0,insertDetailSetKey1.length()-1)+")"; + insertDetailSetKey2 = insertDetailSetKey2.substring(0,insertDetailSetKey2.length()-1)+")"; + String insertIntoDetailSql = "insert into fnainvoiceledgerdetail "+insertDetailSetKey1 + "values "+insertDetailSetKey2 ; + RecordSet rs8 = new RecordSet(); + rs8.executeUpdate(insertIntoDetailSql); + } + } + //将当前时间设置到配置表中,作为下一次的开始时间 + Util.insertOrUpdateConfigValue("getDataTime",endDay,"更新同步时间"); + + } + } catch (IOException e) { + e.printStackTrace(); + logger.info("异常类型说明====="+e); + } catch (NumberFormatException e) { + e.printStackTrace(); + logger.info("异常类型说明====="+e); + } + + + } + + /* + * 将时间戳转换为时间 + */ + public static String stampToDate(String s){ + String res; + SimpleDateFormat simpleDateFormat = new SimpleDateFormat("yyyy-MM-dd"); + long lt = new Long(s); + Date date = new Date(lt); + res = simpleDateFormat.format(date); + return res; + } + + public String getUniqueFieldId() { + return uniqueFieldId; + } + + public void setUniqueFieldId(String uniqueFieldId) { + this.uniqueFieldId = uniqueFieldId; + } + + public String getUrl() { + return url; + } + + public void setUrl(String url) { + this.url = url; + } +} diff --git a/src/main/java/weaver/chaoyang/he/hcy_yihong/sendinvoicevaluestoaccounttable/action/InvoiceValuesToAccountTableAction03.java b/src/main/java/weaver/chaoyang/he/hcy_yihong/sendinvoicevaluestoaccounttable/action/InvoiceValuesToAccountTableAction03.java new file mode 100644 index 0000000..7c6e925 --- /dev/null +++ b/src/main/java/weaver/chaoyang/he/hcy_yihong/sendinvoicevaluestoaccounttable/action/InvoiceValuesToAccountTableAction03.java @@ -0,0 +1,247 @@ +package weaver.chaoyang.he.hcy_yihong.sendinvoicevaluestoaccounttable.action; + +import aiyh.utils.Util; +import aiyh.utils.httpUtil.ResponeVo; +import aiyh.utils.httpUtil.util.HttpUtils; +import lombok.SneakyThrows; +import org.apache.log4j.Logger; +import weaver.conn.RecordSet; +import weaver.interfaces.schedule.BaseCronJob; + +import java.io.IOException; +import java.text.SimpleDateFormat; +import java.util.*; + +public class InvoiceValuesToAccountTableAction03 extends BaseCronJob { + + + private Logger logger = Util.getLogger(); + + private String uniqueFieldId; + + private String url;//请求的接口的url + + + @SneakyThrows + @Override + public void execute() { + try { + String sql1 = "select taxNo,belongTo from uf_TaxNo_Config"; + RecordSet rs1 = new RecordSet(); + rs1.executeQuery(sql1); + + //获取上一次操作的日期 + String startDay = Util.getCusConfigValue("getDataTime"); + + //获取当前的日期 + Date date = new Date(); + SimpleDateFormat dateFormat = new SimpleDateFormat("yyyy-MM-dd"); + String endDay = dateFormat.format(date); + + while(rs1.next()){ + + String taxNo = rs1.getString("taxNo"); + String belongTo = rs1.getString("belongTo"); + + //请求头 + HashMap headers = new HashMap<>(); + headers.put("User-Agent", "Apifox/1.0.0 (https://www.apifox.cn)"); + headers.put("Content-Type", "application/json"); + + + //设置请求体 + Map body = new HashMap<>(); + body.put("identity",taxNo); + body.put("startDay",startDay); + body.put("endDay",endDay); + HttpUtils httpUtils = new HttpUtils(); + + ResponeVo responeVo = httpUtils.apiPost(url, body, headers); + int code = responeVo.getCode(); + if (code != 200){ + logger.info("对方接口状态码为:"+code+" 程序执行错误"); + continue; + } + Map entityMap = responeVo.getEntityMap(); + List datas = (List)entityMap.get("data"); + if (datas==null ||datas.isEmpty()){ + logger.info("接口返回主表参数为空,请查询税号是否准确"); + continue; + } + Map totalDataMap = new HashMap(); + String invoice_detail_Mainid = "";//用来判断台账表中是否含有相同记录 + for (Object data : datas){ + totalDataMap = (Map)data;//主表数据 + logger.info("主表数据==="+totalDataMap); + //第五步:查询每一个参数在台账主表中是否包含记录,如果包含执行update操作,如果不包含,执行insert操作。 + Object invoiceCode = totalDataMap.get("invoiceCode");//发票代码 + Object invoiceNum = totalDataMap.get("invoiceNum");//发票号码 + + //查询发票类型对应配置表:将想要转换的发票类型提前转换 + String queryInvoiceType = "select oaTypeValue from uf_InvoiceType_Mapping where interfaceTypeValue = ?";//改一下 + RecordSet rs2 = new RecordSet(); + rs2.executeQuery(queryInvoiceType,totalDataMap.get("invoiceType")); + if (rs2.next()){ + String oaTypeValue = rs2.getString("oaTypeValue"); + totalDataMap.put("invoiceType",oaTypeValue);//转换发票类型 + logger.info("转换发票类型==="+oaTypeValue); + }else { + break; +// totalDataMap.put("invoiceType","-1");//如果接口中的发票类型 + } + + //将时间戳转换成yyyy-MM-dd + String invoiceDate = (String)totalDataMap.get("invoiceDate"); + String new_invoiceDate = this.stampToDate(invoiceDate); + totalDataMap.put("invoiceDate",new_invoiceDate); + logger.info("转换后的时间戳====="+new_invoiceDate); + + //查询台账表中是否包含这个数据 + String sql2 = "select id from fnaInvoiceLedger where invoicecode = ? and invoicenumber = ?"; + + rs2.executeQuery(sql2,invoiceCode,invoiceNum); + if (rs2.next()) { + invoice_detail_Mainid = rs2.getString("id"); + } + + String mainId = ""; + String detailID = ""; + String updateSetkey = "";//当台账表中存在一条一样的数据的时候,我们需要设置更新条件 + List updateSetVaule = new ArrayList<>();//用来处理update条件下,?的赋值 + String insertSetKey = "(";//向台账中插入的key + String insertSetValue = "(";//向台账中插入的value + //第四步:通过配置的配置表获得到客户传的参数和台账字段的对应关系 + String sql3 = "select * from uf_fptzdypzbd where wybs = ?";//查询台账配置表 + if (rs2.executeQuery(sql3,uniqueFieldId)&&rs2.next()) { + mainId = rs2.getString("id");//查询发票台账对应配置表的id对应查询明细表的mainid + String sqlDetail1 = "select * from uf_fptzdypzbd_dt1 where mainid = ?"; + RecordSet rs3 = new RecordSet(); + rs3.executeQuery(sqlDetail1,mainId); + while(rs3.next()){ + String jkhqcs = rs3.getString("jkhqcs");//接口获取主表参数 + String jkhqzbcslx = rs3.getString("jkhqzbcslx");//接口获取主表参数类型 + String sjkzcs = rs3.getString("sjkzcs");//数据库中主表参数 + String sjkzzbcslx = rs3.getString("sjkzzbcslx");//数据库中主表参数类型 + updateSetkey += sjkzcs + "=" + "?,"; + insertSetKey += sjkzcs + ","; + insertSetValue += "?"+","; + updateSetVaule.add(totalDataMap.get(jkhqcs)); + } + //拼接 发票归属人 + updateSetkey = updateSetkey + "userid_new=?"; + updateSetVaule.add(Integer.parseInt(belongTo)); + insertSetKey = insertSetKey+"userid_new)"; + insertSetValue = insertSetValue+"?)"; + + logger.info("updateSetKey====="+updateSetkey); + logger.info("updateSetVaule====="+updateSetVaule); + logger.info("insertSetKey====="+insertSetKey); + logger.info("insertSetValue====="+insertSetValue); + } + //查询每一个参数在台账主表中是否包含记录,如果包含执行update操作,如果不包含,执行insert操作。 + if (!"".equals(invoice_detail_Mainid)){//执行更新语句 + updateSetVaule.add(invoiceCode); + updateSetVaule.add(invoiceNum); + String sqlUpdate = "update fnaInvoiceLedger set "+updateSetkey +" where invoicecode = ? and invoicenumber = ? "; + Object[] objects = updateSetVaule.toArray(); + logger.info("sqlUpdate更新的update语句====="+sqlUpdate); + boolean b = rs2.executeUpdate(sqlUpdate, objects); + logger.info("主表的更新语句是否更新=="+b); + }else{ + Object[] objects = updateSetVaule.toArray(); + String sqlInsert = "insert into fnaInvoiceLedger "+insertSetKey+" values "+insertSetValue; + logger.info("sqlInsert插入的insert语句======"+sqlInsert); + boolean b = rs2.executeUpdate(sqlInsert, objects); + logger.info("主表的插入语句是否插入=="+b); + } + //查询到刚插入的数据的id作为明细表的mainid + String sqlSelectId = "select id from fnaInvoiceLedger where invoicecode=? and invoicenumber=?"; + RecordSet rs3 = new RecordSet(); + rs3.executeQuery(sqlSelectId,invoiceCode,invoiceNum); + if (rs3.next()){ + detailID= rs3.getString("id"); + logger.info("detailID==="+detailID); + } + //向台账明细表中插入数据操作 + List details = (List)totalDataMap.get("detail");//明细表数据 + logger.info("明细表数据"+details); + String invoiceDetailSql = "delete from fnainvoiceledgerdetail where mainid = ?";//不管明细表中有没有内容一律删掉 + logger.info("不管明细表中有没有内容一律删掉sql语句==="+invoiceDetailSql); + boolean b1 = rs3.executeUpdate(invoiceDetailSql, detailID); + logger.info("删除操作是否成功b1===="+b1); + Map detailsMap = new HashMap<>(); + if (details ==null || details.isEmpty()){ + logger.info("明细表内容为空!跳出明细表出入循环"); + continue; + } + //开始查询配置表获得到客户传的明细表中参数和台账明细表中字段的对应关系 + for (Object detail : details) { + detailsMap = (Map)detail; + String sqlDetail2 = "select * from uf_fptzdypzbd_dt2 where mainid = ?"; + rs3.executeQuery(sqlDetail2,mainId); + String insertDetailSetKey = "(";//insert条件的拼接字符串1 + String insertDetailSetValue = "(";//insert条件的拼接字符串2 + List listDetail = new ArrayList<>();//用来将?赋值 + while (rs3.next()){ + String jkhqmxbzcs = rs3.getString("jkhqmxbzcs");//接口获取明细表中参数 + String jkhqmxbzcslx = rs3.getString("jkhqmxbzcslx");//接口获取明细表中参数类型 + String sjkzmxbcs = rs3.getString("sjkzmxbcs");//数据库中明细表参数 + String sjkzmxbcslx = rs3.getString("sjkzmxbcslx");//数据库中明细表参数类型 + insertDetailSetKey += sjkzmxbcs + ","; + insertDetailSetValue += "?,"; + listDetail.add(detailsMap.get(jkhqmxbzcs)); + + } + insertDetailSetKey = insertDetailSetKey + "mainid)"; + insertDetailSetValue = insertDetailSetValue+"?)"; + listDetail.add(detailID); + logger.info("明细表中用来插入的setkey---insertDetailSetKey==="+insertDetailSetKey); + logger.info("明细表中用来插入的setvalue---insertDetailSetValue==="+insertDetailSetValue); + logger.info("用来拼接?的listDetail"+listDetail); + + String insertIntoDetailSql = "insert into fnainvoiceledgerdetail "+insertDetailSetKey+ "values "+insertDetailSetValue ; + logger.info("insertIntoDetailSql明细表的插入语句==="+insertIntoDetailSql); + boolean b = rs3.executeUpdate(insertIntoDetailSql, listDetail); + logger.info("明细表数据插入是否成功===="+b); + } + } + } + //将当前时间设置到配置表中,作为下一次的开始时间 + logger.info("最后更新到配置表中的时间endDay==="+endDay); + Util.insertOrUpdateConfigValue("getDataTime",endDay,"更新同步时间"); + } catch (IOException e) { + e.printStackTrace(); + } catch (NumberFormatException e) { + e.printStackTrace(); + } + } + + /* + * 将时间戳转换为时间 + */ + public static String stampToDate(String s){ + String res; + SimpleDateFormat simpleDateFormat = new SimpleDateFormat("yyyy-MM-dd"); + long lt = new Long(s); + Date date = new Date(lt); + res = simpleDateFormat.format(date); + return res; + } + + + public String getUniqueFieldId() { + return uniqueFieldId; + } + + public void setUniqueFieldId(String uniqueFieldId) { + this.uniqueFieldId = uniqueFieldId; + } + + public String getUrl() { + return url; + } + + public void setUrl(String url) { + this.url = url; + } +} \ No newline at end of file diff --git a/src/main/java/weaver/chaoyang/he/hcy_yihong/sendinvoicevaluestoaccounttable/action/InvoiceValuesToAccountTableAction04.java b/src/main/java/weaver/chaoyang/he/hcy_yihong/sendinvoicevaluestoaccounttable/action/InvoiceValuesToAccountTableAction04.java new file mode 100644 index 0000000..7f202b9 --- /dev/null +++ b/src/main/java/weaver/chaoyang/he/hcy_yihong/sendinvoicevaluestoaccounttable/action/InvoiceValuesToAccountTableAction04.java @@ -0,0 +1,264 @@ +package weaver.chaoyang.he.hcy_yihong.sendinvoicevaluestoaccounttable.action; + +import aiyh.utils.Util; +import aiyh.utils.httpUtil.ResponeVo; +import aiyh.utils.httpUtil.util.HttpUtils; +import lombok.SneakyThrows; +import org.apache.log4j.Logger; +import weaver.conn.RecordSet; +import weaver.interfaces.schedule.BaseCronJob; + +import java.io.IOException; +import java.text.SimpleDateFormat; +import java.util.*; + +public class InvoiceValuesToAccountTableAction04 extends BaseCronJob { + + + private Logger logger = Util.getLogger(); + + private String uniqueFieldId; + + private String url;//请求的接口的url + + + @SneakyThrows + @Override + public void execute() { + try { + String sql1 = "select taxNo,belongTo from uf_TaxNo_Config"; + RecordSet rs1 = new RecordSet(); + rs1.executeQuery(sql1); + + //获取上一次操作的日期 + String startDay = Util.getCusConfigValue("getDataTime"); + + //获取当前的日期 + Date date = new Date(); + SimpleDateFormat dateFormat = new SimpleDateFormat("yyyy-MM-dd"); + String endDay = dateFormat.format(date); + + while(rs1.next()){ + + String taxNo = rs1.getString("taxNo"); + String belongTo = rs1.getString("belongTo"); + + //请求头 + HashMap headers = new HashMap<>(); + headers.put("User-Agent", "Apifox/1.0.0 (https://www.apifox.cn)"); + headers.put("Content-Type", "application/json"); + + + //设置请求体 + Map body = new HashMap<>(); + body.put("identity",taxNo); + body.put("startDay",startDay); + body.put("endDay",endDay); + HttpUtils httpUtils = new HttpUtils(); + + ResponeVo responeVo = httpUtils.apiPost(url, body, headers); + int code = responeVo.getCode(); + if (code != 200){ + logger.info("对方接口状态码为:"+code+" 程序执行错误"); + continue; + } + Map entityMap = responeVo.getEntityMap(); + List datas = (List)entityMap.get("data"); + if (datas==null ||datas.isEmpty()){ + logger.info("接口返回主表参数为空,请查询税号是否准确"); + continue; + } + Map totalDataMap = new HashMap(); + String invoice_detail_Mainid = "";//用来判断台账表中是否含有相同记录 + for (Object data : datas){ + totalDataMap = (Map)data;//主表数据 + logger.info("主表数据==="+totalDataMap); + //第五步:查询每一个参数在台账主表中是否包含记录,如果包含执行update操作,如果不包含,执行insert操作。 + Object invoiceCode = totalDataMap.get("invoiceCode");//发票代码 + Object invoiceNum = totalDataMap.get("invoiceNum");//发票号码 + + //查询发票类型对应配置表:将想要转换的发票类型提前转换 + String queryInvoiceType = "select oaTypeValue from uf_InvoiceType_Mapping where interfaceTypeValue = ?";//改一下 + RecordSet rs2 = new RecordSet(); + rs2.executeQuery(queryInvoiceType,totalDataMap.get("invoiceType")); + if (rs2.next()){ + String oaTypeValue = rs2.getString("oaTypeValue"); + totalDataMap.put("invoiceType",oaTypeValue);//转换发票类型 + logger.info("转换发票类型==="+oaTypeValue); + }else { + continue; +// totalDataMap.put("invoiceType","-1");//如果接口中的发票类型 + } + + //将时间戳转换成yyyy-MM-dd + String invoiceDate = (String)totalDataMap.get("invoiceDate"); + String new_invoiceDate = this.stampToDate(invoiceDate); + totalDataMap.put("invoiceDate",new_invoiceDate); + logger.info("转换后的时间戳====="+new_invoiceDate); + + //查询台账表中是否包含这个数据 + String sql2 = "select id from fnaInvoiceLedger where invoicecode = ? and invoicenumber = ?"; + + rs2.executeQuery(sql2,invoiceCode,invoiceNum); + if (rs2.next()) { + invoice_detail_Mainid = rs2.getString("id"); + } + + String mainId = ""; + String detailID = ""; + String updateSetkey = "";//当台账表中存在一条一样的数据的时候,我们需要设置更新条件 + List updateSetVaule = new ArrayList<>();//用来处理update条件下,?的赋值 + String insertSetKey = "(";//向台账中插入的key + String insertSetValue = "(";//向台账中插入的value + //第四步:通过配置的配置表获得到客户传的参数和台账字段的对应关系 + String sql3 = "select * from uf_fptzdypzbd where wybs = ?";//查询台账配置表 + if (rs2.executeQuery(sql3,uniqueFieldId)&&rs2.next()) { + mainId = rs2.getString("id");//查询发票台账对应配置表的id对应查询明细表的mainid + String sqlDetail1 = "select * from uf_fptzdypzbd_dt1 where mainid = ?"; + RecordSet rs3 = new RecordSet(); + rs3.executeQuery(sqlDetail1,mainId); + + + String defaultValue = ""; + while(rs3.next()){ + String jkhqcs = rs3.getString("jkhqcs");//接口获取主表参数 + String sjkzcs = rs3.getString("sjkzcs");//数据库中主表参数 + String zhlx = rs3.getString("zhlx");//转换类型 + String zdyz = rs3.getString("zdyz");//自定义值 + if (zhlx!=""&&zhlx.equals("0")){ + updateSetkey += sjkzcs + "=" + "?,"; + insertSetKey += sjkzcs + ","; + insertSetValue += "?"+","; + updateSetVaule.add(totalDataMap.get(jkhqcs)); + }else if (zhlx!=""&&zhlx.equals("1")){ + defaultValue = zdyz; + } + + } + //拼接 发票归属人 + updateSetkey = updateSetkey + "userid_new=?,"; + updateSetVaule.add(Integer.parseInt(belongTo)); + insertSetKey = insertSetKey+"userid_new,"; + insertSetValue = insertSetValue+"?,"; + + + //拼接固定值中的类型 + updateSetkey = updateSetkey + "hxjksflr=?"; + updateSetVaule.add(defaultValue); + insertSetKey = insertSetKey+"hxjksflr)"; + insertSetValue = insertSetValue+"?)"; + + + + logger.info("updateSetKey====="+updateSetkey); + logger.info("updateSetVaule====="+updateSetVaule); + logger.info("insertSetKey====="+insertSetKey); + logger.info("insertSetValue====="+insertSetValue); + } + //查询每一个参数在台账主表中是否包含记录,如果包含执行update操作,如果不包含,执行insert操作。 + if (!"".equals(invoice_detail_Mainid)){//执行更新语句 + updateSetVaule.add(invoiceCode); + updateSetVaule.add(invoiceNum); + String sqlUpdate = "update fnaInvoiceLedger set "+updateSetkey +" where invoicecode = ? and invoicenumber = ? "; + Object[] objects = updateSetVaule.toArray(); + logger.info("sqlUpdate更新的update语句====="+sqlUpdate); + boolean b = rs2.executeUpdate(sqlUpdate, objects); + logger.info("主表的更新语句是否更新=="+b); + }else{ + Object[] objects = updateSetVaule.toArray(); + String sqlInsert = "insert into fnaInvoiceLedger "+insertSetKey+" values "+insertSetValue; + logger.info("sqlInsert插入的insert语句======"+sqlInsert); + boolean b = rs2.executeUpdate(sqlInsert, objects); + logger.info("主表的插入语句是否插入=="+b); + } + //查询到刚插入的数据的id作为明细表的mainid + String sqlSelectId = "select id from fnaInvoiceLedger where invoicecode=? and invoicenumber=?"; + RecordSet rs3 = new RecordSet(); + rs3.executeQuery(sqlSelectId,invoiceCode,invoiceNum); + if (rs3.next()){ + detailID= rs3.getString("id"); + logger.info("detailID==="+detailID); + } + //向台账明细表中插入数据操作 + List details = (List)totalDataMap.get("detail");//明细表数据 + logger.info("明细表数据"+details); + String invoiceDetailSql = "delete from fnainvoiceledgerdetail where mainid = ?";//不管明细表中有没有内容一律删掉 + logger.info("不管明细表中有没有内容一律删掉sql语句==="+invoiceDetailSql); + boolean b1 = rs3.executeUpdate(invoiceDetailSql, detailID); + logger.info("删除操作是否成功b1===="+b1); + Map detailsMap = new HashMap<>(); + if (details ==null || details.isEmpty()){ + logger.info("明细表内容为空!跳出明细表出入循环"); + continue; + } + //开始查询配置表获得到客户传的明细表中参数和台账明细表中字段的对应关系 + for (Object detail : details) { + detailsMap = (Map)detail; + String sqlDetail2 = "select * from uf_fptzdypzbd_dt2 where mainid = ?"; + rs3.executeQuery(sqlDetail2,mainId); + String insertDetailSetKey = "(";//insert条件的拼接字符串1 + String insertDetailSetValue = "(";//insert条件的拼接字符串2 + List listDetail = new ArrayList<>();//用来将?赋值 + while (rs3.next()){ + String jkhqmxbzcs = rs3.getString("jkhqmxbzcs");//接口获取明细表中参数 + String jkhqmxbzcslx = rs3.getString("jkhqmxbzcslx");//接口获取明细表中参数类型 + String sjkzmxbcs = rs3.getString("sjkzmxbcs");//数据库中明细表参数 + String sjkzmxbcslx = rs3.getString("sjkzmxbcslx");//数据库中明细表参数类型 + insertDetailSetKey += sjkzmxbcs + ","; + insertDetailSetValue += "?,"; + listDetail.add(detailsMap.get(jkhqmxbzcs)); + + } + insertDetailSetKey = insertDetailSetKey + "mainid)"; + insertDetailSetValue = insertDetailSetValue+"?)"; + listDetail.add(detailID); + logger.info("明细表中用来插入的setkey---insertDetailSetKey==="+insertDetailSetKey); + logger.info("明细表中用来插入的setvalue---insertDetailSetValue==="+insertDetailSetValue); + logger.info("用来拼接?的listDetail"+listDetail); + + String insertIntoDetailSql = "insert into fnainvoiceledgerdetail "+insertDetailSetKey+ "values "+insertDetailSetValue ; + logger.info("insertIntoDetailSql明细表的插入语句==="+insertIntoDetailSql); + boolean b = rs3.executeUpdate(insertIntoDetailSql, listDetail); + logger.info("明细表数据插入是否成功===="+b); + } + } + } + //将当前时间设置到配置表中,作为下一次的开始时间 + logger.info("最后更新到配置表中的时间endDay==="+endDay); + Util.insertOrUpdateConfigValue("getDataTime",endDay,"更新同步时间"); + } catch (IOException e) { + e.printStackTrace(); + } catch (NumberFormatException e) { + e.printStackTrace(); + } + } + + /* + * 将时间戳转换为时间 + */ + public static String stampToDate(String s){ + String res; + SimpleDateFormat simpleDateFormat = new SimpleDateFormat("yyyy-MM-dd"); + long lt = new Long(s); + Date date = new Date(lt); + res = simpleDateFormat.format(date); + return res; + } + + + public String getUniqueFieldId() { + return uniqueFieldId; + } + + public void setUniqueFieldId(String uniqueFieldId) { + this.uniqueFieldId = uniqueFieldId; + } + + public String getUrl() { + return url; + } + + public void setUrl(String url) { + this.url = url; + } +} \ No newline at end of file diff --git a/src/main/java/weaver/chaoyang/he/jiacheng/deng/toyota/boshoku/action/TbChangeTextNameAction.java b/src/main/java/weaver/chaoyang/he/jiacheng/deng/toyota/boshoku/action/TbChangeTextNameAction.java new file mode 100644 index 0000000..09af6f9 --- /dev/null +++ b/src/main/java/weaver/chaoyang/he/jiacheng/deng/toyota/boshoku/action/TbChangeTextNameAction.java @@ -0,0 +1,234 @@ +package weaver.chaoyang.he.jiacheng.deng.toyota.boshoku.action; + +import aiyh.utils.Util; +import com.sun.istack.internal.NotNull; +import org.apache.log4j.Logger; +import weaver.conn.RecordSet; +import weaver.interfaces.workflow.action.Action; +import weaver.soa.workflow.request.*; + +import java.util.ArrayList; +import java.util.HashMap; +import java.util.List; +import java.util.Map; +import java.util.stream.Collectors; +/** + *

附件上传后修改名称保存到目录

+ * @Author jiacheng.deng + * @Date 2023/2/13 10:41 + */ +public class TbChangeTextNameAction implements Action { + + //日志打印 + private final Logger log = Util.getLogger(); + + /** + *

附件上传后修改名称

+ * @param requestInfo + * @return Action.SUCCESS + * @author jiacheng.deng + */ + @Override + public String execute(RequestInfo requestInfo) { + + Property[] property = requestInfo.getMainTableInfo().getProperty(); + + List> detailData = new ArrayList<>(); + + Map mainMap = new HashMap<>(); + for (Property property1 : property) { + String name = property1.getName(); + String value = property1.getValue(); + + mainMap.put(name,value); + } + + log.info("main table name and value is : " + mainMap); + + DetailTable detailTable = requestInfo.getDetailTableInfo().getDetailTable(0); + + Row[] row2 = detailTable.getRow(); + + for (Row row : row2) { + Cell[] cell = row.getCell(); + Map detailMap = new HashMap<>(); + for (Cell cell1 : cell) { + String name = cell1.getName(); + String value = cell1.getValue(); + detailMap.put(name,value); + } + detailData.add(detailMap); + } + + for (Map detailDatum : detailData) { + log.info("detail table name and value is : " + detailDatum ); + } + + String workflowid = requestInfo.getWorkflowid(); + RecordSet refindFieldType = new RecordSet(); + String findFieldhtmltypeSQL = "select w3.billid,w3.showtablename,w3.fieldhtmltype,w3.fieldname from workflow_base w1 join workflow_bill w2 on w1.formid = w2.id \n " + + " join workflow_field_table_view w3 on w3.billid = w2.id\n " + + " where w1.id = ? and w3.fieldhtmltype='附件上传'"; + boolean findFieldhtmltype = refindFieldType.executeQuery(findFieldhtmltypeSQL, workflowid); + log.info("查询表单字段类型sql是否执行:" + findFieldhtmltype); + + String findMainParamValueSQL = "select paramvalue from uf_systemconfig where uuid = 'main_upload'"; + String findDetailParamValueSQL = "select paramvalue from uf_systemconfig where uuid = 'detail_upload'"; + + RecordSet refindMainParam = new RecordSet(); + boolean findMainParamValue = refindMainParam.executeQuery(findMainParamValueSQL); + refindMainParam.next(); + String mainParamvalue = refindMainParam.getString("paramvalue"); + log.info("查询配置列表配置主表参数sql是否执行:" + findMainParamValue + "and 主表配置的附件参数为:" + mainParamvalue); + + RecordSet refindDetailParam = new RecordSet(); + boolean findDetailParamValue = refindDetailParam.executeQuery(findDetailParamValueSQL); + refindDetailParam.next(); + String detailParamvalue = refindDetailParam.getString("paramvalue"); + log.info("查询配置列表配置明细表参数sql是否执行:" + findDetailParamValue + "and 明细表配置的附件参数为:" + detailParamvalue); + + List showtablenameList = new ArrayList(); + List fieldnameList = new ArrayList(); + String fieldname ; + String showtablename; + + while (refindFieldType.next()){ + showtablename = refindFieldType.getString("showtablename"); + fieldname = refindFieldType.getString("fieldname"); + showtablenameList.add(showtablename); + fieldnameList.add(fieldname); + } + + List collect = showtablenameList.stream().distinct().collect(Collectors.toList()); + + if(collect.size() >= 2){ + log.info("明细表和主表都有附件上传框"); + + List list = new ArrayList<>(); + if (!mainMap.get(mainParamvalue).equals("")) { + String[] mainUploadSplitArr = mainMap.get(mainParamvalue).split(","); + for (String mainUploadSplitNum : mainUploadSplitArr) { + int i = Integer.parseInt(mainUploadSplitNum); + list.add(i); + } + + for ( Map detailDatum : detailData) { + if(! detailDatum.get(detailParamvalue).equals("")){ + String[] detailUploadSplitArr = detailDatum.get(detailParamvalue).split(","); + for (String detailUploadSplitNum : detailUploadSplitArr) { + int i = Integer.parseInt(detailUploadSplitNum); + list.add(i); + } + }else{ + continue; + } + } + for (Integer uploadNum : list) { + String findFjSQL = "select * from docdetail where id = ?"; + RecordSet recordSet = new RecordSet(); + boolean findFj= recordSet.executeQuery(findFjSQL, uploadNum); + log.info("b1是否执行:" + findFj); + while (recordSet.next()) { + String docsubject = recordSet.getString("docsubject"); + log.info("find docsubject is : " + docsubject); + if (!"".equals(docsubject)) { + String fjName = mainMap.get("sqdh") + " - " + docsubject; + log.info("附件修改后的名称:" + fjName); + String updateFjNameSQL = "update docdetail set docsubject = ? where id = " + uploadNum; + log.info("修改文件名称sql:" + updateFjNameSQL); + //recordset使用重复 + boolean updateFjName = recordSet.executeUpdate(updateFjNameSQL,fjName); + log.info("b2是否执行:" + updateFjName); +// todo:处理逻辑 + String selectImageFileNameSql = "select imagefilename from docimagefile where docid = ?"; + while (recordSet.executeQuery(selectImageFileNameSql,uploadNum)&&recordSet.next()){ + String imageFileName = recordSet.getString("imagefilename"); + log.info("find imagefilename is : "+imageFileName); + if (!"".equals(imageFileName)) { + String fjName1 = mainMap.get("sqdh") + " - "+imageFileName; + log.info("修改文件名称sql:"+fjName1); + String updateImageFileNameSql = "update docimagefile set imagefilename = ? where id = ?"; + } + } + + } + } + } + }else{ + for (Map detailDatum : detailData) { + if(! detailDatum.get(detailParamvalue).equals("")){ + String[] detailUploadSplitArr = detailDatum.get(detailParamvalue).split(","); + for (String detailUploadSplitNum : detailUploadSplitArr) { + int i = Integer.parseInt(detailUploadSplitNum); + list.add(i); + } + }else{ + continue; + } + } + for (Integer uploadNum : list) { + String findFjSQL = "select * from docdetail where id = ?"; + RecordSet recordSet = new RecordSet(); + boolean findFj= recordSet.executeQuery(findFjSQL, uploadNum); + log.info("b1是否执行:" + findFj); + while (recordSet.next()) { + String docsubject = recordSet.getString("docsubject"); + log.info("find docsubject is : " + docsubject); + if (!"".equals(docsubject)) { + String fjName = mainMap.get("sqdh") + " - " + docsubject; + log.info("附件修改后的名称:" + fjName); + String updateFjNameSQL = "update docdetail set docsubject = ? where id = " + uploadNum; + log.info("修改文件名称sql:" + updateFjNameSQL); + //recordset使用重复 + boolean updateFjName = recordSet.executeUpdate(updateFjNameSQL,fjName); + log.info("b2是否执行:" + updateFjName); + } + } + } + } + + }else{ + log.info("主表或者明细表只有一个有附件上传框,或者都没上传框"); + return Action.SUCCESS; + } + return Action.SUCCESS; + } + + /** + *

获取所有明细数据

+ * + * @return 以明细表需要为键,以明细表数据为值的键值对明细数据信息 + */ + protected Map>> getDetailTableValue(RequestInfo requestInfo) { + DetailTable[] detailTableArr = requestInfo.getDetailTableInfo().getDetailTable(); + Map>> detailDataList = new HashMap<>((int) Math.ceil(detailTableArr.length * 0.75)); + for (DetailTable detailTable : detailTableArr) { + List> detailData = getDetailValue(detailTable); + detailDataList.put(detailTable.getId(), detailData); + } + return detailDataList; + } + + /** + *

根据明细表信息获取明细表数据

+ * + * @param detailTable 明细表对象 + * @return 明细表数据 + */ + @NotNull + private List> getDetailValue(DetailTable detailTable) { + Row[] rowArr = detailTable.getRow(); + List> detailData = new ArrayList<>(rowArr.length); + for (Row row : rowArr) { + Cell[] cellArr = row.getCell(); + Map rowData = new HashMap<>((int) Math.ceil(cellArr.length * 0.75)); + for (Cell cell : cellArr) { + String fieldName = cell.getName(); + String value = cell.getValue(); + rowData.put(fieldName, value); + } + detailData.add(rowData); + } + return detailData; + } +} diff --git a/src/main/java/weaver/chaoyang/he/shangan/common/util/CommonWFUtil.java b/src/main/java/weaver/chaoyang/he/shangan/common/util/CommonWFUtil.java new file mode 100644 index 0000000..c06a66a --- /dev/null +++ b/src/main/java/weaver/chaoyang/he/shangan/common/util/CommonWFUtil.java @@ -0,0 +1,273 @@ +package weaver.chaoyang.he.shangan.common.util; + +import weaver.conn.RecordSet; +import weaver.general.TimeUtil; +import weaver.general.Util; +import weaver.hrm.User; +import weaver.workflow.webservices.*; +import weaver.workflow.workflow.WorkflowComInfo; +import weaver.zwl.common.ToolUtil; + +import java.text.SimpleDateFormat; +import java.util.*; + +/** + * 常用通用工具方法 + * EBU七部 + */ +public class CommonWFUtil { + + private static final ToolUtil tu = new ToolUtil(); + /** + * + * 发起流程 + * @param workflowId 流程id + * @param mainFormData 主表数据 key:数据库字段名称 value:值 + * @param dtlFormData 明细数据 key:明细表num value:每一行明细数据 + * @param defaultValue 是否需要默认值和节点前附加规则的设值,例如人力资源、日期等 + * @param user 当前用户信息 + */ + public static String startWorkflow(String workflowId, Map mainFormData, + Map>> dtlFormData, boolean defaultValue, User user) throws Exception{ + return startWorkflow(workflowId,mainFormData,dtlFormData,defaultValue,user,"0"); + } + + /** + * + * 发起流程 + * @param workflowId 流程id + * @param mainFormData 主表数据 key:数据库字段名称 value:值 + * @param dtlFormData 明细数据 key:明细表num value:每一行明细数据 + * @param defaultValue 是否需要默认值和节点前附加规则的设值,例如人力资源、日期等 + * @param user 当前用户信息 + * @param isNextFlow 是否自动提交至下一个节点 0:否 1:是 + */ + public static String startWorkflow(String workflowId, Map mainFormData, + Map>> dtlFormData, boolean defaultValue, User user,String isNextFlow) { + int formid = 0; + String defaultName = ""; + RecordSet rs = new RecordSet(); + String sql = " select a.formId ,a.isValId,a.defaultName,a.version,a.activeVersionID from workflow_base a where a.id=?"; + rs.executeQuery(sql, workflowId); + if (rs.next()) { + formid = Math.abs(rs.getInt("formId")); + defaultName = Util.null2String(rs.getString("defaultName")).trim(); + String activeVersionID = Util.null2String(rs.getString("activeVersionID")); + + if(!"".equals(activeVersionID)){ + workflowId = activeVersionID; + } + } + + //流程默认标题没有开启 + if("1".equals(defaultName) || "".equals(defaultName)){ + //生成默认标题 + WorkflowComInfo wc = new WorkflowComInfo(); + //流程标题 + defaultName = Util.formatMultiLang(wc.getWorkflowname(workflowId)) + "-" + user.getLastname() + "-" + TimeUtil.getCurrentDateString(); + } + + //设置流程信息 + WorkflowBaseInfo wbi = new WorkflowBaseInfo(); + wbi.setWorkflowId(workflowId); + WorkflowServiceImpl wsi = new WorkflowServiceImpl(); + WorkflowRequestInfo wri = new WorkflowRequestInfo();//流程基本信息 + wri.setCreatorId(user.getUID()+"");//创建人id + wri.setCreatorName(user.getLastname()); + wri.setRequestLevel("0");//0 正常,1重要,2紧急 + wri.setRequestName(defaultName);//流程标题 + wri.setWorkflowBaseInfo(wbi); //流程类型 + wri.setIsnextflow(isNextFlow); + + //主表 + WorkflowRequestTableRecord[] writ = new WorkflowRequestTableRecord[1]; + + if(mainFormData == null){ + mainFormData = new HashMap<>(); + } + + if(defaultValue){ + //查询主表的附加规则设置 + rs.executeQuery("select a.customervalue,b.fieldname from workflow_addinoperate a " + + " join workflow_billfield b on a.fieldid = b.id " + + " join workflow_flownode c on c.nodeid = a.objid " + + " where a.workflowid = ? and a.isnode = 1 and a.ispreadd = 1 and a.type = 0 and c.nodetype = 0 and b.viewtype = 0 ", workflowId); + while(rs.next()){ + String fieldname = Util.null2String(rs.getString("fieldname")); + String customervalue = Util.null2String(rs.getString("customervalue")); + if(!mainFormData.containsKey(fieldname)){ + mainFormData.put(fieldname, customervalue); + } + } + + defaultValueSet(mainFormData,user,workflowId,""); + } + if(mainFormData.size() > 0){ + int filedCount = mainFormData.size();//需要维护的字段数量 + WorkflowRequestTableField[] workflowRequestTableField = new WorkflowRequestTableField[filedCount]; //一行的字段数组 + int i = 0; + for(Map.Entry entry:mainFormData.entrySet()){ + String key = entry.getKey(); + String value = entry.getValue(); + workflowRequestTableField[i] = new WorkflowRequestTableField(); + workflowRequestTableField[i].setFieldName(key);//字段名称 + workflowRequestTableField[i].setFieldValue(value);//字段的值 + workflowRequestTableField[i].setView(true);//字段是否可见 + workflowRequestTableField[i].setEdit(true);//字段是否可编辑 + i++; + } + writ[0] = new WorkflowRequestTableRecord(); + writ[0].setWorkflowRequestTableFields(workflowRequestTableField); + }else{ + WorkflowRequestTableField[] workflowRequestTableField = new WorkflowRequestTableField[0]; //一行的字段数组 + writ[0] = new WorkflowRequestTableRecord(); + writ[0].setWorkflowRequestTableFields(workflowRequestTableField); + } + + WorkflowMainTableInfo wmi = new WorkflowMainTableInfo(); + wmi.setRequestRecords(writ); + wri.setWorkflowMainTableInfo(wmi);//添加主字段数据 + //主表end + + //明细表 + //查询流程共有几个明细表 + int maxDtl = 0; + List dtlTableList = new ArrayList<>(); + rs.executeQuery("select a.tableName,a.billId from workflow_billDetailTable a join workflow_base b on b.formId = a.billId where b.id = ? \n" + + "order by a.orderId asc", workflowId); + while(rs.next()){ + String tableName = Util.null2String(rs.getString("tableName")); + + int dtlId = Util.getIntValue(tableName.substring(tableName.indexOf("_dt") + 3),-1); + + if(dtlId>maxDtl){ + maxDtl = dtlId; + } + dtlTableList.add(""+dtlId); + } + if(dtlFormData != null && dtlFormData.size() > 0){ + WorkflowDetailTableInfo[] workflowDetailTableInfos = new WorkflowDetailTableInfo[maxDtl]; + for(int i = 0;i < dtlTableList.size();i++){ + List> dtlList = dtlFormData.get(dtlTableList.get(i)); //第i个明细表中的数据 + if(dtlList == null || dtlList.size() == 0){ + continue; + } + + WorkflowRequestTableRecord[] WorkflowRequestTableRecord = new WorkflowRequestTableRecord[dtlList.size()]; + Map defaultData = new HashMap<>(); + if(defaultValue){ + //明细默认信息 + rs.executeQuery("select a.customerValue,b.fieldName from workflow_addinoperate a " + + " join workflow_billfield b on a.fieldid = b.id " + + " join workflow_flownode c on c.nodeid = a.objid " + + " where a.workflowid = ? and a.isnode = 1 and a.ispreadd = 1 " + + " and a.type = 0 and c.nodetype = 0 and b.viewtype = 1 and b.detailtable = ?", workflowId,"formtable_main_"+formid+"_dt"+i); + while(rs.next()){ + String fieldname = Util.null2String(rs.getString("fieldName")); + String customervalue = Util.null2String(rs.getString("customerValue")); + if(!defaultData.containsKey(fieldname)){ + defaultData.put(fieldname, customervalue); + } + } + + defaultValueSet(defaultData,user,workflowId,"formtable_main_" + formid + "_dt" + i); + } + int num = 0; + for(Map dtlMap : dtlList){ //添加一行明细表数据 + tu.writeDebuggerLog("","明细表" + i + ",第" + (num + 1) + "行待写入字段信息:[" + dtlMap.toString() + "]!"); + + WorkflowRequestTableField[] workflowRequestTableFields = new WorkflowRequestTableField[dtlMap.size()+defaultData.size()]; + int j = 0; + for(Map.Entry entry:dtlMap.entrySet()){ + String key = entry.getKey(); + String value = entry.getValue(); + workflowRequestTableFields[j] = new WorkflowRequestTableField(); + workflowRequestTableFields[j].setFieldName(key);//字段名称 + workflowRequestTableFields[j].setFieldValue(value);//字段的值 + workflowRequestTableFields[j].setView(true);//字段是否可见 + workflowRequestTableFields[j].setEdit(true);//字段是否可编辑 + j++; + } + if(defaultValue){ + for(Map.Entry entry:defaultData.entrySet()){ + String key = entry.getKey(); + if(dtlMap.containsKey(key)){ + continue; + } + String value = entry.getValue(); + workflowRequestTableFields[j] = new WorkflowRequestTableField(); + workflowRequestTableFields[j].setFieldName(key);//字段名称 + workflowRequestTableFields[j].setFieldValue(value);//字段的值 + workflowRequestTableFields[j].setView(true);//字段是否可见 + workflowRequestTableFields[j].setEdit(true);//字段是否可编辑 + j++; + } + } + + tu.writeDebuggerLog("","明细表" + i + ",第" + (num + 1) + "行总有" + j + "字段!"); + + WorkflowRequestTableRecord[num] = new WorkflowRequestTableRecord(); + WorkflowRequestTableRecord[num].setWorkflowRequestTableFields(workflowRequestTableFields); + num++; + } + + tu.writeDebuggerLog("","明细表" + i + ",共有" + WorkflowRequestTableRecord.length + "行记录!"); + + workflowDetailTableInfos[i] = new WorkflowDetailTableInfo(); + workflowDetailTableInfos[i].setWorkflowRequestTableRecords(WorkflowRequestTableRecord); + } + + tu.writeDebuggerLog("","创建的流程共有" + workflowDetailTableInfos.length + "个明细表!"); + wri.setWorkflowDetailTableInfos(workflowDetailTableInfos);//添加明细字段信息 + } + return wsi.doCreateWorkflowRequest(wri,user.getUID()); + } + + /** + * 设置默认值 + * @param defaultData 默认数据集合 + * @param user 当前用户信息 + * @param workflowId 流程类型ID + * @param tableName 流程表名称 + */ + private static void defaultValueSet(Map defaultData,User user,String workflowId,String tableName){ + RecordSet rs = new RecordSet(); + + String selectSQL = "select a.fieldName,a.type from workflow_billfield a " + + " join workflow_base b on a.billid = b.formid " + + " where b.id = ? and a.fieldhtmltype = 3 " + + " and a.type in(1,2,4,19,178,164)"; + + if(!"".equals(tableName)){ + selectSQL += " and a.detailtable = '" + tableName + "' and a.viewtype = 1"; + }else{ + selectSQL += " and a.viewtype = 0"; + } + + //查询主表的人力资源、部门、分部、日期、年度等浏览按钮填写默认值 + rs.executeQuery(selectSQL, workflowId); + + while(rs.next()){ + String fieldName = Util.null2String(rs.getString("fieldName")); + int type = Util.getIntValue(rs.getString("type"),0); + if(!defaultData.containsKey(fieldName)){ + if(type == 1){//人力资源 + defaultData.put(fieldName, ""+user.getUID()); + }else if(type == 2){//日期 + defaultData.put(fieldName, TimeUtil.getCurrentDateString()); + }else if(type == 4){//部门 + defaultData.put(fieldName, ""+user.getUserDepartment()); + }else if(type == 19){//时间 + String timestrformart = "HH:mm" ; + SimpleDateFormat SDF = new SimpleDateFormat(timestrformart) ; + Calendar calendar = Calendar.getInstance() ; + defaultData.put(fieldName, SDF.format(calendar.getTime())); + }else if(type == 178){ //年 + defaultData.put(fieldName, TimeUtil.getCurrentDateString().split("-")[0]); + }else if(type == 164){//分部 + defaultData.put(fieldName, ""+user.getUserSubCompany1()); + } + } + } + } +} diff --git a/src/main/java/weaver/chaoyang/he/shangan/cornjob/MailInfoDao.java b/src/main/java/weaver/chaoyang/he/shangan/cornjob/MailInfoDao.java new file mode 100644 index 0000000..7263dee --- /dev/null +++ b/src/main/java/weaver/chaoyang/he/shangan/cornjob/MailInfoDao.java @@ -0,0 +1,107 @@ +package weaver.chaoyang.he.shangan.cornjob; + + +import org.apache.commons.lang3.StringUtils; + +import java.util.Date; +import java.util.List; + +/** + * 邮件信息 实体类 + */ +public class MailInfoDao { + + /** + * 发件人 + */ + private String from ; + + /** + * 发件日期 + */ + private Date date; + + /** + * 邮件主题 + */ + private String subject; + + /** + * 邮件内容 + */ + private String content; + + /** + * 是否包含附件 + */ + private boolean isContainAttachment; + + /** + * 附件ID(上传至OA系统) + */ + private List attachmentIdList; + + /** + * 对象toString 方法 + * @return 字符串 + */ + public String toString(){ + return "MailInfoDao Information: {" + + "form :" + from + ",\n" + + "date :" + date + ",\n" + + "subject :" + subject + ",\n" + + "content :" + content + ",\n" + + "isContainAttachment :" + isContainAttachment + ",\n" + + "attachmentIdList :" + StringUtils.join(attachmentIdList, ",") + "\n" + + "}"; + } + + + public String getFrom() { + return from; + } + + public void setFrom(String from) { + this.from = from; + } + + public Date getDate() { + return date; + } + + public void setDate(Date date) { + this.date = date; + } + + public String getSubject() { + return subject; + } + + public void setSubject(String subject) { + this.subject = subject; + } + + public String getContent() { + return content; + } + + public void setContent(String content) { + this.content = content; + } + + public boolean isContainAttachment() { + return isContainAttachment; + } + + public void setContainAttachment(boolean containAttachment) { + isContainAttachment = containAttachment; + } + + public List getAttachmentIdList() { + return attachmentIdList; + } + + public void setAttachmentIdList(List attachmentIdList) { + this.attachmentIdList = attachmentIdList; + } +} diff --git a/src/main/java/weaver/chaoyang/he/shangan/cornjob/MailTriggerWorkflowCronJob.java b/src/main/java/weaver/chaoyang/he/shangan/cornjob/MailTriggerWorkflowCronJob.java new file mode 100644 index 0000000..5f45f7e --- /dev/null +++ b/src/main/java/weaver/chaoyang/he/shangan/cornjob/MailTriggerWorkflowCronJob.java @@ -0,0 +1,190 @@ +package weaver.chaoyang.he.shangan.cornjob; + +import org.apache.commons.lang3.StringUtils; +import weaver.chaoyang.he.shangan.common.util.CommonWFUtil; +import weaver.chaoyang.he.zwl.common.ThreadPoolConfig; +import weaver.conn.RecordSet; +import weaver.general.TimeUtil; +import weaver.general.Util; +import weaver.hrm.User; +import weaver.interfaces.schedule.BaseCronJob; + +import weaver.zwl.common.ToolUtil; + +import java.util.*; +import java.util.concurrent.ExecutorService; + +/** + * 上海安装工程集团 + * 邮件触发流程 计划任务 + */ +public class MailTriggerWorkflowCronJob extends BaseCronJob { + + private final ToolUtil tool = new ToolUtil(); + + private final ReadMail readMail = new ReadMail(); + + + /** + * 实现父类方法 + * 具体的业务实现 + */ + @Override + public synchronized void execute(){ + tool.writeDebuggerLog("","-------- MailTriggerWorkflowCronJob Begin---------------"); + //拿到一个线程池 + ExecutorService threadPool = ThreadPoolConfig.createThreadPoolInstance(); + List> configList = readMail.getConfiguration(); + + tool.writeDebuggerLog("","configList:[" + configList.size() + "]"); + +// threadPool.execute(() -> { + for(Map configMap : configList){ + try { + getMainInfoAndCreateWorkflow(configMap); + } catch (Exception e) { + tool.writeDebuggerLog("","创建流程信息异常,异常信息:[" + e.getMessage() + "]"); + throw new RuntimeException(e); + } + } +// }); + + tool.writeDebuggerLog("","-------- MailTriggerWorkflowCronJob End---------------"); + } + + /** + * 获取邮箱中的邮件信息,且根据配置创建流程 + * @param dataMap 配置信息 + */ + @SuppressWarnings("unchecked") + private void getMainInfoAndCreateWorkflow(Map dataMap) throws Exception { + try { + //邮箱地址 + String mailAddress = (String) dataMap.get("mailAddress"); + //邮箱密码 + String mailPassword = (String) dataMap.get("mailPassword"); + //白名单列表 + String whiteList = Util.null2String(dataMap.get("whiteList")); + //获取用户ID + int remindUser = (int) dataMap.get("remindUser"); + //文档存储目录 + int secCategory = (int) dataMap.get("secCategory"); + //触发的流程类型ID + String workflowId = (String) dataMap.get("workflowId"); + //邮件文件夹 + String mailFolder = Util.null2String(dataMap.get("mailFolder")); + + //用户信息 + User createUser = new User(remindUser); + + //流程字段与邮件信息匹配集合 + List> fieldList = (List>) dataMap.get("fieldList"); + + List> newFieldList = new ArrayList<>(); + + //先对配置字段进行转换,将字段ID转成对应的字段数据库名 + for(Map fieldMap : fieldList){ + for(int key : fieldMap.keySet()){ + int fieldId = fieldMap.get(key); + //根据字段ID获取其字段名称 + String fieldName = getFieldNameByFieldid(fieldId); + + Map dtMap = new HashMap<>(); + dtMap.put("fieldName",fieldName); + dtMap.put("fieldId",fieldId); + dtMap.put("mailField",key); + + newFieldList.add(dtMap); + } + } + + //获取邮箱中的未读邮件 + List mailInfoDaoList = readMail.getMainInfo(mailAddress,mailPassword,whiteList,secCategory,remindUser,mailFolder); + + tool.writeDebuggerLog("","mailInfoDaoList:[" + mailInfoDaoList.size() + "]"); + if(mailInfoDaoList.size() > 0){ + for(MailInfoDao mailInfoDao : mailInfoDaoList){ + System.out.println(mailInfoDao.toString()); + + createWorkflow(workflowId,createUser,mailInfoDao,newFieldList); + } + } + } catch (Exception e) { + e.printStackTrace(); + tool.writeDebuggerLog("","导出邮箱中的未读邮件报错==="+e); + } + } + + /** + * 根据字段ID获取其对应的字段名称 + * @param fieldId 字段ID + * @return 字段名称 + */ + private String getFieldNameByFieldid(int fieldId){ + if(fieldId > 0){ + String querySQL = "select fieldname from workflow_billfield where id = ?"; + + RecordSet rs = new RecordSet(); + + if(rs.executeQuery(querySQL,fieldId) && rs.next()){ + return Util.null2String(rs.getString(1)); + } + } + return ""; + } + + + /** + * 创建流程信息 + * @param mailInfoDao 邮件信息实体类 + * @param fieldList 流程字段与邮件信息匹配映射 + */ + private void createWorkflow(String workflowId, User createUser, MailInfoDao mailInfoDao, List> fieldList) throws Exception { + Map mainTableMap = new HashMap<>(); + + for(Map fieldMap : fieldList){ + tool.writeDebuggerLog("","fieldMap:[" + fieldMap.toString() + "]"); + //字段数据库名 + String fieldName = Util.null2String(fieldMap.get("fieldName")); + + if(!"".equals(fieldName)){ + + int mailField = Util.getIntValue(Util.null2String(fieldMap.get("mailField")),-1); + + String fieldValue = ""; + + switch (mailField){ + case 0 ://发件人 + fieldValue = mailInfoDao.getFrom(); + break; + case 1 : //发件日期 + Date date = mailInfoDao.getDate(); + fieldValue = TimeUtil.getFormartString(date,"yyyy-MM-dd"); + break; + case 2 : //邮件主题 + fieldValue = mailInfoDao.getSubject(); + break; + case 3 : //邮件内容 + fieldValue = mailInfoDao.getContent(); + break; + case 4 ://是否包含附件 + fieldValue = mailInfoDao.isContainAttachment() ? "1" : "0"; + break; + case 5 : //附件 + List docIds = mailInfoDao.getAttachmentIdList(); + fieldValue = StringUtils.join(docIds,","); + break; + } + mainTableMap.put(fieldName,fieldValue); + } + } + + tool.writeDebuggerLog("","mainTableMap:[" + mainTableMap.toString() + "]"); + + if(!mainTableMap.isEmpty()){ + String requestId = CommonWFUtil.startWorkflow(workflowId,mainTableMap,null,true,createUser,"0"); + + tool.writeDebuggerLog("","创建成功的流程请求ID:[" + requestId + "]"); + } + } +} diff --git a/src/main/java/weaver/chaoyang/he/shangan/cornjob/ReadMail.java b/src/main/java/weaver/chaoyang/he/shangan/cornjob/ReadMail.java new file mode 100644 index 0000000..6e797df --- /dev/null +++ b/src/main/java/weaver/chaoyang/he/shangan/cornjob/ReadMail.java @@ -0,0 +1,520 @@ +package weaver.chaoyang.he.shangan.cornjob; + +import com.sun.mail.imap.IMAPFolder; +import com.sun.mail.imap.IMAPStore; +import org.apache.commons.lang3.StringUtils; +import weaver.conn.RecordSet; +import weaver.docs.docs.DocImageManager; +import weaver.docs.webservices.DocInfo; +import weaver.docs.webservices.DocServiceImpl; +import weaver.file.ImageFileManager; +import weaver.general.IOUtils; +import weaver.general.Util; +import weaver.hrm.User; +import weaver.zwl.common.ToolUtil; + +import javax.mail.*; +import javax.mail.internet.MimeMultipart; +import javax.mail.internet.MimeUtility; +import java.io.IOException; +import java.io.InputStream; +import java.lang.reflect.Method; +import java.util.*; + +/** + * 上海安装工程集团 + * 读取邮件信息工具类 + * + */ +public class ReadMail extends ToolUtil { + + /** + * 定义SSL factory + */ + private static final String SSL_FACTORY = "javax.net.ssl.SSLSocketFactory"; + + /** + * 定义邮箱host (腾讯邮箱)暂不修改 + */ + private static final String host = "imap.exmail.qq.com"; + + /** + * 定义邮箱端口 + */ + private static final String port = "993"; + + /** + * 邮箱连接Session + */ + private static Session session; + + /** + * 配置表名称 + */ + private final static String configTableName = "uf_mail_wf_config"; + + /** + * 获取收件箱中的邮件信息 + * @param mailAddress 邮箱地址 + * @param mailPassword 邮箱密码 + * @param whiteList 发件人白名单 + * @param secCategory 附件目录ID + * @param userId 操作者ID + * @return 返回收件箱中的邮件信息集合 + */ + public List getMainInfo(String mailAddress,String mailPassword,String whiteList,int secCategory,int userId){ + return getMainInfo(mailAddress,mailPassword,whiteList,secCategory,userId,""); + } + /** + * 获取收件箱中的邮件信息 + * @param mailAddress 邮箱地址 + * @param mailPassword 邮箱密码 + * @param whiteList 发件人白名单 + * @param secCategory 附件目录ID + * @param userId 操作者ID + * @param mailFolder 邮箱文件夹 + * @return 返回收件箱中的邮件信息集合 + */ + public List getMainInfo(String mailAddress,String mailPassword,String whiteList,int secCategory,int userId,String mailFolder){ + if(session == null){ + session = createSession(); + } + + List mailInfoDaoList = new ArrayList<>(); + //文件夹信息 + IMAPFolder folder = null; + //邮箱会话信息 + IMAPStore store = null; + try{ + store=(IMAPStore)session.getStore("imap"); // 使用imap会话机制,连接服务器 + store.connect(host,Util.getIntValue(port),mailAddress,mailPassword); + + if(StringUtils.isBlank(mailFolder)){ + mailFolder = "INBOX"; + } + + folder=(IMAPFolder)store.getFolder(mailFolder); //收件箱 + + // 使用只读方式打开收件箱 + folder.open(Folder.READ_WRITE); + + //获取所有的邮件 +// Message[] mess = folder.getMessages(); + //获取未读邮件 + Message[] mess = folder.getMessages(folder.getMessageCount()-folder.getUnreadMessageCount()+1,folder.getMessageCount()); + + for (Message message : mess) { + Flags flags = message.getFlags(); + if (!flags.contains(Flags.Flag.SEEN)) {//未读邮件处理 + String from = MimeUtility.decodeText(message.getFrom()[0].toString()); + + if (StringUtils.isNotBlank(whiteList) && !isBelongToWhite(whiteList, from)) { + continue; + } + //设置已读 + message.setFlag(Flags.Flag.SEEN, true); + + MailInfoDao mailInfoDao = analysisMessage(message, secCategory, userId); + + mailInfoDaoList.add(mailInfoDao); + } + } + }catch (MessagingException e) { + e.printStackTrace(); + this.writeDebuggerLog("","异常信息96:[" + e.getMessage() + "]"); + } catch (Exception e) { + e.printStackTrace(); + this.writeDebuggerLog("","异常信息99:[" + e.getMessage() + "]"); + throw new RuntimeException(e); + } finally { + try { + if (folder != null) { + folder.close(false); + } + if (store != null) { + store.close(); + } + } catch (MessagingException e) { + e.printStackTrace(); + this.writeDebuggerLog("","异常信息110:[" + e.getMessage() + "]"); + } + } + + return mailInfoDaoList; + + } + + /** + * 解析邮件信息 + * @param message 邮件 + * @param secCategory 附件存储目录 + * @param userId 附件所属者 + * @return 返回邮件对象 + * @throws Exception 抛出异常信息 + */ + private MailInfoDao analysisMessage(Message message,int secCategory,int userId) throws Exception { + MailInfoDao dao = new MailInfoDao(); + //邮件发送主题 + String subject = message.getSubject(); + //发送日期 + Date date = message.getSentDate(); + //邮件正文 + String htmlContent = getTextFromMessage(message); + + String from = MimeUtility.decodeText(message.getFrom()[0].toString()); + + + //是否包含附件 + boolean isContainAttachment = isContainAttachment(message); + + dao.setFrom(from); + dao.setSubject(subject); + dao.setDate(date); + dao.setContent(htmlContent); + dao.setContainAttachment(isContainAttachment); + if(isContainAttachment){ + List docList = saveAttachment(message,secCategory,userId); + dao.setAttachmentIdList(docList); + } + + return dao; + } + + + /** + * 判断邮件中是否包含附件 + * @return 邮件中存在附件返回true,不存在返回false + * @throws MessagingException Message异常信息 + * @throws IOException IO异常信息 + */ + private boolean isContainAttachment(Part part) throws MessagingException, IOException { + boolean flag = false; + if (part.isMimeType("multipart/*")) { + MimeMultipart multipart = (MimeMultipart) part.getContent(); + int partCount = multipart.getCount(); + for (int i = 0; i < partCount; i++) { + BodyPart bodyPart = multipart.getBodyPart(i); + String disposition = bodyPart.getDisposition(); + if (disposition != null && (disposition.equalsIgnoreCase(Part.ATTACHMENT) || disposition.equalsIgnoreCase(Part.INLINE))) { + flag = true; + } else if (bodyPart.isMimeType("multipart/*")) { + flag = isContainAttachment(bodyPart); + } else { + String contentType = bodyPart.getContentType(); + if (contentType.contains("application") || contentType.contains("name")) { + flag = true; + } + } + + if (flag) break; + } + } else if (part.isMimeType("message/rfc822")) { + flag = isContainAttachment((Part)part.getContent()); + } + return flag; + } + + /** + * 获取邮件附件信息,同时将附件上传至OA系统中返回对应的文档ID + * @param part 邮件中多个组合体中的其中一个组合体 + * @throws Exception 抛出的异常信息 + */ + private List saveAttachment(Part part,int secCategory,int userId) throws Exception { + + List docList = new ArrayList<>(); + + if (part.isMimeType("multipart/*")) { + Multipart multipart = (Multipart) part.getContent(); //复杂体邮件 + //复杂体邮件包含多个邮件体 + int partCount = multipart.getCount(); + for (int i = 0; i < partCount; i++) { + //获得复杂体邮件中其中一个邮件体 + BodyPart bodyPart = multipart.getBodyPart(i); + //某一个邮件体也有可能是由多个邮件体组成的复杂体 + String disposition = bodyPart.getDisposition(); + + if (disposition != null && (disposition.equalsIgnoreCase(Part.ATTACHMENT) || disposition.equalsIgnoreCase(Part.INLINE))) { + InputStream is = bodyPart.getInputStream(); + //附件名称 + String fileName = MimeUtility.decodeText(bodyPart.getFileName()); + int imageFileId = createFileByInputSteam(is, fileName); + + if(imageFileId > 0){ + int docId = createDocByImageFileId(fileName,secCategory,imageFileId,userId); + + docList.add(docId); + } + } else if (bodyPart.isMimeType("multipart/*")) { + docList.addAll(saveAttachment(bodyPart,secCategory,userId)); + } else { + + /*String contentType = bodyPart.getContentType(); + if (contentType.contains("name") || contentType.contains("application")) { + //附件名称 + String fileName = MimeUtility.decodeText(bodyPart.getFileName()); + int imageFileId = createFileByInputSteam(bodyPart.getInputStream(), fileName); + + if(imageFileId > 0){ + int docId = createDocByImageFileId(fileName,secCategory,imageFileId,userId); + docList.add(docId); + } + }*/ + + } + } + } else if (part.isMimeType("message/rfc822")) { + docList.addAll(saveAttachment((Part) part.getContent(),secCategory,userId)); + } + + return docList; + } + + /** + * 创建文件信息,文件权限继承文档目录权限 + * + * @param fileName 文件名称 + * @param secCategory 文件目录 + * @param imageFileId 物理文件ID + * @param userId 用户ID + * @return 文档ID + * @throws Exception 可能会出现的异常 + */ + private int createDocByImageFileId(String fileName, int secCategory, int imageFileId, Integer userId) throws Exception { + DocInfo docInfo = new DocInfo(); + docInfo.setImagefileId(imageFileId); + docInfo.setSeccategory(secCategory); + docInfo.setDocSubject(fileName); + docInfo.setDoccontent(""); + DocServiceImpl docService = new DocServiceImpl(); + User user = new User(userId); + user.setLanguage(7); + + int docId = docService.createDocByUser(docInfo, user); + DocImageManager imgManger = new DocImageManager(); + imgManger.resetParameter(); + imgManger.setDocid(docId); + imgManger.setImagefileid(imageFileId); + imgManger.setImagefilename(fileName); + imgManger.setIsextfile("1"); + String ext = fileName.substring(fileName.lastIndexOf(".") + 1); + if ("doc".equalsIgnoreCase(ext)) { + imgManger.setDocfiletype("3"); + } else if ("xls".equalsIgnoreCase(ext)) { + imgManger.setDocfiletype("4"); + } else if ("ppt".equalsIgnoreCase(ext)) { + imgManger.setDocfiletype("5"); + } else if ("wps".equalsIgnoreCase(ext)) { + imgManger.setDocfiletype("6"); + } else if ("docx".equalsIgnoreCase(ext)) { + imgManger.setDocfiletype("7"); + } else if ("xlsx".equalsIgnoreCase(ext)) { + imgManger.setDocfiletype("8"); + } else if ("pptx".equalsIgnoreCase(ext)) { + imgManger.setDocfiletype("9"); + } else { + imgManger.setDocfiletype("2"); + } + imgManger.AddDocImageInfo(); + return docId; + } + + + /** + * 创建物理文件 + * + * @param content 文件流 + * @param fileName 文件名 + * @return 文件id + */ + private int createFileByInputSteam(InputStream content, String fileName) { + ImageFileManager imageFileManager = new ImageFileManager(); + int imgFileId = 0; + try { + Method saveImageFileByInputStream = ImageFileManager.class.getMethod("saveImageFileByInputStream", InputStream.class, String.class); + imgFileId = (int) saveImageFileByInputStream.invoke(imageFileManager, content, fileName); + } catch (NoSuchMethodException e) { + imageFileManager.setImagFileName(fileName); + try { + imageFileManager.setData(IOUtils.toBytes(content)); + imgFileId = imageFileManager.saveImageFile(); + } catch (Exception ex) { + ex.printStackTrace(); + this.writeDebuggerLog("","创建文件失败,文件流转换失败,失败原因:[" + e.getMessage() + "]"); + } + } catch (Exception e) { + e.printStackTrace(); + this.writeDebuggerLog("","创建文件失败,失败原因:[" + e.getMessage() + "]"); + } + return imgFileId; + } + + /** + * 解析邮件正文 + * @param message 邮件消息类 + * @return 返回邮件正文 + * @throws MessagingException 信息异常 + * @throws IOException IO流异常 + */ + private String getTextFromMessage(Message message) throws MessagingException, IOException { + String result = ""; + + if (message.isMimeType("text/plain")) { + result = message.getContent().toString(); + } else if (message.isMimeType("multipart/*")) { + MimeMultipart mimeMultipart = (MimeMultipart) message.getContent(); + result = getTextFromMimeMultipart(mimeMultipart); + } + + return result; + } + + /** + * 复杂体 递归获取邮件正文 + * @param mimeMultipart 邮件复杂体类 + * @return 正文 + * @throws MessagingException 信息异常 + * @throws IOException IO流异常 + */ + private String getTextFromMimeMultipart( + MimeMultipart mimeMultipart) throws MessagingException, IOException{ + + StringBuilder result = new StringBuilder(); + + int count = mimeMultipart.getCount(); + + for (int i = 0; i < count; i++) { + BodyPart bodyPart = mimeMultipart.getBodyPart(i); + if (bodyPart.isMimeType("text/plain")) { + result.append(bodyPart.getContent()); + break; // without break same text appears twice in my tests + } else if (bodyPart.isMimeType("text/html")) { + String html = (String) bodyPart.getContent(); + //result.append(org.jsoup.Jsoup.parse(html).text()); + result.append(html); + } else if (bodyPart.getContent() instanceof MimeMultipart){ + result.append(getTextFromMimeMultipart((MimeMultipart) bodyPart.getContent())); + } + + } + + return result.toString(); + + } + + + /** + * 判断发件人 是否属于白名单中 + * @param whiteList 白名单列表 + * @param from 发件人 + * @return 返回判断结果 + */ + private boolean isBelongToWhite(String whiteList,String from){ + boolean isContain = false; + + List list = Util.splitString2List(whiteList,";"); + + for(String mail : list){ + if(from.contains(mail)){ + isContain = true; + break; + } + } + + return isContain; + } + + /** + * 获取登录邮箱的Session信息 + * @return 返回创建的Session + */ + private Session createSession(){ + Properties props = System.getProperties(); + props.setProperty("mail.imap.socketFactory.class", SSL_FACTORY); + props.setProperty("mail.imap.socketFactory.port",port); + props.setProperty("mail.store.protocol","imap"); + props.setProperty("mail.imap.host", host); + props.setProperty("mail.imap.port", port); + props.setProperty("mail.imap.auth.login.disable", "true"); + Session session = Session.getDefaultInstance(props,null); + session.setDebug(false); + return session; + } + + /** + * 获取建模配置信息 + * @return 返回建模配置信息集合 + */ + public List> getConfiguration(){ + //查询配置信息 + String selectData = "select u.*,wb.docCategory from " + configTableName + " u left join workflow_base wb on u.workflowId = wb.id where u.status = 1"; + + String selectDetailData = "select * from " + configTableName + "_dt1 where mainId = ?"; + RecordSet rs = new RecordSet(); + + List> configList = new ArrayList<>(); + + RecordSet rs_d = new RecordSet(); + + int mainId; + + if(rs.executeQuery(selectData)){ + while(rs.next()){ + mainId = Util.getIntValue(rs.getString("id"),-1); + //流程类型ID + String workflowId = Util.null2String(rs.getString("workflowId")); + //收件人邮箱 + String mailAddress = Util.null2String(rs.getString("mailAddress")); + //邮箱密码 + String mailPassword = Util.null2String(rs.getString("mailPassword")); + //邮件内容写入字段ID + //int contentField = Util.getIntValue(rs.getString("contentField"),0); + //提醒人 + int remindUser = Util.getIntValue(rs.getString("remindUser"),0); + //发件人白名单 + String whiteSender = Util.null2String(rs.getString("whiteSender")); + //文件夹目录 + String docCategory = Util.null2String(rs.getString("docCategory")); + //邮箱文件夹 + String mailFolder = Util.null2String(rs.getString("mailFolder")); + + Map detailMap = new HashMap<>(); + + detailMap.put("workflowId",workflowId); + detailMap.put("mailAddress",mailAddress); + detailMap.put("mailPassword",mailPassword); + detailMap.put("mailFolder",mailFolder); + detailMap.put("remindUser",remindUser); + detailMap.put("whiteSender",whiteSender); + + int secCategory = -1; + if(!"".equals(docCategory)){ + secCategory = Util.getIntValue(docCategory.substring(docCategory.lastIndexOf(",")),0); + } + + detailMap.put("secCategory",secCategory); + + List> fieldList = new ArrayList<>(); + if(rs_d.executeQuery(selectDetailData,mainId)){ + while(rs_d.next()){ + //邮件字段 + int mailField = Util.getIntValue(rs_d.getString("mailField"),0); + //流程字段 + int billField = Util.getIntValue(rs_d.getString("billField"),0); + + Map fieldMap = new HashMap<>(); + fieldMap.put(mailField,billField); + + fieldList.add(fieldMap); + } + } + + detailMap.put("fieldList",fieldList); + + configList.add(detailMap); + } + } + + return configList; + } + +} diff --git a/src/main/java/weaver/chaoyang/he/xiao/commons/config/dao/ConfigMappingCMD.java b/src/main/java/weaver/chaoyang/he/xiao/commons/config/dao/ConfigMappingCMD.java new file mode 100644 index 0000000..f020e94 --- /dev/null +++ b/src/main/java/weaver/chaoyang/he/xiao/commons/config/dao/ConfigMappingCMD.java @@ -0,0 +1,162 @@ +package weaver.chaoyang.he.xiao.commons.config.dao; + +import weaver.conn.RecordSet; +import weaver.general.Util; +import weaver.xiao.commons.config.entity.DocImageFile; +import weaver.xiao.commons.config.entity.FieldMessage; +import weaver.xiao.commons.config.entity.MappingDetail; +import weaver.xiao.commons.config.entity.RequestMappingConfig; +import weaver.xiao.commons.config.enumtype.DataSourceEnum; +import weaver.xiao.commons.exception.ValueDealException; +import weaver.xiao.commons.utils.SqlUtil; +import weaver.zwl.common.ToolUtil; + +import java.util.ArrayList; +import java.util.List; +import java.util.Objects; + + +/** + * @author XiaoBokang + * @create 2021/12/29 9:46 + */ + +public class ConfigMappingCMD { + + private final ToolUtil toolUtil = new ToolUtil(); + private final String configTableName = "uf_request_config"; + private final SqlUtil sqlUtil = new SqlUtil(); + + public RequestMappingConfig selectByUniqueCode(String uniqueCode) { + toolUtil.writeDebuggerLog("=======================查询配置列表======================="); + RequestMappingConfig requestMappingConfig = new RequestMappingConfig(); + RecordSet recordSet = new RecordSet(); + String querySql = "select id,workflow,requestUrl,dataSource,uniqueCode from " + configTableName + " where uniqueCode = ?"; + toolUtil.writeDebuggerLog("执行查询的sql query mainRequestMappingConfig list sql new>>>>" + querySql + " uniqueCode >>" + uniqueCode); + recordSet.executeQuery(querySql, uniqueCode); + if (recordSet.next()) { + int mainId = Util.getIntValue(recordSet.getString("id")); + requestMappingConfig = sqlUtil.recordSetToEntityByEntity(recordSet, RequestMappingConfig.class); + this.setDetailMapping(mainId, requestMappingConfig); + } + return requestMappingConfig; + } + + private void setDetailMapping(int mainId, RequestMappingConfig requestMappingConfig) { + // 查询明细1的信息 + RecordSet detail1RecordSet = new RecordSet(); + String dataSource = requestMappingConfig.getDataSource(); + if (Objects.isNull(dataSource) || "".equals(dataSource)) { + dataSource = "0"; + } + DataSourceEnum anEnum = DataSourceEnum.getEnum(dataSource); + String queryDetail1Sql = ""; + switch (anEnum) { + case CUS_TABLE: + queryDetail1Sql = "select paramName,paramType,getValueType,dataSource,belongTo,workflowField,modelField,fieldName,valueContext," + + " from " + configTableName + "_dt1 config "; + break; + case WORKFLOW: + queryDetail1Sql = "select paramName,paramType,getValueType,dataSource,belongTo,workflowField,modelField,valueContext," + + " fv.id fieldId,fv.fieldname,fv.tablename,fv.indexdesc " + + " from " + configTableName + "_dt1 config " + + " left join workflow_field_table_view fv on config.workflowField = fv.id " + + " where mainid = ? "; + break; + case MODEL: + queryDetail1Sql = "select paramName,paramType,getValueType,dataSource,belongTo,workflowField,modelField,fieldName,valueContext," + + " fv.id fieldId,fv.fieldname,fv.tablename,fv.indexdesc " + + " from " + configTableName + "_dt1 config " + + " left join workflow_field_table_view fv on config.modelField = fv.id " + + " where mainid = ? "; + break; + default: + throw new ValueDealException("不支持的数据来源"); + } + toolUtil.writeDebuggerLog("执行查询的明细1sql query detail1Sql >>>>" + queryDetail1Sql + " mainId:" + mainId); + detail1RecordSet.executeQuery(queryDetail1Sql, mainId); + List mappingDetails = new ArrayList<>(); + while (detail1RecordSet.next()) { + MappingDetail mappingDetail = sqlUtil.recordSetToEntityByEntity(detail1RecordSet, MappingDetail.class); + String getValueType = mappingDetail.getGetValueType(); + // 设置流程字段相关信息 +// if("0".equals(getValueType) || "4".equals(getValueType)){ + FieldMessage fieldMessage = sqlUtil.recordSetToEntityByEntity(detail1RecordSet, FieldMessage.class); + mappingDetail.setFieldMassage(fieldMessage); +// } + mappingDetails.add(mappingDetail); + } + // 查询明细2的信息 + RecordSet detail2RecordSet = new RecordSet(); + String queryDetail2Sql = "select paramName,belongTo,childType,dataSource,detailId from uf_request_config_dt2 where mainid = ?"; + toolUtil.writeDebuggerLog("执行查询的明细sql query detail2Sql >>>>" + queryDetail2Sql + " mainId:" + mainId); + detail2RecordSet.executeQuery(queryDetail2Sql, mainId); + while (detail2RecordSet.next()) { + MappingDetail mappingDetail = sqlUtil.recordSetToEntityByEntity(detail2RecordSet, MappingDetail.class); + mappingDetail.setParamType("6");// 设置参数类型为List + mappingDetails.add(mappingDetail); + } + // 查询明细3的信息 + RecordSet detail3RecordSet = new RecordSet(); + String queryDetail3Sql = "select paramName,belongTo from uf_request_config_dt3 where mainid = ?"; + toolUtil.writeDebuggerLog("执行查询的明细sql query detail3Sql >>>>" + queryDetail3Sql + " mainId:" + mainId); + detail3RecordSet.executeQuery(queryDetail3Sql, mainId); + while (detail3RecordSet.next()) { + MappingDetail mappingDetail = sqlUtil.recordSetToEntityByEntity(detail3RecordSet, MappingDetail.class); + mappingDetail.setParamType("5");// 设置参数类型为Object + mappingDetails.add(mappingDetail); + } + requestMappingConfig.setConfigDetail(mappingDetails); +// //查询明细4的信息 +// RecordSet detail4RecordSet = new RecordSet(); +// List responseMappingList = new ArrayList<>(); +// String queryDetail4Sql = "select responseFieldName,workflowField,mainOrDetail,detailTableId,workflowFieldName from uf_request_config_dt4 where mainid = ?"; +// toolUtil.writeDebuggerLog("执行查询的明细sql query detail4Sql >>>>"+queryDetail4Sql+" mainId:"+mainId); +// detail4RecordSet.executeQuery(queryDetail4Sql,mainId); +// while (detail4RecordSet.next()){ +// ResponseMapping responseMapping = sqlUtil.recordSetToEntityByEntity(detail4RecordSet, ResponseMapping.class); +// responseMappingList.add(responseMapping); +// } +// requestMappingConfig.setResponseMappingList(responseMappingList); + requestMappingConfig.setConfigDetail(mappingDetails); + } + + + /** + *

查询附件信息

+ * + * @param docIds 文档id + * @return 附件信息 + * @author YouHong.ai + */ + public List selectDocImageFileList(String docIds) { + String sql = "select docfile.IMAGEFILEID,docfile.IMAGEFILENAME,docfile.DOCID,docfile.ID, " + + " imf.FILESIZE " + + "from docimagefile docfile " + + "left join imagefile imf on imf.IMAGEFILEID = docfile.IMAGEFILEID " + + "where docid in (" + docIds + ")"; + RecordSet rs = new RecordSet(); + rs.executeQuery(sql); + List docImageFileList = new ArrayList<>(); + while (rs.next()) { + String IMAGEFILEID = rs.getString("IMAGEFILEID"); + String IMAGEFILENAME = rs.getString("IMAGEFILENAME"); + String DOCID = rs.getString("DOCID"); + String ID = rs.getString("ID"); + String fileSize = rs.getString("FILESIZE"); + DocImageFile docImageFile = new DocImageFile(); + docImageFile.setImageFileId(Util.getIntValue(IMAGEFILEID)); + docImageFile.setImageFileName(IMAGEFILENAME); + docImageFile.setDocId(Util.getIntValue(DOCID)); + docImageFile.setId(Util.getIntValue(ID)); + docImageFile.setFileSize(Util.getIntValue(fileSize) / 1024L); + docImageFileList.add(docImageFile); + } + if (docImageFileList.isEmpty()) { + throw new NullPointerException("附件字段不存在值!请检查数据表或配置表数据类型是否正确!"); + } + return docImageFileList; + } + + +} diff --git a/src/main/java/weaver/chaoyang/he/xiao/commons/config/entity/DocImageFile.java b/src/main/java/weaver/chaoyang/he/xiao/commons/config/entity/DocImageFile.java new file mode 100644 index 0000000..e78ff99 --- /dev/null +++ b/src/main/java/weaver/chaoyang/he/xiao/commons/config/entity/DocImageFile.java @@ -0,0 +1,40 @@ +package weaver.chaoyang.he.xiao.commons.config.entity; + +import lombok.Getter; +import lombok.Setter; +import lombok.ToString; + +/** + *

附件信息

+ * + *

create: 2022-11-21 10:55

+ * + * @author youHong.ai + */ + +@Getter +@Setter +@ToString +public class DocImageFile { + /** + * 文件id + */ + private Integer imageFileId; + /** + * 文件名称 + */ + private String imageFileName; + /** + * docId + */ + private Integer docId; + /** + * id + */ + private Integer id; + + /** + * 文件大小 + */ + private Long fileSize; +} diff --git a/src/main/java/weaver/chaoyang/he/xiao/commons/config/entity/FieldMessage.java b/src/main/java/weaver/chaoyang/he/xiao/commons/config/entity/FieldMessage.java new file mode 100644 index 0000000..c60a52c --- /dev/null +++ b/src/main/java/weaver/chaoyang/he/xiao/commons/config/entity/FieldMessage.java @@ -0,0 +1,26 @@ +package weaver.chaoyang.he.xiao.commons.config.entity; + +import lombok.Data; +import weaver.xiao.commons.utils.annotation.SqlFieldMapping; + +/** + * @author XiaoBokang + * @create 2021/12/31 10:15 + */ + +@Data +public class FieldMessage { + + @SqlFieldMapping("fieldId") + private String fieldId; + + @SqlFieldMapping("fieldName") + private String fieldName; + + @SqlFieldMapping("indexDesc") + private String indexDesc; + + @SqlFieldMapping("tableName") + private String tableName; + +} diff --git a/src/main/java/weaver/chaoyang/he/xiao/commons/config/entity/ListMapIndexValue.java b/src/main/java/weaver/chaoyang/he/xiao/commons/config/entity/ListMapIndexValue.java new file mode 100644 index 0000000..bb694d3 --- /dev/null +++ b/src/main/java/weaver/chaoyang/he/xiao/commons/config/entity/ListMapIndexValue.java @@ -0,0 +1,17 @@ +package weaver.chaoyang.he.xiao.commons.config.entity; + +import lombok.Data; + +/** + *

list分割暂存类

+ * + *

create: 2022-08-05 11:25

+ * + * @author aiyh EBU7-dev-1 + */ + +@Data +public class ListMapIndexValue { + private String key; + private Object value; +} diff --git a/src/main/java/weaver/chaoyang/he/xiao/commons/config/entity/MappingDetail.java b/src/main/java/weaver/chaoyang/he/xiao/commons/config/entity/MappingDetail.java new file mode 100644 index 0000000..97ca74a --- /dev/null +++ b/src/main/java/weaver/chaoyang/he/xiao/commons/config/entity/MappingDetail.java @@ -0,0 +1,48 @@ +package weaver.chaoyang.he.xiao.commons.config.entity; + +import lombok.Data; +import weaver.xiao.commons.config.entity.FieldMessage; +import weaver.xiao.commons.utils.annotation.SqlFieldMapping; + +import java.util.List; + +/** + * @author XiaoBokang + * @create 2021/12/28 17:45 + */ + +@Data +public class MappingDetail { + + @SqlFieldMapping("paramName") + private String paramName; + + @SqlFieldMapping("paramType") + private String paramType; + + @SqlFieldMapping("getValueType") + private String getValueType; + + @SqlFieldMapping("childType") + private String childType; + + @SqlFieldMapping("dataSource") + private String dataSource; + + @SqlFieldMapping("detailId") + private String detailId; + + @SqlFieldMapping("belongTo") + private String belongTo; + + @SqlFieldMapping("workflowField") + private String workflowField; + + @SqlFieldMapping("valueContext") + private String valueContext; + + private List childList; + + private FieldMessage fieldMassage; + +} diff --git a/src/main/java/weaver/chaoyang/he/xiao/commons/config/entity/MultipartFile.java b/src/main/java/weaver/chaoyang/he/xiao/commons/config/entity/MultipartFile.java new file mode 100644 index 0000000..1acddba --- /dev/null +++ b/src/main/java/weaver/chaoyang/he/xiao/commons/config/entity/MultipartFile.java @@ -0,0 +1,37 @@ +package weaver.chaoyang.he.xiao.commons.config.entity; + +import lombok.Getter; +import lombok.Setter; +import lombok.ToString; + +import java.io.InputStream; + +/** + *

+ * + *

create: 2022-11-21 11:12

+ * + * @author youHong.ai + */ + +@Setter +@Getter +@ToString +public class MultipartFile { + /** + * 文件名 + */ + String fileName; + /** + * 上传文件的key + */ + String fileKey; + /** + * 文件流信息 + */ + InputStream stream; + /** + * 文件大小 + */ + Long fileSize; +} diff --git a/src/main/java/weaver/chaoyang/he/xiao/commons/config/entity/RequestMappingConfig.java b/src/main/java/weaver/chaoyang/he/xiao/commons/config/entity/RequestMappingConfig.java new file mode 100644 index 0000000..ab7ed80 --- /dev/null +++ b/src/main/java/weaver/chaoyang/he/xiao/commons/config/entity/RequestMappingConfig.java @@ -0,0 +1,45 @@ +package weaver.chaoyang.he.xiao.commons.config.entity; + + + +import lombok.Data; +import weaver.xiao.commons.config.entity.MappingDetail; +import weaver.xiao.commons.config.entity.ResponseMapping; +import weaver.xiao.commons.utils.annotation.SqlFieldMapping; + +import java.util.List; + +/** + * @author XiaoBokang + * @create 2021/12/28 17:43 + */ + +@Data +public class RequestMappingConfig { + + @SqlFieldMapping("workflow") + private String workflow; + + @SqlFieldMapping("requestUrl") + private String requestUrl; + + @SqlFieldMapping("uniqueCode") + private String uniqueCode; + + @SqlFieldMapping("dataSource") + private String dataSource; + + @SqlFieldMapping("modelId") + private String modelId; + + @SqlFieldMapping("tableName") + private String tableName; + + @SqlFieldMapping("urlDesc") + private String urlDesc; + + private List configDetail; + + private List responseMappingList; + +} diff --git a/src/main/java/weaver/chaoyang/he/xiao/commons/config/entity/ResponseMapping.java b/src/main/java/weaver/chaoyang/he/xiao/commons/config/entity/ResponseMapping.java new file mode 100644 index 0000000..3e93cf1 --- /dev/null +++ b/src/main/java/weaver/chaoyang/he/xiao/commons/config/entity/ResponseMapping.java @@ -0,0 +1,17 @@ +package weaver.chaoyang.he.xiao.commons.config.entity; + +import lombok.Data; + +/** + * @author XiaoBokang + * @create 2022/4/12 22:28 + */ + +@Data +public class ResponseMapping { + private String responseFieldName; + private String workflowField; + private String mainOrDetail; + private String detailTableId; + private String workflowFieldName; +} diff --git a/src/main/java/weaver/chaoyang/he/xiao/commons/config/enumtype/DataSourceEnum.java b/src/main/java/weaver/chaoyang/he/xiao/commons/config/enumtype/DataSourceEnum.java new file mode 100644 index 0000000..52dc902 --- /dev/null +++ b/src/main/java/weaver/chaoyang/he/xiao/commons/config/enumtype/DataSourceEnum.java @@ -0,0 +1,35 @@ +package weaver.chaoyang.he.xiao.commons.config.enumtype; + +import java.util.EnumSet; +import java.util.HashMap; +import java.util.Map; + +/** + * @author XiaoBokang + * @create 2022/6/14 12:26 + */ + +public enum DataSourceEnum { + + WORKFLOW("0"), + MODEL("1"), + CUS_TABLE("2"); + + private static final Map LOOK_UP = new HashMap<>(8); + + static { + for (DataSourceEnum dataSource : EnumSet.allOf(DataSourceEnum.class)){ + LOOK_UP.put(dataSource.value,dataSource); + } + } + public final String value; + + DataSourceEnum(String value){ + this.value = value; + } + + public static DataSourceEnum getEnum(String value){ + return LOOK_UP.get(value); + } + +} diff --git a/src/main/java/weaver/chaoyang/he/xiao/commons/config/enumtype/GetValueTypeEnum.java b/src/main/java/weaver/chaoyang/he/xiao/commons/config/enumtype/GetValueTypeEnum.java new file mode 100644 index 0000000..868d8bb --- /dev/null +++ b/src/main/java/weaver/chaoyang/he/xiao/commons/config/enumtype/GetValueTypeEnum.java @@ -0,0 +1,44 @@ +package weaver.chaoyang.he.xiao.commons.config.enumtype; + +import java.util.EnumSet; +import java.util.HashMap; +import java.util.Map; + +/** + * @author XiaoBokang + * @create 2022/6/14 13:13 + */ + +public enum GetValueTypeEnum { + + WORKFLOW_FIELD("0"), + DEFAULT_VALUE("1"), + CURRENT_TIME("3"), + CUS_SQL("4"), + REQUEST_ID("5"), + MAIN_DATA_ID("6"), + RANDOM("7"), + ATTACHMENT("8"), + + CUS_INTERFACE("9"), + + CUS_FIELD("10"); + + private static final Map LOOK_UP = new HashMap<>(8); + + static { + for (GetValueTypeEnum getValueTypeEnum : EnumSet.allOf(GetValueTypeEnum.class)) { + LOOK_UP.put(getValueTypeEnum.value, getValueTypeEnum); + } + } + + public final String value; + + GetValueTypeEnum(String value) { + this.value = value; + } + + public static GetValueTypeEnum getEnum(String value) { + return LOOK_UP.get(value); + } +} diff --git a/src/main/java/weaver/chaoyang/he/xiao/commons/config/enumtype/ParamTypeEnum.java b/src/main/java/weaver/chaoyang/he/xiao/commons/config/enumtype/ParamTypeEnum.java new file mode 100644 index 0000000..108d26f --- /dev/null +++ b/src/main/java/weaver/chaoyang/he/xiao/commons/config/enumtype/ParamTypeEnum.java @@ -0,0 +1,43 @@ +package weaver.chaoyang.he.xiao.commons.config.enumtype; + +import java.util.EnumSet; +import java.util.HashMap; +import java.util.Map; + +/** + * @author XiaoBokang + * @create 2022/6/14 12:56 + */ + +public enum ParamTypeEnum { + + STRING("0"), + INT("1"), + DOUBLE("2"), + DATE("3"), + DATE_TIME("4"), + OBJECT("5"), + LIST("6"), + CUS_DATE_STR("7"), + TIME_STAMP("8"), + DATE_VAL("9"), + Boolean("10"); + + + private static final Map LOOK_UP = new HashMap<>(8); + + static { + for (ParamTypeEnum paramTypeEnum : EnumSet.allOf(ParamTypeEnum.class)){ + LOOK_UP.put(paramTypeEnum.value,paramTypeEnum); + } + } + public final String value; + + ParamTypeEnum(String value){ + this.value = value; + } + + public static ParamTypeEnum getEnum(String value){ + return LOOK_UP.get(value); + } +} diff --git a/src/main/java/weaver/chaoyang/he/xiao/commons/config/interfacies/CusInterfaceGetValue.java b/src/main/java/weaver/chaoyang/he/xiao/commons/config/interfacies/CusInterfaceGetValue.java new file mode 100644 index 0000000..345f746 --- /dev/null +++ b/src/main/java/weaver/chaoyang/he/xiao/commons/config/interfacies/CusInterfaceGetValue.java @@ -0,0 +1,38 @@ +package weaver.chaoyang.he.xiao.commons.config.interfacies; + +import org.apache.log4j.Logger; +import weaver.xiao.commons.utils.LogUtil; + +import java.util.Map; + +/** + *

自定义获取参数值

+ * + * @author EBU7-dev-1 aiyh + *

create: 2022-07-25 14:18

+ */ + +public interface CusInterfaceGetValue { + + final String START_LEFT = "{"; + final String VAR_START_STR = "#{"; + final String MAIN = "main."; + final String DETAIL = "detail."; + final String END_STR = "}"; + + final String SQL_START = "#sql{"; + + final Logger log = LogUtil.getLogger(); + + /** + * 获取参数值 + * + * @param mainMap 主表数据 + * @param detailMap 明细表数据 + * @param currentValue 当前字段值 + * @param pathParam 路径参数 + * @return 最终返回参数 + */ + Object execute(Map mainMap, Map detailMap, String currentValue, + Map pathParam); +} diff --git a/src/main/java/weaver/chaoyang/he/xiao/commons/config/interfacies/CusInterfaceListValue.java b/src/main/java/weaver/chaoyang/he/xiao/commons/config/interfacies/CusInterfaceListValue.java new file mode 100644 index 0000000..add6dd1 --- /dev/null +++ b/src/main/java/weaver/chaoyang/he/xiao/commons/config/interfacies/CusInterfaceListValue.java @@ -0,0 +1,25 @@ +package weaver.chaoyang.he.xiao.commons.config.interfacies; + +import java.util.List; +import java.util.Map; + +/** + *

自定义数组数据来源

+ * + *

create: 2022-08-15 15:38

+ * + * @author aiyh EBU7-dev-1 + */ + +public interface CusInterfaceListValue { + + /** + *

自定义数组数据来源

+ * + * @param pathParam 路径参数 + * @param mainMap 主表数据 + * @param mainTable 主表表明 + * @return 数组 + */ + List execute(Map pathParam, Map mainMap, String mainTable); +} diff --git a/src/main/java/weaver/chaoyang/he/xiao/commons/config/service/DealWithMapping.java b/src/main/java/weaver/chaoyang/he/xiao/commons/config/service/DealWithMapping.java new file mode 100644 index 0000000..d47db40 --- /dev/null +++ b/src/main/java/weaver/chaoyang/he/xiao/commons/config/service/DealWithMapping.java @@ -0,0 +1,855 @@ +package weaver.chaoyang.he.xiao.commons.config.service; + +import com.alibaba.fastjson.JSON; +import com.google.common.base.Strings; +import lombok.AllArgsConstructor; +import lombok.Data; +import lombok.NoArgsConstructor; +import org.apache.commons.lang3.StringUtils; +import weaver.conn.RecordSet; +import weaver.file.ImageFileManager; +import weaver.general.Util; +import weaver.xiao.commons.config.dao.ConfigMappingCMD; +import weaver.xiao.commons.config.entity.*; +import weaver.xiao.commons.config.enumtype.GetValueTypeEnum; +import weaver.xiao.commons.config.enumtype.ParamTypeEnum; +import weaver.xiao.commons.config.interfacies.CusInterfaceGetValue; +import weaver.xiao.commons.config.interfacies.CusInterfaceListValue; +import weaver.xiao.commons.exception.ValueDealException; +import weaver.zwl.common.ToolUtil; + +import java.io.InputStream; +import java.lang.reflect.Constructor; +import java.lang.reflect.InvocationTargetException; +import java.security.SecureRandom; +import java.text.ParseException; +import java.text.SimpleDateFormat; +import java.util.*; +import java.util.regex.Matcher; +import java.util.regex.Pattern; +import java.util.stream.Collectors; + +/** + * @author XiaoBokang & aiyh + * @create 2021/12/29 10:10 + */ + +@Data +@AllArgsConstructor +@NoArgsConstructor +public class DealWithMapping extends ToolUtil { + + private final ConfigMappingCMD mappingCMD = new ConfigMappingCMD(); + private String mainTable; + private String forMatString; + public static final char SBC_SPACE = 12288; // 全角空格 12288 + public static final char DBC_SPACE = 32; // 半角空格 32 + // ASCII character 33-126 <-> unicode 65281-65374 + public static final char ASCII_START = 33; + public static final char ASCII_END = 126; + public static final char UNICODE_START = 65281; + public static final char UNICODE_END = 65374; + public static final char DBC_SBC_STEP = 65248; // + + private List fileNames = new ArrayList<>(); + private List fileInputStreams = new ArrayList<>(); + private List multipartFileList = new ArrayList<>(); + + + /** + *

将日期字符串转换为Date对象

+ * + * @param dateStr 日期字符串 + * @return 日期对象 + */ + public static Date parseDate(String dateStr) { + ThreadLocal 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) { + // TODO Auto-generated catch block + throw new ValueDealException("无法将" + dateStr + "转换为日期对象!", e); + } + } + + private static Map getMapMapping(RecordSet rs) { + Map map = new HashMap<>(); + String[] columnType = rs.getColumnTypeName(); + int colCounts; + colCounts = rs.getColCounts() == 0 ? columnType.length : rs.getColCounts(); + for (int i = 1; i <= colCounts; i++) { + String key; + String type = "varchar"; + if (columnType != null) { + if (columnType.length != colCounts) { + type = "varchar"; + } else { + type = columnType[i - 1]; + } + } + key = rs.getColumnName(i).toLowerCase(); + if ("int".equalsIgnoreCase(type) || "Integer".equalsIgnoreCase(type) + || "Long".equalsIgnoreCase(type) || "BIGINT".equalsIgnoreCase(type) + || "NUMBER".equalsIgnoreCase(type) || "INTEGER".equalsIgnoreCase(type) + || "TINYINT".equalsIgnoreCase(type) || "SMALLINT".equalsIgnoreCase(type)) { + map.put(key, rs.getInt(i) == -1 ? rs.getString(i) : rs.getInt(i)); + continue; + } + if ("FLOAT".equalsIgnoreCase(type)) { + map.put(key, rs.getFloat(i)); + continue; + } + if ("DATE".equalsIgnoreCase(type) || "TIMESTAMP".equalsIgnoreCase(type) + || "DATETIME".equalsIgnoreCase(type)) { + map.put(key, rs.getString(i)); + continue; + } + if ("DOUBLE".equalsIgnoreCase(type)) { + map.put(key, rs.getDouble(i)); + continue; + } + if ("DECIMAL".equalsIgnoreCase(type) || "NUMERIC".equalsIgnoreCase(type)) { + map.put(key, rs.getDouble(i)); + continue; + } + map.put(key, rs.getString(i)); + } + return map; + } + + /** + * 将配置参数通过唯一标识查询处理成树形结构 + * + * @param uniqueCode 唯一标识 + * @return + */ + public RequestMappingConfig treeDealWithUniqueCode(String uniqueCode) { + this.writeDebuggerLog("============== 根据uniqueCode查询请求配置树形列表 treeDealWith begin ================="); + RequestMappingConfig tempConfig = mappingCMD.selectByUniqueCode(uniqueCode); + return this.dealWith(tempConfig); + } + + /** + * 处理成树形结构 + * + * @param tempConfig 配置列表 + * @return + */ + public RequestMappingConfig dealWith(RequestMappingConfig tempConfig) { + this.writeDebuggerLog("查询到的请求配置列表 query RequestMappingConfig list >>>" + JSON.toJSONString(tempConfig)); + List mappingDetails = tempConfig.getConfigDetail(); + List subMappingDetailList = new ArrayList<>(); + // 过滤出指定节点的子节点,并返回除去子节点之外的节点列表 + List collect = this.filterList(mappingDetails, subMappingDetailList, "rootNode"); + // 将数据库查询出来的信息赋值给要返回的配置信息树 + RequestMappingConfig requestMappingConfig = new RequestMappingConfig(); + requestMappingConfig.setRequestUrl(tempConfig.getRequestUrl()); + requestMappingConfig.setWorkflow(tempConfig.getWorkflow()); + requestMappingConfig.setResponseMappingList(tempConfig.getResponseMappingList()); + List mappingDetailList = new ArrayList<>(); + // 循环判断根节点 + for (MappingDetail mappingDetail : collect) { + String paramType = mappingDetail.getParamType(); + ParamTypeEnum anEnum = ParamTypeEnum.getEnum(paramType); + if (ParamTypeEnum.OBJECT == anEnum || ParamTypeEnum.LIST == anEnum) { + List childList = new ArrayList<>(); + mappingDetail.setChildList(childList); + this.getChildList(mappingDetail, mappingDetails, childList); + } + mappingDetailList.add(mappingDetail); + } + requestMappingConfig.setConfigDetail(mappingDetailList); + this.writeDebuggerLog("通过处理后得到的树形参数列表 deal with tree >>>" + JSON.toJSONString(requestMappingConfig)); + return requestMappingConfig; + } + + /** + * 通过递归的方式设置子节点信息 + * + * @param mappingDetail 当前节点 + * @param mappingDetailList 所有节点 + * @param childList 子节点 + */ + private void getChildList(MappingDetail mappingDetail, List mappingDetailList, List childList) { + String paramName = mappingDetail.getParamName(); + String paramType = mappingDetail.getParamType(); + if ("5".equals(paramType) || "6".equals(paramType)) { + List list = new ArrayList<>(); + mappingDetail.setChildList(list); + List subMappingDetailList = new ArrayList<>(); + List collect = this.filterList(mappingDetailList, subMappingDetailList, paramName); + for (MappingDetail detail : collect) { + this.getChildList(detail, subMappingDetailList, list); + } + } + childList.add(mappingDetail); + } + + /** + * 过滤list集合信息 + * + * @param mappingDetailList 原始集合 + * @param subMappingDetailList 过滤后集合 + * @param paramName 过滤信息 + * @return + */ + private List filterList(List mappingDetailList, List subMappingDetailList, String paramName) { + List tempList = new ArrayList<>(); + for (MappingDetail mappingDetail : mappingDetailList) { + String belongTo = mappingDetail.getBelongTo(); + if (paramName.equals(belongTo)) { + tempList.add(mappingDetail); + } else { + subMappingDetailList.add(mappingDetail); + } + } + return tempList; + } + + /** + * 解析请求参数配置树,转换成请求参数 + * + * @param recordSet 主表数据结果集 + * @param requestMappingConfig 配置树 + * @return + */ + public Map getRequestParam(RecordSet recordSet, RequestMappingConfig requestMappingConfig) { + this.multipartFileList.clear(); + this.fileNames.clear(); + Map requestParam = new HashMap<>(); + List configDetail = requestMappingConfig.getConfigDetail(); + Map mainMap = getMapMapping(recordSet); + this.objValueDeal(mainMap, null, configDetail, requestParam); + return requestParam; + } + + /** + * 解析请求参数配置树,转换成请求参数 + * + * @param recordSet 主表数据结果集 + * @param requestMappingConfig 配置树 + * @return + */ + public List getRequestListParam(RecordSet recordSet, RequestMappingConfig requestMappingConfig) { + this.multipartFileList.clear(); + this.fileInputStreams.clear(); + this.fileNames.clear(); + Map requestParam = new HashMap<>(); + List configDetail = requestMappingConfig.getConfigDetail(); + Map mainMap = getMapMapping(recordSet); + this.objValueDeal(mainMap, null, configDetail, requestParam); + List rootList = (List) requestParam.get("rootList"); + return rootList; + } + + /** + * 解析请求参数配置树,转换成请求参数 + * + * @param recordSet 主表数据结果集 + * @param detailRecordSet 明细表数据集 + * @param requestMappingConfig 配置树 + * @return + */ + public List> getRequestParams(RecordSet recordSet, RecordSet detailRecordSet, RequestMappingConfig requestMappingConfig) { + this.multipartFileList.clear(); + this.fileInputStreams.clear(); + this.fileNames.clear(); + List> list = new ArrayList<>(); + while (detailRecordSet.next()) { + Map requestParam = new HashMap<>(); + List configDetail = requestMappingConfig.getConfigDetail(); + Map mainMap = getMapMapping(recordSet); + Map detailMap = getMapMapping(detailRecordSet); + this.objValueDeal(mainMap, detailMap, configDetail, requestParam); + list.add(requestParam); + } + return list; + } + + /** + * 对象类型处理 + * + * @param mainMap 主表数据结果集 + * @param detailMap 明细数据结果集 + * @param configDetail 配置列表集合 + * @param requestParam 节点参数 + */ + private void objValueDeal(Map mainMap, Map detailMap, List configDetail, Map requestParam) { + for (MappingDetail mappingDetail : configDetail) { + String paramType = mappingDetail.getParamType(); + ParamTypeEnum anEnum = ParamTypeEnum.getEnum(paramType); + String paramName = mappingDetail.getParamName(); + // 5为对象类型 + if (ParamTypeEnum.OBJECT == anEnum) { + List childList = mappingDetail.getChildList(); + Map map = new HashMap<>(); + requestParam.put(paramName, map); + this.objValueDeal(mainMap, detailMap, childList, map); + } + // 6为List类型 + else if (ParamTypeEnum.LIST == anEnum) { + String childType = mappingDetail.getChildType(); + List childList = mappingDetail.getChildList(); + List list = new ArrayList<>(); + requestParam.put(paramName, list); + this.listValueDeal(mainMap, childList, list, mappingDetail); + List tempList = new ArrayList(); + for (Object o : list) { + if (o instanceof Map) { +// map处理 key->1的类型 + Map mapItem = (Map) o; + Map> tempMap = new HashMap<>(8); + for (Map.Entry entry : mapItem.entrySet()) { + String key = entry.getKey(); + String pattern = "(?\\S+)->(\\[(?[0-9]+)])"; + Pattern compile = Pattern.compile(pattern); + Matcher matcher = compile.matcher(key); + Object value = entry.getValue(); + if (matcher.find()) { + String tempKey = matcher.group("key"); + if (key.endsWith("_")) { + tempKey = tempKey + "_"; + } + ListMapIndexValue listMapIndexValue = new ListMapIndexValue(); + listMapIndexValue.setValue(value); + listMapIndexValue.setKey(tempKey); + String index = matcher.group("index"); + List listMapIndexValues = tempMap.get(index); + if (null == listMapIndexValues) { + listMapIndexValues = new ArrayList<>(); + } + listMapIndexValues.add(listMapIndexValue); + tempMap.put(index, listMapIndexValues); + } else { + ListMapIndexValue listMapIndexValue = new ListMapIndexValue(); + listMapIndexValue.setValue(value); + listMapIndexValue.setKey(key); + List listMapIndexValues = tempMap.get("default"); + if (null == listMapIndexValues) { + listMapIndexValues = new ArrayList<>(); + } + listMapIndexValues.add(listMapIndexValue); + tempMap.put("default", listMapIndexValues); + } + } + for (Map.Entry> entrty : tempMap.entrySet()) { + Map map = new HashMap<>(); + List valueList = entrty.getValue(); + for (ListMapIndexValue listMapIndexValue : valueList) { + map.put(listMapIndexValue.getKey(), listMapIndexValue.getValue()); + } + tempList.add(map); + } + } + } +// tempList.addAll(list); + requestParam.put(paramName, tempList); +// if (!tempList.isEmpty()) { +// requestParam.put(paramName, tempList); +// } + } else { + Object value = this.normalValueDeal(mainMap, detailMap, mappingDetail); + if (!Objects.isNull(value)) { + requestParam.put(paramName, value); + } + } + } + } + + /** + * 普通类型处理 + * + * @param mainMap 主表数据结果集 + * @param detailMap 明细数据结果集 + * @param mappingDetail 配置节点信息 + * @return + */ + private Object normalValueDeal(Map mainMap, Map detailMap, MappingDetail mappingDetail) { + + String paramType = mappingDetail.getParamType(); + ParamTypeEnum typeEnum = ParamTypeEnum.getEnum(paramType); + String getValueType = mappingDetail.getGetValueType(); + GetValueTypeEnum getValueTypeEnum = GetValueTypeEnum.getEnum(getValueType); + String valueContext = mappingDetail.getValueContext(); + String childSource = mappingDetail.getDataSource(); + String paramName = mappingDetail.getParamName(); + Object value = ""; + switch (getValueTypeEnum) { + // 流程字段 + case WORKFLOW_FIELD: { + FieldMessage fieldMassage = mappingDetail.getFieldMassage(); + String fieldName = fieldMassage.getFieldName(); + if ("1".equals(childSource)) { + value = Util.null2String(detailMap.get(fieldName)); + } else { + value = Util.null2String(mainMap.get(fieldName)); + } + } + break; + // 默认值 + case DEFAULT_VALUE: { + value = valueContext; + } + break; + // 当前时间 + case CURRENT_TIME: { + value = new Date(); + } + break; + // 自定义sql查询 + case CUS_SQL: { + FieldMessage fieldMassage = mappingDetail.getFieldMassage(); + String tempValue = ""; + if (fieldMassage != null) { + String fieldName = fieldMassage.getFieldName(); + if ("1".equals(childSource)) { + tempValue = Util.null2String(detailMap.get(fieldName)); + } else { + tempValue = Util.null2String(mainMap.get(fieldName)); + } + } + String requestId = Util.null2String(mainMap.get("requestid")); + tempValue = "'" + tempValue + "'"; + value = this.getValueByChangeRule(valueContext, tempValue, requestId); + } + break; + // requestId + case REQUEST_ID: { + value = Util.null2String(mainMap.get("requestid")); + } + break; + // 数据id + case MAIN_DATA_ID: { + if ("1".equals(childSource)) { + value = Util.null2String(detailMap.get("id")); + } else { + value = Util.null2String(mainMap.get("id")); + } +// value = Util.null2String(main.getString("id")); + } + break; + // 随机数 + case RANDOM: { + int bit = Util.getIntValue(valueContext, 10); + value = this.getGUID(bit); + } + break; + // 附件 + case ATTACHMENT: { + /*int imageFileId = Util.getIntValue(String.valueOf(value)); + InputStream inputStream = ImageFileManager.getInputStreamById(imageFileId); + String fileName = this.getFileNameById(imageFileId); + fileInputStreams.add(inputStream); + fileNames.add(fileName);*/ + // TODO 附件重新优化 + FieldMessage fieldMassage = mappingDetail.getFieldMassage(); + String fieldName = fieldMassage.getFieldName(); + if ("1".equals(childSource)) { + value = Util.null2String(detailMap.get(fieldName)); + } else { + value = Util.null2String(mainMap.get(fieldName)); + } + String fileIds = Util.null2String(value); + if ("".equals(fileIds)) { + throw new NullPointerException("附件字段不存在值!请检查数据表或配置表数据类型是否正确!"); + } + List docImageFiles = mappingCMD.selectDocImageFileList(fileIds); + for (DocImageFile docImageFile : docImageFiles) { + MultipartFile multipartFile = new MultipartFile(); + InputStream FileInputStream = ImageFileManager.getInputStreamById(docImageFile.getImageFileId()); + multipartFile.setFileKey(paramName); + multipartFile.setStream(FileInputStream); + multipartFile.setFileName(docImageFile.getImageFileName()); + multipartFile.setFileSize(docImageFile.getFileSize() / 1024); + multipartFileList.add(multipartFile); + } + return null; + + } +// 自定义接口 + case CUS_INTERFACE: { + if (null == valueContext || valueContext.length() == 0) { + } else { + Map pathParamMap = new HashMap<>(8); + CusInterfaceGetValue o = getCusInterfaceObj(valueContext, CusInterfaceGetValue.class, pathParamMap); + FieldMessage fieldMassage = mappingDetail.getFieldMassage(); + if (null != fieldMassage && !StringUtils.isEmpty(fieldMassage.getFieldName())) { + String fieldName = fieldMassage.getFieldName(); + if ("1".equals(childSource)) { + value = Util.null2String(detailMap.get(fieldName)); + } else { + value = Util.null2String(mainMap.get(fieldName)); + } + } + value = o.execute(mainMap, detailMap, String.valueOf(value == null ? "" : value), pathParamMap); + } + } + break; + case CUS_FIELD: { + value = detailMap.get(valueContext.trim()); + } + break; + default: + throw new ValueDealException("不支持的取值方式"); + } + + switch (typeEnum) { + // String类型 + case STRING: { + if (null == value || Strings.isNullOrEmpty(String.valueOf(value))) { + value = ""; + break; + } + value = Util.null2String(String.valueOf(value)); + } + break; + // int类型 + case INT: { + if (null == value || Strings.isNullOrEmpty(String.valueOf(value))) { + value = -1; + break; + } + value = Util.getIntValue(String.valueOf(value)); + } + break; + // double类型 + case DOUBLE: { + if (null == value || Strings.isNullOrEmpty(String.valueOf(value))) { + value = 0.00; + break; + } + value = Util.getDoubleValue(String.valueOf(value)); + } + break; + // 日期类型 + case DATE: { + if (null == value || Strings.isNullOrEmpty(String.valueOf(value))) { + value = ""; + break; + } + try { + Date date = value instanceof Date ? (Date) value : parseDate(String.valueOf(value)); + value = this.diyDateFortMat(date, "yyyy-MM-dd"); + } catch (Exception e) { + this.writeDebuggerLog("时间处理异常:" + e); + throw new ValueDealException("时间处理异常:参数>>" + paramName); + } + + } + break; + // 时间日期类型 + case DATE_TIME: { + if (null == value || Strings.isNullOrEmpty(String.valueOf(value))) { + value = ""; + break; + } + try { + Date date = value instanceof Date ? (Date) value : parseDate(String.valueOf(value)); + value = this.diyDateFortMat(date, "yyyy-MM-dd HH:mm:ss"); + } catch (Exception e) { + this.writeDebuggerLog("时间处理异常:" + e); + throw new ValueDealException("时间处理异常:参数>>" + paramName + " 异常信息:" + e); + } + } + break; + // 自定义时间格式化类型 + case CUS_DATE_STR: { + if (null == value || Strings.isNullOrEmpty(String.valueOf(value))) { + value = ""; + break; + } + try { + forMatString = valueContext; + Date date = value instanceof Date ? (Date) value : parseDate(String.valueOf(value)); + value = this.diyDateFortMat(date, forMatString); + } catch (Exception e) { + this.writeDebuggerLog("时间处理异常:" + e); + throw new ValueDealException("时间处理异常:参数>>" + paramName + " 异常信息:" + e.getMessage()); + } + } + break; + // 时间戳类型 + case TIME_STAMP: { + if (null == value || Strings.isNullOrEmpty(String.valueOf(value))) { + value = ""; + break; + } + try { + Date date = value instanceof Date ? (Date) value : parseDate(String.valueOf(value)); + value = date.getTime(); + } catch (Exception e) { + this.writeDebuggerLog("时间处理异常:" + e); + throw new ValueDealException("时间处理异常:参数>>" + paramName + " 异常信息:" + e.getMessage()); + } + } + break; + case Boolean: { + if (null == value || Strings.isNullOrEmpty(String.valueOf(value))) { + value = false; + break; + } + value = Boolean.valueOf(String.valueOf(value)); + } + break; + default: + return value; + } + + return value; + } + + /** + * list类型处理 + * + * @param mainMap 主表数据集 + * @param childList 子节点配置列表 + * @param list 子节点参数 + * @param detail 当前节点 + */ + private void listValueDeal(Map mainMap, List childList, List list, MappingDetail detail) throws ValueDealException { + String childSource = detail.getDataSource(); + String childType = detail.getChildType(); + if ("1".equals(childSource)) { + int mainId = Util.getIntValue(Util.null2String(mainMap.get("id"))); + int detailId = Util.getIntValue(detail.getDetailId()); + String detailTableName = mainTable + "_dt" + detailId; + String querySql = "select * from " + detailTableName + " where mainid = ?"; + RecordSet recordSetDetail = new RecordSet(); + recordSetDetail.executeQuery(querySql, mainId); + while (recordSetDetail.next()) { + Map detailMap = getMapMapping(recordSetDetail); + if ("0".equals(childType)) { + Map item = new HashMap<>(); + list.add(item); + this.objValueDeal(mainMap, detailMap, childList, item); + } else { + for (MappingDetail mappingDetail : childList) { + Object o = this.normalValueDeal(mainMap, detailMap, mappingDetail); + list.add(o); + } + } + } + } else if ("0".equals(childSource)) { + if ("0".equals(childType)) { + Map item = new HashMap<>(); + list.add(item); + this.objValueDeal(mainMap, null, childList, item); + } else { + for (MappingDetail mappingDetail : childList) { + Object o = this.normalValueDeal(mainMap, null, mappingDetail); + list.add(o); + } + } +// for (MappingDetail mappingDetail : childList) { +// Object o = this.normalValueDeal(recordSet, null, mappingDetail); +// list.add(o); +// } + } else if ("2".equals(childSource)) { + // 自定义接口 + Map pathParamMap = new HashMap<>(8); + CusInterfaceListValue cusInterfaceObj = getCusInterfaceObj(detail.getDetailId(), CusInterfaceListValue.class, pathParamMap); + List resultList = cusInterfaceObj.execute(pathParamMap, mainMap, mainTable); + if (null == resultList || resultList.isEmpty()) { + return; + } + if ("0".equals(childType)) { + + // 对象类型 + for (Object o : resultList) { + Map item = new HashMap<>(); + list.add(item); + this.objValueDeal(mainMap, (Map) o, childList, item); + } + } else { + // 普通数据类型 + for (Object o : resultList) { + for (MappingDetail mappingDetail : childList) { + if (o instanceof Map) { + Object value = this.normalValueDeal(mainMap, (Map) o, mappingDetail); + list.add(value); + } else { + list.add(o); + } + } + } + } + } + } + + /** + * 自定义时间格式化 + * + * @param date 日期 + * @param tempStr 格式化字符串 + * @return + */ + private String diyDateFortMat(Date date, String tempStr) { + SimpleDateFormat simpleDateFormat = new SimpleDateFormat(tempStr); + return simpleDateFormat.format(date); + } + + private String getGUID(int bit) { + + StringBuilder uid = new StringBuilder(); + + // 产生16位的强随机数 + + Random rd = new SecureRandom(); + + for (int i = 0; i < bit; i++) { + + // 产生0-2的3位随机数 + int type = rd.nextInt(3); + + switch (type) { + case 0: + // 0-9的随机数 + uid.append(rd.nextInt(10)); + break; + case 1: + // ASCII在65-90之间为大写,获取大写随机 + uid.append((char) (rd.nextInt(25) + 65)); + break; + case 2: + // ASCII在97-122之间为小写,获取小写随机 + uid.append((char) (rd.nextInt(25) + 97)); + break; + default: + break; + } + } + return uid.toString(); + } + + /** + * 通过文件id获取文件名 + * + * @param fileId 文件id + * @return + */ + public String getFileNameById(int fileId) { + String fileName = ""; + String querySql = "select filename from docimagefile where imgagefileid = ?"; + RecordSet recordSet = new RecordSet(); + recordSet.executeQuery(querySql, fileId); + if (recordSet.next()) { + fileName = recordSet.getString("filename"); + } + return fileName; + } + + /** + * 全角转半角 + * + * @param src 全角字符 + * @return 半角字符 + */ + public static char sbc2dbc(char src) { + if (src == SBC_SPACE) { + return DBC_SPACE; + } + + if (src >= UNICODE_START && src <= UNICODE_END) { + return (char) (src - DBC_SBC_STEP); + } + + return src; + } + + /** + * 全角转半角 + * + * @param src 全角字符串 + * @return DBC case + */ + public static String sbc2dbcCase(String src) { + if (src == null) { + return null; + } + char[] c = src.toCharArray(); + for (int i = 0; i < c.length; i++) { + c[i] = sbc2dbc(c[i]); + } + return new String(c); + } + + public T getCusInterfaceObj(String path, Class clazz, Map pathParamMap) { + path = sbc2dbcCase(path); + String[] split = path.split("\\?"); + String classPath = split[0]; + String paramStr = ""; + if (split.length > 1) { + paramStr = Arrays.stream(split).skip(1).collect(Collectors.joining("")); + } +/* 获取?后的参数:"weaver.aiyh_jitu.pushdata.service.toones.GetRequestValueCusGetValueImpl?" + + "requestType=get&apiOnlyMark=getAssign&valueKey=data&assign=#{main.zd2}&" + + "#processorClass=weaver.aiyh_jitu.pushdata.service.toones.GetAssignProcessorProcessorImpl" + + "&afterProcessor.hrmId=#{main.zd2}&beforeProcessor.hrmId=#{main.zd2}&高=udh高殿下g" + + "&assignValue=#sql{select workcode from hrmresource where id = #{main.zd1} and test = #{h-hah} and a in (${hrmids})}&hah=haode"; + 最终获取到的map,如下 + key:requestType + value:get + key:apiOnlyMark + value:getAssign + key:valueKey + value:data + key:assign + value:#{main.zd2} + key:#processorClass + value:weaver.aiyh_jitu.pushdata.service.toones.GetAssignProcessorProcessorImpl + key:afterProcessor.hrmId + value:#{main.zd2} + key:beforeProcessor.hrmId + value:#{main.zd2} + key:高 + value:udh高殿下g + key:assignValue + value:#sql{select workcode from hrmresource where id = #{main.zd1} and test = #{h-hah} and a in (${hrmids})} + key:hah + value:haode*/ +// 最终通过反射调用weaver.aiyh_jitu.pushdata.service.GetAssignProcessorProcessorImpl类,将参数传递给这个类, 使用``包裹的字符串会被解析为一个字符串 + String pattern = "&?(?([#.\\w\\u4E00-\\u9FA5]+))=" + + "(?((`([():/\\-&$#={ }.\\w\\u4E00-\\u9FA5?]*)`)|" + + "((#(\\{|sql\\{))?([():/\\-$#={ }.\\w\\u4E00-\\u9FA5?]+)?}?)))&?"; + Pattern compile = Pattern.compile(pattern); + Matcher matcher = compile.matcher(paramStr); + while (matcher.find()) { + String key = matcher.group("key"); + String paramValue = matcher.group("value"); + if (paramValue != null && paramValue.startsWith("`") && paramValue.endsWith("`")) { + paramValue = paramValue.substring(1, paramValue.length() - 1); + } + pathParamMap.put(key, paramValue); + } + Class aClass; + try { + aClass = Class.forName(classPath); + } catch (ClassNotFoundException e) { + throw new IllegalArgumentException("未能找到自定义接口:" + classPath); + } + if (!clazz.isAssignableFrom(aClass)) { + throw new IllegalArgumentException("自定义接口:" + classPath + " 不是" + + clazz.getName() + "的子类或实现类!"); + } + Constructor constructor; + try { + constructor = aClass.getConstructor(); + } catch (NoSuchMethodException e) { + throw new IllegalArgumentException(classPath + "没有空参构造方法,无法获取构造方法对象!"); + } + T o; + try { + o = (T) constructor.newInstance(); + } catch (InstantiationException | IllegalAccessException | InvocationTargetException e) { + throw new IllegalArgumentException("无法构造" + classPath + "对象!"); + } + return o; + } + +} diff --git a/src/main/java/weaver/chaoyang/he/xiao/commons/exception/RequestException.java b/src/main/java/weaver/chaoyang/he/xiao/commons/exception/RequestException.java new file mode 100644 index 0000000..3bef02c --- /dev/null +++ b/src/main/java/weaver/chaoyang/he/xiao/commons/exception/RequestException.java @@ -0,0 +1,21 @@ +package weaver.chaoyang.he.xiao.commons.exception; + +/** + * @author XiaoBokang + * @create 2022/1/12 11:06 + */ + +public class RequestException extends RuntimeException{ + public RequestException(String message){ + super(message); + } + + public RequestException(String message, Throwable cause) { + super(message, cause); + } + + @Override + public synchronized Throwable fillInStackTrace() { + return super.fillInStackTrace(); + } +} diff --git a/src/main/java/weaver/chaoyang/he/xiao/commons/exception/ValueDealException.java b/src/main/java/weaver/chaoyang/he/xiao/commons/exception/ValueDealException.java new file mode 100644 index 0000000..11d8d52 --- /dev/null +++ b/src/main/java/weaver/chaoyang/he/xiao/commons/exception/ValueDealException.java @@ -0,0 +1,22 @@ +package weaver.chaoyang.he.xiao.commons.exception; + +/** + * @author XiaoBokang + * @create 2022/1/4 9:50 + */ + +public class ValueDealException extends RuntimeException{ + + public ValueDealException(String message){ + super(message); + } + + public ValueDealException(String message, Throwable cause) { + super(message, cause); + } + + @Override + public synchronized Throwable fillInStackTrace() { + return super.fillInStackTrace(); + } +} diff --git a/src/main/java/weaver/chaoyang/he/xiao/commons/utils/JsonResult.java b/src/main/java/weaver/chaoyang/he/xiao/commons/utils/JsonResult.java new file mode 100644 index 0000000..f8c669c --- /dev/null +++ b/src/main/java/weaver/chaoyang/he/xiao/commons/utils/JsonResult.java @@ -0,0 +1,70 @@ +package weaver.chaoyang.he.xiao.commons.utils; + +import com.alibaba.fastjson.JSONObject; + + +/** + * @author XiaoBokang + * @create 2021/9/9 19:33 + */ + +public class JsonResult { + + private Integer code; + private String message; + private Object Data; + + public JsonResult(Integer code, String message, Object data) { + this.code = code; + this.message = message; + Data = data; + } + + public static String success(String message){ + return JSONObject.toJSONString(new JsonResult(200,message,null)); + } + public static String success(){ + return JSONObject.toJSONString(new JsonResult(200,"success",null)); + } + public static String successData(String message,Object data){ + return JSONObject.toJSONString(new JsonResult(200,message,data)); + } + public static String successData(Object data){ + return JSONObject.toJSONString(new JsonResult(200,"success",data)); + } + + public static String error(int code,String message){ + return JSONObject.toJSONString(new JsonResult(code,message,null)); + } + public static String error(String message){ + return JSONObject.toJSONString(new JsonResult(500,message,null)); + } + public static String error(){ + return JSONObject.toJSONString(new JsonResult(500,"fail",null)); + } + + + public Integer getCode() { + return code; + } + + public void setCode(Integer code) { + this.code = code; + } + + public String getMessage() { + return message; + } + + public void setMessage(String message) { + this.message = message; + } + + public Object getData() { + return Data; + } + + public void setData(Object data) { + Data = data; + } +} diff --git a/src/main/java/weaver/chaoyang/he/xiao/commons/utils/LogUtil.java b/src/main/java/weaver/chaoyang/he/xiao/commons/utils/LogUtil.java new file mode 100644 index 0000000..ae57e78 --- /dev/null +++ b/src/main/java/weaver/chaoyang/he/xiao/commons/utils/LogUtil.java @@ -0,0 +1,73 @@ +package weaver.chaoyang.he.xiao.commons.utils; + +import org.apache.log4j.*; + +import java.io.File; +import java.io.PrintWriter; +import java.io.StringWriter; + +/** + * @author XiaoBokang + * @create 2022/3/3 14:16 + */ + +public class LogUtil { + + private static volatile Logger log = null; + + public static Logger getLogger(){ + return LogUtil.getLogger(weaver.general.GCONST.getLogPath() + "cus" + File.separator + "util_cus" + File.separator + "cus.log"); + } + + /** + * 获取日志对象 + * @return 日志对象 + */ + public static Logger getLogger(String file) { + if (log == null) { + synchronized (LogUtil.class) { + if (log == null) { + DailyRollingFileAppender appender = new DailyRollingFileAppender(); + log = Logger.getLogger("xbk_cus"); + appender.setName("xbk_cus"); + appender.setEncoding("UTF-8"); + appender.setDatePattern("'_'yyyyMMdd'.log'"); + appender.setFile(file); + 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.setAppend(true); + appender.activateOptions(); + log.addAppender(appender); + boolean enableDebug = true; + if (!enableDebug) { + log.setLevel(Level.INFO); + } + } + } + } + return log; + } + + public static Logger getSqlLogger(){ + return LogUtil.getLogger(weaver.general.GCONST.getLogPath() + "cus" + File.separator + "sql" + File.separator + "cussql.log"); + } + + + /** + * 获取堆栈中的异常信息 + * @param throwable 异常 + * @return + */ + public static String getExceptionStr(Throwable throwable){ + StringWriter stringWriter = new StringWriter(); + throwable.printStackTrace(new PrintWriter(stringWriter,true)); + String s = stringWriter.getBuffer().toString(); + try{ + stringWriter.close(); + }catch (Exception ignored){ + ignored.printStackTrace(); + } + return s; + } + +} diff --git a/src/main/java/weaver/chaoyang/he/xiao/commons/utils/PreMap.java b/src/main/java/weaver/chaoyang/he/xiao/commons/utils/PreMap.java new file mode 100644 index 0000000..8419125 --- /dev/null +++ b/src/main/java/weaver/chaoyang/he/xiao/commons/utils/PreMap.java @@ -0,0 +1,26 @@ +package weaver.chaoyang.he.xiao.commons.utils; + +import java.util.HashMap; +import java.util.Map; + +/** + * @author XiaoBokang + * @create 2021/8/20 14:01 + */ + +public class PreMap extends HashMap implements Map { + + public PreMap(){ + super(); + } + + public static PreMap create(){ + return new PreMap(); + } + + @Override + public PreMap put(String key, Object value){ + super.put(key,value); + return this; + } +} diff --git a/src/main/java/weaver/chaoyang/he/xiao/commons/utils/PropUtil.java b/src/main/java/weaver/chaoyang/he/xiao/commons/utils/PropUtil.java new file mode 100644 index 0000000..7395a36 --- /dev/null +++ b/src/main/java/weaver/chaoyang/he/xiao/commons/utils/PropUtil.java @@ -0,0 +1,57 @@ +package weaver.chaoyang.he.xiao.commons.utils; + +import weaver.common.util.string.StringUtil; +import weaver.general.GCONST; + +import java.io.*; +import java.util.Enumeration; +import java.util.HashMap; +import java.util.Map; +import java.util.Properties; + +/** + * @author XiaoBokang + * @create 2022/3/10 11:13 + */ + +public class PropUtil { + /** + * 通过文件名获取到对应的配置文件map对象 + * @param fileName prop/文件夹下的文件名(不包含.properties) + * @return 配置文件对应的map对象 + */ + public static Map getProperties2Map(String fileName) { + String propertyPath = GCONST.getPropertyPath(); + if (StringUtil.isNullOrEmpty(fileName)) { + return null; + } + if (fileName.contains(".properties")) { + fileName = fileName.replace(".properties", ""); + } + String path = propertyPath + File.separator + fileName + ".properties"; + Properties prop = new Properties(); + Map map = new HashMap<>(); + InputStream inputStream = null; + try { + inputStream = new BufferedInputStream(new FileInputStream(path)); + prop.load(inputStream); + Enumeration enumeration = prop.propertyNames(); + while (enumeration.hasMoreElements()) { + String key = String.valueOf(enumeration.nextElement()); + map.put(key, prop.getProperty(key)); + } + } catch (IOException e) { + throw new RuntimeException("找不到文件:" + path); + } finally { + try { + if (inputStream != null) { + inputStream.close(); + } + } catch (IOException e) { + e.printStackTrace(); + } + } + return map; + } + +} diff --git a/src/main/java/weaver/chaoyang/he/xiao/commons/utils/RequestBaseInfo.java b/src/main/java/weaver/chaoyang/he/xiao/commons/utils/RequestBaseInfo.java new file mode 100644 index 0000000..d0361c2 --- /dev/null +++ b/src/main/java/weaver/chaoyang/he/xiao/commons/utils/RequestBaseInfo.java @@ -0,0 +1,59 @@ +package weaver.chaoyang.he.xiao.commons.utils; + +import lombok.Data; + +import java.io.InputStream; +import java.util.HashMap; +import java.util.Map; + +/** + * @author XiaoBokang + * @create 2021/8/23 16:34 + */ + +@Data +public class RequestBaseInfo{ + + private String type; + private String url; + private Object params; + private InputStream[] inputStreams; + private String[] fileNames; + private String fileField; + private Map headers; + + private static final Map HEADER_NORMAL = new HashMap<>(); + private static final Map PARAMS_NORMAL = new HashMap<>(); + + + public static RequestBaseInfo create(String type, String url){ + return create(type,url,HEADER_NORMAL,PARAMS_NORMAL); + } + + public static RequestBaseInfo create(String type, String url, Map headers){ + return create(type,url,headers,PARAMS_NORMAL); + } + + public static RequestBaseInfo create(String type, String url, Map headers, Object params){ + RequestBaseInfo requestInfo = new RequestBaseInfo(); + requestInfo.setType(type.toUpperCase()); + requestInfo.setUrl(url); + requestInfo.setParams(params); + requestInfo.setHeaders(headers); + return requestInfo; + } + + public static RequestBaseInfo createByFile(String type, String url, Map headers, Object params, InputStream[] inputStreams, String fileField, String[] fileNames){ + RequestBaseInfo requestInfo = new RequestBaseInfo(); + requestInfo.setType(type.toUpperCase()); + requestInfo.setUrl(url); + requestInfo.setParams(params); + requestInfo.setHeaders(headers); + requestInfo.setInputStreams(inputStreams); + requestInfo.setFileNames(fileNames); + requestInfo.setFileField(fileField); + return requestInfo; + } + + +} diff --git a/src/main/java/weaver/chaoyang/he/xiao/commons/utils/RequestUtil.java b/src/main/java/weaver/chaoyang/he/xiao/commons/utils/RequestUtil.java new file mode 100644 index 0000000..783b0b3 --- /dev/null +++ b/src/main/java/weaver/chaoyang/he/xiao/commons/utils/RequestUtil.java @@ -0,0 +1,166 @@ +package weaver.chaoyang.he.xiao.commons.utils; + +import com.alibaba.fastjson.JSON; +import com.fasterxml.jackson.databind.ObjectMapper; +import org.apache.http.HttpEntity; +import org.apache.http.client.methods.*; +import org.apache.http.entity.ContentType; +import org.apache.http.entity.StringEntity; +import org.apache.http.entity.mime.HttpMultipartMode; +import org.apache.http.entity.mime.MultipartEntityBuilder; +import org.apache.http.impl.client.DefaultHttpClient; +import org.apache.http.util.EntityUtils; +import weaver.xiao.commons.exception.RequestException; +import weaver.xiao.commons.utils.RequestBaseInfo; +import weaver.zwl.common.ToolUtil; +import weaver.wechat.request.HttpManager; + +import javax.ws.rs.core.MediaType; +import java.io.IOException; +import java.io.InputStream; +import java.io.PrintWriter; +import java.io.StringWriter; +import java.nio.charset.StandardCharsets; +import java.util.Map; + + +/** + * @author XiaoBokang + * @create 2021/8/9 10:09 + */ + +public class RequestUtil { + + public static T apiRequest(RequestBaseInfo requestInfo, Class tClass){ + + Map headers = requestInfo.getHeaders(); + T result = null; + + switch(requestInfo.getType()){ + case "GET" :{ + String sendUrl = serializableUrl(requestInfo.getUrl(), (Map) requestInfo.getParams()); + HttpGet httpGet = new HttpGet(sendUrl); + headers.forEach(httpGet::setHeader); + result = apiSend(httpGet,tClass); + }break; + case "POST" :{ + HttpPost httpPost = new HttpPost(requestInfo.getUrl()); + headers.forEach(httpPost::setHeader); + httpPost.setEntity(new StringEntity(JSON.toJSONString(requestInfo.getParams()),"UTF-8")); + new ToolUtil().writeErrorLog("请求信息:url:"+requestInfo.getUrl()+" params:"+JSON.toJSONString(requestInfo.getParams())); + result = apiSend(httpPost,tClass);}break; + case "PUT" :{ + HttpPut httpPut = new HttpPut(requestInfo.getUrl()); + headers.forEach(httpPut::setHeader); + httpPut.setEntity(new StringEntity(JSON.toJSONString(requestInfo.getParams()),"UTF-8")); + result = apiSend(httpPut,tClass);}break; + } + + return result; + } + + public static T POSTBySerializableUrl(RequestBaseInfo requestInfo, Class tClass){ + T result = null; + Map headers = requestInfo.getHeaders(); + String url = serializableUrl(requestInfo.getUrl(), (Map) requestInfo.getParams()); + HttpPost httpPost = new HttpPost(url); + headers.forEach(httpPost::setHeader); + new ToolUtil().writeErrorLog("请求信息:url:"+requestInfo.getUrl()+" params:"+JSON.toJSONString(requestInfo.getParams())); + result = apiSend(httpPost,tClass); + return result; + } + + public static T apiUploadFileByInputStream(RequestBaseInfo requestInfo, Class tClass){ + Map params = (Map) requestInfo.getParams(); + HttpPost httpPost = new HttpPost(requestInfo.getUrl()); + requestInfo.getHeaders().forEach(httpPost::setHeader); + MultipartEntityBuilder builder = MultipartEntityBuilder.create(); + builder.setCharset(StandardCharsets.UTF_8); + builder.setMode(HttpMultipartMode.BROWSER_COMPATIBLE); + InputStream[] inputStreams = requestInfo.getInputStreams(); + String[] fileNames = requestInfo.getFileNames(); + for (int i = 0; i < inputStreams.length; i++) { + builder.addBinaryBody(requestInfo.getFileField(),inputStreams[i],ContentType.MULTIPART_FORM_DATA,fileNames[i]); + } + params.forEach((k,v)->{ + builder.addTextBody(k,JSON.toJSONString(v),ContentType.create(MediaType.TEXT_PLAIN,"UTF-8")); + }); + HttpEntity entity = builder.build(); + httpPost.setEntity(entity); + return apiSend(httpPost,tClass); + } + + public static T apiSend( + HttpUriRequest httpRequest, + Class resClass + ){ + DefaultHttpClient httpClient = HttpManager.getHttpClient(); + CloseableHttpResponse execute = null; + T res = null; + try { + new ToolUtil().writeDebuggerLog("开始发送请求:request start -----------------"); + execute = httpClient.execute(httpRequest); + if(execute.getStatusLine().getStatusCode() == 200){ + new ToolUtil().writeDebuggerLog("请求发送成功:request send success -----------------"); + HttpEntity entity = execute.getEntity(); + String response= EntityUtils.toString(entity,"utf-8"); +// ObjectMapper mapper = new ObjectMapper(); +// CollectionType listType = mapper.getTypeFactory().constructCollectionType(ArrayList.class, Map.class); +// List> list = mapper.readValue(response, listType); +// result.put("res",list); + if(resClass.equals(String.class)){ + return (T) response; + }else { + ObjectMapper objectMapper = new ObjectMapper(); + res = objectMapper.readValue(response, resClass); + } + }else { + HttpEntity entity = execute.getEntity(); + String response = EntityUtils.toString(entity,"utf-8"); + new ToolUtil().writeDebuggerLog("请求状态不为200,返回信息为:"+response); + throw new RequestException("请求状态异常:"+response); + } + } catch (IOException e) { + new ToolUtil().writeDebuggerLog("请求发生异常 request error>>>"+e); + try { + if(execute != null) { + execute.close(); + } + } catch (IOException ioException) { + ioException.printStackTrace(); + } + e.printStackTrace(); + throw new RequestException("请求调用异常:"+e); + } + return res; + } + + public static String serializableUrl(String url,Map params){ + if(params == null || params.isEmpty()){ + return url; + } + url += "?"; + for (Map.Entry entry: params.entrySet()){ + url += entry.getKey() + "=" + entry.getValue() + "&"; + } + return url.substring(0,url.length()-1); + } + + /** + * 获取堆栈中的异常信息 + * @param throwable 异常 + * @return + */ + public static String getExceptionStr(Throwable throwable){ + StringWriter stringWriter = new StringWriter(); + throwable.printStackTrace(new PrintWriter(stringWriter,true)); + String s = stringWriter.getBuffer().toString(); + try{ + stringWriter.close(); + }catch (Exception ignored){ + ignored.printStackTrace(); + } + return s; + } + +} diff --git a/src/main/java/weaver/chaoyang/he/xiao/commons/utils/SqlUtil.java b/src/main/java/weaver/chaoyang/he/xiao/commons/utils/SqlUtil.java new file mode 100644 index 0000000..d016240 --- /dev/null +++ b/src/main/java/weaver/chaoyang/he/xiao/commons/utils/SqlUtil.java @@ -0,0 +1,261 @@ +package weaver.chaoyang.he.xiao.commons.utils; + +import org.apache.log4j.Logger; +import weaver.conn.RecordSet; +import weaver.formmode.data.ModeDataIdUpdate; +import weaver.formmode.setup.ModeRightInfo; +import weaver.general.TimeUtil; +import weaver.general.Util; +import weaver.xiao.commons.utils.LogUtil; +import weaver.xiao.commons.utils.annotation.SqlFieldMapping; + + +import java.lang.reflect.Field; +import java.util.*; + +/** + * @author XiaoBokang + * @create 2021/12/7 14:19 + */ + +public class SqlUtil { + + private final Logger logger = LogUtil.getSqlLogger(); + ModeDataIdUpdate mdu = ModeDataIdUpdate.getInstance(); + ModeRightInfo mri = new ModeRightInfo(); + + /** + * 通过列名将数据库结果集转换成指定的实体类 + * @param recordSet 数据库结果集 + * @param tClass 实体类文件 + * @param 泛型 + * @return + */ + public T recordSetToEntityByEntity(RecordSet recordSet, Class tClass){ + T res = null; + try{ + String[] columnNames = recordSet.getColumnName(); + if(tClass.equals(Map.class)){ + Map tempRes = new HashMap<>(); + for (String columnName : columnNames) { + tempRes.put(columnName,recordSet.getString(columnName)); + } + res = (T) tempRes; + }else { + Field[] declaredFields = tClass.getDeclaredFields(); + res = tClass.newInstance(); + for (Field field : declaredFields) { + field.setAccessible(true); + SqlFieldMapping annotation = field.getAnnotation(SqlFieldMapping.class); + Class fieldType = field.getType(); + if(annotation != null){ + String value = annotation.value(); + int type = annotation.type(); + Object valueText = null; + switch (type){ + case 1:{ + String tempValue = Util.null2String(recordSet.getString(value)); + valueText = this.getFieldVal(fieldType,tempValue); + }break; + case 2:{ + valueText = this.getFieldVal(fieldType,value); + }break; + } + field.set(res,valueText); + } + } + } + }catch (Exception e){ + logger.info("转换实体类异常:"+e); + } + return res; + } + + /** + * 通过字段类型获取字段的值 + * @param fieldType 字段类型 + * @param tempValue 转换前的字符串值 + * @return + */ + public Object getFieldVal(Class fieldType,String tempValue){ + Object fieldVal = null; + if(fieldType.equals(int.class)){ + fieldVal = Util.getIntValue(tempValue); + }else if(fieldType.equals(String.class)){ + fieldVal = Util.null2String(tempValue); + }else if(fieldType.equals(boolean.class)){ + fieldVal = Boolean.parseBoolean(tempValue); + }else { + fieldVal = ""; + } + return fieldVal; + } + + /** + * 构建更新语句 + * @param tableName 表名 + * @param updateParam 更新参数 + * @param whereParam 条件参数 + * @return + */ + public boolean updateMode(String tableName, Map updateParam, Map whereParam) { + RecordSet recordSet = new RecordSet(); + List paramList = new ArrayList<>(); + String updateSql = buildUpdateSql(tableName, updateParam, whereParam, paramList); + logger.info("向表"+tableName+"更新数据>>>" + updateSql + " param:" + paramList); + boolean updateFlag = recordSet.executeUpdate(updateSql, paramList); + logger.info("更新标识:" + updateFlag); + return updateFlag; + } + + /** + * 构建更新sql语句,收集参数信息 + * @param tableName 表名 + * @param updateParam 更新参数 + * @param whereParam 条件参数 + * @param paramList 参数集合 + * @return + */ + public String buildUpdateSql(String tableName, Map updateParam, Map whereParam,List paramList){ + StringBuilder updateBuilder = new StringBuilder("update "); + updateBuilder.append(tableName).append(" set "); + Set> updateEntries = updateParam.entrySet(); + for (Map.Entry updateEntry : updateEntries) { + updateBuilder.append(updateEntry.getKey()) + .append(" = ?,"); + paramList.add(updateEntry.getValue()); + } + StringBuilder whereBuilder = new StringBuilder(); + Set> whereEntries = whereParam.entrySet(); + for (Map.Entry whereEntry : whereEntries) { + whereBuilder.append(" and ") + .append(whereEntry.getKey()) + .append(" = ? "); + paramList.add(whereEntry.getValue()); + } + String preStr = updateBuilder.substring(0, updateBuilder.length() - 1) + " "; + String fixStr = whereBuilder.toString(); + if(!"".equals(fixStr)){ + fixStr = fixStr.replaceFirst(" and "," where "); + } + return preStr + fixStr; + } + + /** + * 向表插入数据 + * @param tableName 表名 + * @param insertParam 插入参数 + * @return + */ + public boolean insertTable(String tableName, Map insertParam) { + RecordSet recordSet = new RecordSet(); + //构建新建sql语句,收集参数信息 + List paramList = new ArrayList<>(); + String insertSql = buildInsetSql(tableName, insertParam, paramList); + logger.info("向表"+tableName+"插入数据>>>" + insertSql + " param:" + paramList); + boolean flag = recordSet.executeUpdate(insertSql, paramList); + logger.info("插入标识:" + flag); + return flag; + } + + /** + * 构建新建sql语句,收集参数信息 + * @param tableName 表名 + * @param insertParam 插入参数 + * @param paramList 返回数据集合 + * @return + */ + public String buildInsetSql(String tableName, Map insertParam,List paramList){ + StringBuilder suffixBuilder = new StringBuilder(); + StringBuilder prefixBuilder = new StringBuilder(); + prefixBuilder.append("insert into ") + .append(tableName).append("("); + suffixBuilder.append(" values ("); + Set> entries = insertParam.entrySet(); + for (Map.Entry entry : entries) { + String key = entry.getKey(); + Object value = entry.getValue(); + prefixBuilder.append(key).append(","); + suffixBuilder.append("?,"); + paramList.add(value); + } + String suffixString = suffixBuilder.substring(0, suffixBuilder.length() - 1); + String prefixString = prefixBuilder.substring(0, prefixBuilder.length() - 1); + String insertSql = prefixString + ")" + suffixString+")"; + return insertSql; + } + + + /** + * 将接口调用信息插入至建模中 + * @param tableName 表名 + * @param param 插入信息 + * @param modeId 模块id + * @return + */ + public int insertToMode(String tableName,Map param,String modeId){ + logger.info("=====插入建模信息===="); + if(modeId == null || "".equals(modeId)) { + modeId = this.getModeIdByTableName(tableName); + } + logger.info("通过表名获取modeId ==>modeId"+modeId+" tableName==>"+tableName); + Map whereParam = new HashMap<>(); + int dataId = mdu.getModeDataNewId(tableName, Util.getIntValue(modeId,-1), 1, 0, TimeUtil.getCurrentDateString(), TimeUtil.getOnlyCurrentTimeString()); + whereParam.put("id",dataId); + boolean updateFlag = this.updateMode(tableName, param, whereParam); + if(updateFlag){ + mri.rebuildModeDataShareByEdit(1, Util.getIntValue(modeId,-1),dataId); + }else { + logger.info("更新失败,从表==>"+tableName+" 删除数据:"+dataId); + String deleteSql = "delete from "+tableName+" where id = ?"; + RecordSet deleteRecordSet = new RecordSet(); + deleteRecordSet.executeUpdate(deleteSql,dataId); + } + return dataId; + } + + /** + * 将接口调用信息插入至建模中不做权限重构 + * @param tableName 表名 + * @param param 插入信息 + * @param modeId 模块id + * @return + */ + public int insertToModeNoRight(String tableName,Map param,String modeId){ + logger.info("=====插入建模信息===="); + if(modeId == null || "".equals(modeId)) { + modeId = this.getModeIdByTableName(tableName); + } + logger.info("通过表名获取modeId ==>modeId"+modeId+" tableName==>"+tableName); + Map whereParam = new HashMap<>(); + int dataId = mdu.getModeDataNewId(tableName, Util.getIntValue(modeId,-1), 1, 0, TimeUtil.getCurrentDateString(), TimeUtil.getOnlyCurrentTimeString()); + whereParam.put("id",dataId); + boolean updateFlag = this.updateMode(tableName, param, whereParam); + if(updateFlag){ + return dataId; + }else { + logger.info("更新失败,从表==>"+tableName+" 删除数据:"+dataId); + String deleteSql = "delete from "+tableName+" where id = ?"; + RecordSet deleteRecordSet = new RecordSet(); + deleteRecordSet.executeUpdate(deleteSql,dataId); + } + return -1; + } + + /** + * 通过表名查询模块id + * @param tableName 表名 + * @return + */ + public String getModeIdByTableName(String tableName){ + String modeId = ""; + String querySql = "select id from modeinfo where formid = (select id from workflow_bill where tablename = ?)"; + RecordSet recordSet = new RecordSet(); + recordSet.executeQuery(querySql,tableName); + if(recordSet.next()){ + modeId = Util.null2String(recordSet.getString("id")); + } + return modeId; + } + +} diff --git a/src/main/java/weaver/chaoyang/he/xiao/commons/utils/annotation/SqlFieldMapping.java b/src/main/java/weaver/chaoyang/he/xiao/commons/utils/annotation/SqlFieldMapping.java new file mode 100644 index 0000000..8f40f62 --- /dev/null +++ b/src/main/java/weaver/chaoyang/he/xiao/commons/utils/annotation/SqlFieldMapping.java @@ -0,0 +1,21 @@ +package weaver.chaoyang.he.xiao.commons.utils.annotation; + +import java.lang.annotation.ElementType; +import java.lang.annotation.Retention; +import java.lang.annotation.RetentionPolicy; +import java.lang.annotation.Target; + +/** + * @author XiaoBokang + * @create 2022/5/10 18:22 + */ + +@Target(ElementType.FIELD) +@Retention(RetentionPolicy.RUNTIME) +public @interface SqlFieldMapping { + /** 字段所属 1:数据库值,2:默认值 */ + int type() default 1; + /** 数据库字段名或默认值 */ + String value(); + +} diff --git a/src/main/java/weaver/chaoyang/he/zwl/common/CusBaseAction.java b/src/main/java/weaver/chaoyang/he/zwl/common/CusBaseAction.java new file mode 100644 index 0000000..3001353 --- /dev/null +++ b/src/main/java/weaver/chaoyang/he/zwl/common/CusBaseAction.java @@ -0,0 +1,104 @@ +package weaver.chaoyang.he.zwl.common; + + +import weaver.common.StringUtil; +import weaver.conn.RecordSetTrans; +import weaver.general.Util; +import weaver.hrm.User; +import weaver.interfaces.workflow.action.Action; +import weaver.soa.workflow.request.RequestInfo; +import weaver.workflow.request.RequestManager; +import weaver.zwl.common.ToolUtil; + +/** + * 自定义Action实现类,添加通用参数 + * @author bleach + * @date 2019-10-09 + * @verion 1.0 + */ +public abstract class CusBaseAction extends ToolUtil implements Action { + //当前类名称 + private String className = this.getClass().getName(); + + + protected RequestInfo requestInfo;//流程请求信息实体类 + protected RecordSetTrans rsts = null;//流程操作事务数据集 + protected String tablename;//当前流程表单名称 + protected String requestId;//流程请求ID + protected String workflowId;//流程类型ID + protected User user = null;//当前用户 + protected int creater = -1;//流程创建人ID + protected RequestManager reqManager = null; + protected String[] baseArray = new String[5]; + protected int formid = -1; + protected String cusparam = ""; + + protected abstract String handle();//OrganizationAction 具体操作 + + /** + * 实现父类方法 + * + * @param requestInfo + * @return + */ + @Override + public String execute(RequestInfo requestInfo) { + this.requestInfo = requestInfo; + + this.rsts = requestInfo.getRsTrans(); + if (this.rsts == null) { + rsts = new RecordSetTrans(); + } + this.initParam(); + return handle(); + } + + /** + * 初始化常用参数 + */ + private void initParam() { + this.requestId = StringUtil.vString(requestInfo.getRequestid()); + this.workflowId = StringUtil.vString(requestInfo.getWorkflowid()); + this.reqManager = requestInfo.getRequestManager(); + this.user = reqManager.getUser(); + this.creater = reqManager.getCreater(); + + this.tablename = requestInfo.getRequestManager().getBillTableName(); + + this.formid = reqManager.getFormid(); + //通过系统请求管理类获取表单名称失败,再次查询 + if ("".equals(this.tablename)) { + tablename = getBillTableNameByWorkflowId(this.workflowId); + formid = Util.getIntValue(tablename.replace("formtable_main_", ""),0); + } + + //获取流程基础数据 + String select_base_sql = "select * from workflow_requestbase where requestid = ?"; + try { + if (rsts == null) { + rsts = new RecordSetTrans(); + } + + String request_name = ""; + String request_mark = ""; + + if (rsts.executeQuery(select_base_sql, requestId)) { + while (rsts.next()) { + request_name = Util.null2String(rsts.getString("requestname")); + request_mark = Util.null2String(rsts.getString("requestmark")); + } + } + + baseArray[0] = this.requestId; + baseArray[1] = request_name; + baseArray[2] = request_mark; + baseArray[3] = tablename; + + this.writeNewDebuggerLog(className, "main_requestname:[" + request_name + "],main_requestmark:[" + request_mark + "],workflowid:[" + workflowId + "],requestid:[" + requestId + "],tablename:[" + tablename + "],formid:[" + formid +"]"); + } catch (Exception e1) { + // TODO Auto-generated catch block + e1.printStackTrace(); + this.writeNewDebuggerLog(className, "get workflow dataset error:[" + e1.getMessage() + "/" + e1.toString() + "]"); + } + } +} diff --git a/src/main/java/weaver/chaoyang/he/zwl/common/ThreadPoolConfig.java b/src/main/java/weaver/chaoyang/he/zwl/common/ThreadPoolConfig.java new file mode 100644 index 0000000..05848e0 --- /dev/null +++ b/src/main/java/weaver/chaoyang/he/zwl/common/ThreadPoolConfig.java @@ -0,0 +1,36 @@ +package weaver.chaoyang.he.zwl.common; + +import com.google.common.util.concurrent.ThreadFactoryBuilder; + +import java.util.concurrent.*; + +/** + * 自定义线程池 + * 异步执行线程池 + */ +public class ThreadPoolConfig { + + private static volatile ExecutorService threadPool; + + /** + * 创建线程池实例 + * @return 返回一个异步执行 + */ + public static ExecutorService createThreadPoolInstance() { + if (threadPool == null) { + synchronized (ThreadPoolConfig.class) { + if (threadPool == null) { + ThreadFactory threadFactory = new ThreadFactoryBuilder().setNameFormat("thread-pool-cus-%d").build(); + threadPool = new ThreadPoolExecutor(25, + 50, + 60L, + TimeUnit.SECONDS, + new ArrayBlockingQueue<>(100), + threadFactory, + new ThreadPoolExecutor.AbortPolicy()); + } + } + } + return threadPool; + } +} diff --git a/src/main/java/weaver/chaoyang/he/zwl/common/ToolUtil.java b/src/main/java/weaver/chaoyang/he/zwl/common/ToolUtil.java new file mode 100644 index 0000000..9860a63 --- /dev/null +++ b/src/main/java/weaver/chaoyang/he/zwl/common/ToolUtil.java @@ -0,0 +1,411 @@ +package weaver.chaoyang.he.zwl.common; + +import weaver.conn.ConnStatementDataSource; +import weaver.conn.RecordSet; +import weaver.general.BaseBean; +import weaver.general.GCONST; +import weaver.general.TimeUtil; +import weaver.general.Util; +import weaver.zwl.common.logging.Logger; +import weaver.zwl.common.logging.LoggerFactory; + +import java.io.*; +import java.sql.SQLException; +import java.util.HashMap; +import java.util.Map; + +/** + * 常用工具方法-公用类 + * @author bleach + * @date 2018-01-18 + * @version 2.0 Modify By Weilin.Zhu 添加日志级别 2018-12-05 + * @version 3.0 Modify By Weilin.Zhu 修改日志输出方式,使用log4j 2020-03-10 + * @version 4.0 Modify By Weilin.Zhu 去除根据建模配置来控制日志输出功能 2021-06-29 + */ +public class ToolUtil extends BaseBean { + + Logger logger = LoggerFactory.getLogger("cus"); + + + private RecordSet rs = new RecordSet(); + + + /** + * 构造方法 + */ + public ToolUtil() { + //logger = LoggerFactory.getLogger("cus"); + } + + /** + * 根据流程类型ID获取其对应的表单名称 + * @param workflowid 流程类型ID + * @return 字符串 + */ + public String getBillTableNameByWorkflowId(String workflowid){ + String tablename = ""; + + if(!"".equals(workflowid)){ + String select_data = "select tablename from workflow_bill where id in (select formid from workflow_base where id = ?)"; + + if(rs.executeQuery(select_data, workflowid)){ + if(rs.next()){ + tablename = Util.null2String(rs.getString(1)); + } + } + } + + return tablename; + } + + /** + * 查询满足模糊查询的所有标识集合 + * @param likestr 模糊条件 + * @return + */ + public Map getSystemParamValueMap(String likestr){ + return getSystemParamList(likestr); + } + + /** + * 查询系统中所有参数配置 + * @return + */ + public Map getAllSystemParamValue(){ + return getSystemParamList(""); + } + + + /** + * 获取参数集合 + * @param likestr 模糊查询的条件 + * @return 集合 + */ + private Map getSystemParamList(String likestr){ + Map param_map = new HashMap(); + + String select_sql = "select uuid,paramvalue from uf_systemconfig"; + + RecordSet rs = new RecordSet(); + + if(!"".equals(likestr)){ + select_sql += " where uuid like '%" + likestr + "%'"; + } + + if(rs.execute(select_sql)){ + while(rs.next()){ + String uuid = Util.null2String(rs.getString(1)); + String paramvalue = Util.null2String(rs.getString(2)); + + param_map.put(uuid, paramvalue); + } + } + + return param_map; + + } + + /** + * 获取系统参数设置值 + * @param uuid 参数标识 + * @return 返回配置值 + */ + public String getSystemParamValue(String uuid){ + String paramvalue = ""; + + if(!"".equals(uuid)){ + String select_sql = "select paramvalue from uf_systemconfig where uuid = ?"; + + RecordSet rs = new RecordSet(); + rs.executeQuery(select_sql,uuid); + if(rs.next()){ + paramvalue = Util.null2String(rs.getString(1)); + } + } + + return paramvalue; + } + + /** + * 用数据库值,根据规则转换,获取其最终结果 + * @param cus_sql 自定义转换的SQL + * @param value 参数值 + * @return 配置值 + */ + public String getValueByChangeRule(String cus_sql,String value){ + + return getValueByChangeRule(cus_sql,value,""); + } + + /** + * 用数据库值,根据规则转换,获取其最终结果 + * @param cus_sql 自定义转换的SQL + * @param value 参数值 + * @param requestid 流程请求ID + * @return + */ + public String getValueByChangeRule(String cus_sql,String value,String requestid){ + + return getValueByChangeRule(cus_sql,value,requestid,0); + } + + /** + * 用数据库值,根据规则转换,获取其最终结果 + * @param cus_sql 自定义转换的SQL + * @param value 参数值 + * @param requestid 流程请求ID + * @param detailKeyvalue 明细表主键值 + * @return + */ + public String getValueByChangeRule(String cus_sql,String value,String requestid,int detailKeyvalue){ + return getValueByChangeRule(cus_sql,value,requestid,detailKeyvalue,null); + } + + /** + * 用数据库值,根据规则转换,获取其最终结果 + * @param cus_sql 自定义转换的SQL + * @param value 参数值 + * @param requestid 流程请求ID + * @param detailKeyvalue 明细表主键值 + * @pram datasourceid 外部数据源ID + * @return + */ + public String getValueByChangeRule(String cus_sql,String value,String requestid,int detailKeyvalue,String datasourceid){ + String endValue = ""; + cus_sql = ToDBC(cus_sql); + + cus_sql = cus_sql.replace(" ", " "); + + cus_sql = cus_sql.replace("{?dt.id}", String.valueOf(detailKeyvalue)); + + //参数进行替换 + String sqlString = cus_sql.replace("{?requestid}", requestid); + + sqlString = sqlString.replace("?", value); + + try { + if(datasourceid != null && !"".equals(datasourceid)){ + ConnStatementDataSource csds = new ConnStatementDataSource(datasourceid); + + csds.setStatementSql(sqlString); + + csds.executeQuery(); + + if(csds.next()){ + endValue = Util.null2String(csds.getString(1)); + } + + csds.close(); + }else{ + + RecordSet rs = new RecordSet(); + if(rs.executeQuery(sqlString)){ + rs.next(); + + endValue = Util.null2String(rs.getString(1)); + } + } + } catch (SQLException e) { + // TODO Auto-generated catch block + e.printStackTrace(); + } catch (Exception e) { + // TODO Auto-generated catch block + e.printStackTrace(); + } + + return endValue; + } + + + /** + * 用数据库值,根据规则转换,获取其最终结果 + * @param cus_sql 自定义转换的SQL + * @param value 参数值 + * @return + */ + public String getValueByChangeRule_SingleParam(String cus_sql,String value){ + String endValue = ""; + + cus_sql = cus_sql.replace(" ", " "); + + RecordSet rs = new RecordSet(); + + if(rs.executeQuery(cus_sql,value)){ + rs.next(); + + endValue = Util.null2String(rs.getString(1)); + } + + return endValue; + } + + /** + * 全角转半角 + * @param input + * @return + */ + private String ToDBC(String input) { + char c[] = input.toCharArray(); + for (int i = 0; i < c.length; i++) { + if (c[i] == '\u3000') { + c[i] = ' '; + } else if (c[i] > '\uFF00' && c[i] < '\uFF5F') { + c[i] = (char) (c[i] - 65248); + } + } + String returnString = new String(c); + return returnString; + } + + /** + * 根据字段ID获取其对应的字段名称 + * @param fieldid + * @return + */ + public String getFieldNameByFieldid(int fieldid){ + if(fieldid > 0){ + return getFieldNameByFieldid(String.valueOf(fieldid)); + }else{ + return ""; + } + } + + /** + * 根据字段ID获取其对应的字段名称 + * @param fieldid + * @return + */ + public String getFieldNameByFieldid(String fieldid){ + String fieldname = ""; + + if(!"".equals(fieldid)){ + + if(fieldid.startsWith(",")){ + fieldid = fieldid.substring(1); + } + + if(fieldid.endsWith(",")){ + fieldid =fieldid.substring(0,fieldid.length() - 1); + } + + String select_sql = "select fieldname from workflow_billfield where id in (" + fieldid + ")"; + + RecordSet rs = new RecordSet(); + + if(rs.execute(select_sql)){ + while(rs.next()){ + + fieldname += "," + Util.null2String(rs.getString(1)); + } + } + } + + if(fieldname.startsWith(",")){ + fieldname = fieldname.substring(1); + } + + return fieldname; + } + + /** + * 输出调试日志 + * @param logstr 日志信息 + */ + public void writeDebuggerLog(String logstr){ + logger.info(logstr); + } + + /** + * 输出调试日志 + * @param className 类名称 + * @param logstr 日志信息 + */ + public void writeDebuggerLog(String className,String logstr){ + logger.info(logstr); + } + + /** + * 输出警告日志 + * @param className 类名称 + * @param logstr 日志信息 + */ + public void writeWarningLog(String className,String logstr){ + logger.warn(logstr); + } + + /** + * 输出错误日志 + * @param className 类名称 + * @param logstr 日志信息 + */ + public void writeErrorLog(String className,String logstr){ + logger.error(logstr); + } + + + /** + * 日志输出 + * @param logstr + */ + public void writeDebugLog(Object logstr){ + logger.info(logstr); + } + + /** + * 日志输出 + * @param logstr + */ + public void writeErrorLog(Object logstr){ + logger.error(logstr); + } + + /** + * 日志输出 + * @param logstr + */ + public void writeNewDebuggerLog(Object o,Object logstr){ + logger.info(logstr); + } + + /** + * 写入同步的日志文件 + * @param o + * @param s + * @deprecated 该写入文件的日志输出方式删除 + */ + protected void writeNewLog(String o,String s){ + try { + String filename = "cus_" + TimeUtil.getCurrentDateString() + "_ecology.log"; + + + String folder = GCONST.getRootPath() + "log" + File.separatorChar + "cus"; + + //this.writeDebugLog("folder:[" + folder + "]"); + + File f = new File(folder); + + // 创建文件夹 + if (!f.exists()) { + f.mkdirs(); + } + + f = new File(folder + File.separatorChar + filename); + //文件不存在,则直接创建 + if(!f.exists()){ + f.createNewFile(); + } + + BufferedWriter out = new BufferedWriter(new OutputStreamWriter(new FileOutputStream(f, true))); + + out.write("[" + o + "][" + TimeUtil.getCurrentTimeString() + "]:"+ s + "\r\n"); + + //关闭写入流 + out.close(); + + } catch (IOException e) { + // TODO Auto-generated catch block + e.printStackTrace(); + writeDebugLog("创建日志文件存在异常:[" + e.getMessage() + "/" + e.toString() + "]"); + } + } +} diff --git a/src/main/java/weaver/chaoyang/he/zwl/common/ToolUtil_E9.java b/src/main/java/weaver/chaoyang/he/zwl/common/ToolUtil_E9.java new file mode 100644 index 0000000..eb9aeff --- /dev/null +++ b/src/main/java/weaver/chaoyang/he/zwl/common/ToolUtil_E9.java @@ -0,0 +1,396 @@ +package weaver.chaoyang.he.zwl.common; + +import weaver.conn.ConnStatementDataSource; +import weaver.conn.RecordSet; +import weaver.general.BaseBean; +import weaver.general.GCONST; +import weaver.general.TimeUtil; +import weaver.general.Util; +import weaver.zwl.common.logging.Logger; +import weaver.zwl.common.logging.LoggerFactory; + +import java.io.*; +import java.sql.SQLException; +import java.util.HashMap; +import java.util.Map; + +/** + * 常用工具方法-公用类 + * @author bleach + * @date 2018-01-18 + * @version 2.0 Modify By Weilin.Zhu 添加日志级别 2018-12-05 + * @version 3.0 Modify By Weilin.Zhu 修改日志输出方式,使用log4j 2020-03-10 + * @version 4.0 Modify By Weilin.Zhu 去除根据建模配置来控制日志输出功能 2021-06-29 + * @version 5.0 Modify By Weilin.Zhu 执行SQL转换异常信息抛出,不再进行捕获 + */ +public class ToolUtil_E9 extends BaseBean { + + Logger logger = LoggerFactory.getLogger("cus"); + + + private RecordSet rs = new RecordSet(); + + + /** + * 构造方法 + */ + public ToolUtil_E9() { + //logger = LoggerFactory.getLogger("cus"); + } + + /** + * 根据流程类型ID获取其对应的表单名称 + * @param workflowid 流程类型ID + * @return 字符串 + */ + public String getBillTableNameByWorkflowId(String workflowid){ + String tablename = ""; + + if(!"".equals(workflowid)){ + String select_data = "select tablename from workflow_bill where id in (select formid from workflow_base where id = ?)"; + + if(rs.executeQuery(select_data, workflowid)){ + if(rs.next()){ + tablename = Util.null2String(rs.getString(1)); + } + } + } + + return tablename; + } + + /** + * 查询满足模糊查询的所有标识集合 + * @param likestr 模糊条件 + * @return + */ + public Map getSystemParamValueMap(String likestr){ + return getSystemParamList(likestr); + } + + /** + * 查询系统中所有参数配置 + * @return + */ + public Map getAllSystemParamValue(){ + return getSystemParamList(""); + } + + + /** + * 获取参数集合 + * @param likestr 模糊查询的条件 + * @return 集合 + */ + private Map getSystemParamList(String likestr){ + Map param_map = new HashMap(); + + String select_sql = "select uuid,paramvalue from uf_systemconfig"; + + RecordSet rs = new RecordSet(); + + if(!"".equals(likestr)){ + select_sql += " where uuid like '%" + likestr + "%'"; + } + + if(rs.execute(select_sql)){ + while(rs.next()){ + String uuid = Util.null2String(rs.getString(1)); + String paramvalue = Util.null2String(rs.getString(2)); + + param_map.put(uuid, paramvalue); + } + } + + return param_map; + + } + + /** + * 获取系统参数设置值 + * @param uuid 参数标识 + * @return 返回配置值 + */ + public String getSystemParamValue(String uuid){ + String paramvalue = ""; + + if(!"".equals(uuid)){ + String select_sql = "select paramvalue from uf_systemconfig where uuid = ?"; + + RecordSet rs = new RecordSet(); + rs.executeQuery(select_sql,uuid); + if(rs.next()){ + paramvalue = Util.null2String(rs.getString(1)); + } + } + + return paramvalue; + } + + /** + * 用数据库值,根据规则转换,获取其最终结果 + * @param cus_sql 自定义转换的SQL + * @param value 参数值 + * @return 配置值 + */ + public String getValueByChangeRule(String cus_sql,String value) throws Exception { + + return getValueByChangeRule(cus_sql,value,""); + } + + /** + * 用数据库值,根据规则转换,获取其最终结果 + * @param cus_sql 自定义转换的SQL + * @param value 参数值 + * @param requestid 流程请求ID + * @return + */ + public String getValueByChangeRule(String cus_sql,String value,String requestid) throws Exception { + + return getValueByChangeRule(cus_sql,value,requestid,0); + } + + /** + * 用数据库值,根据规则转换,获取其最终结果 + * @param cus_sql 自定义转换的SQL + * @param value 参数值 + * @param requestid 流程请求ID + * @param detailKeyvalue 明细表主键值 + * @return + */ + public String getValueByChangeRule(String cus_sql,String value,String requestid,int detailKeyvalue) throws Exception { + return getValueByChangeRule(cus_sql,value,requestid,detailKeyvalue,null); + } + + /** + * 用数据库值,根据规则转换,获取其最终结果 + * @param cus_sql 自定义转换的SQL + * @param value 参数值 + * @param requestid 流程请求ID + * @param detailKeyvalue 明细表主键值 + * @pram datasourceid 外部数据源ID + * @return + */ + public String getValueByChangeRule(String cus_sql,String value,String requestid,int detailKeyvalue,String datasourceid) throws Exception { + String endValue = ""; + cus_sql = ToDBC(cus_sql); + + cus_sql = cus_sql.replace(" ", " "); + + cus_sql = cus_sql.replace("{?dt.id}", String.valueOf(detailKeyvalue)); + + //参数进行替换 + String sqlString = cus_sql.replace("{?requestid}", requestid); + + sqlString = sqlString.replace("?", value); + + if(datasourceid != null && !"".equals(datasourceid)){ + ConnStatementDataSource csds = new ConnStatementDataSource(datasourceid); + + csds.setStatementSql(sqlString); + + csds.executeQuery(); + + if(csds.next()){ + endValue = Util.null2String(csds.getString(1)); + } + + csds.close(); + }else{ + + RecordSet rs = new RecordSet(); + if(rs.executeQuery(sqlString)){ + rs.next(); + endValue = Util.null2String(rs.getString(1)); + } + } + + + return endValue; + } + + + /** + * 用数据库值,根据规则转换,获取其最终结果 + * @param cus_sql 自定义转换的SQL + * @param value 参数值 + * @return + */ + public String getValueByChangeRule_SingleParam(String cus_sql,String value){ + String endValue = ""; + + cus_sql = cus_sql.replace(" ", " "); + + RecordSet rs = new RecordSet(); + + if(rs.executeQuery(cus_sql,value)){ + rs.next(); + + endValue = Util.null2String(rs.getString(1)); + } + + return endValue; + } + + /** + * 全角转半角 + * @param input + * @return + */ + public String ToDBC(String input) { + char c[] = input.toCharArray(); + for (int i = 0; i < c.length; i++) { + if (c[i] == '\u3000') { + c[i] = ' '; + } else if (c[i] > '\uFF00' && c[i] < '\uFF5F') { + c[i] = (char) (c[i] - 65248); + } + } + String returnString = new String(c); + return returnString; + } + + /** + * 根据字段ID获取其对应的字段名称 + * @param fieldid + * @return + */ + public String getFieldNameByFieldid(int fieldid){ + if(fieldid > 0){ + return getFieldNameByFieldid(String.valueOf(fieldid)); + }else{ + return ""; + } + } + + /** + * 根据字段ID获取其对应的字段名称 + * @param fieldid + * @return + */ + public String getFieldNameByFieldid(String fieldid){ + String fieldname = ""; + + if(!"".equals(fieldid)){ + + if(fieldid.startsWith(",")){ + fieldid = fieldid.substring(1); + } + + if(fieldid.endsWith(",")){ + fieldid =fieldid.substring(0,fieldid.length() - 1); + } + + String select_sql = "select fieldname from workflow_billfield where id in (" + fieldid + ")"; + + RecordSet rs = new RecordSet(); + + if(rs.execute(select_sql)){ + while(rs.next()){ + + fieldname += "," + Util.null2String(rs.getString(1)); + } + } + } + + if(fieldname.startsWith(",")){ + fieldname = fieldname.substring(1); + } + + return fieldname; + } + + /** + * 输出调试日志 + * @param className 类名称 + * @param logstr 日志信息 + */ + public void writeDebuggerLog(String className,String logstr){ + logger.info(logstr); + } + + /** + * 输出警告日志 + * @param className 类名称 + * @param logstr 日志信息 + */ + public void writeWarningLog(String className,String logstr){ + logger.warn(logstr); + } + + /** + * 输出错误日志 + * @param className 类名称 + * @param logstr 日志信息 + */ + public void writeErrorLog(String className,String logstr){ + logger.error(logstr); + } + + + /** + * 日志输出 + * @param logstr + */ + public void writeDebugLog(Object logstr){ + logger.info(logstr); + } + + /** + * 日志输出 + * @param logstr + */ + public void writeErrorLog(Object logstr){ + logger.error(logstr); + } + + /** + * 日志输出 + * @param logstr + */ + public void writeNewDebuggerLog(Object o,Object logstr){ + logger.info(logstr); + } + + /** + * 写入同步的日志文件 + * @param o + * @param s + * @deprecated 该写入文件的日志输出方式删除 + */ + protected void writeNewLog(String o,String s){ + try { + String filename = "cus_" + TimeUtil.getCurrentDateString() + "_ecology.log"; + + + String folder = GCONST.getRootPath() + "log" + File.separatorChar + "cus"; + + //this.writeDebugLog("folder:[" + folder + "]"); + + File f = new File(folder); + + // 创建文件夹 + if (!f.exists()) { + f.mkdirs(); + } + + f = new File(folder + File.separatorChar + filename); + //文件不存在,则直接创建 + if(!f.exists()){ + f.createNewFile(); + } + + BufferedWriter out = new BufferedWriter(new OutputStreamWriter(new FileOutputStream(f, true))); + + out.write("[" + o + "][" + TimeUtil.getCurrentTimeString() + "]:"+ s + "\r\n"); + + //关闭写入流 + out.close(); + + } catch (IOException e) { + // TODO Auto-generated catch block + e.printStackTrace(); + writeDebugLog("创建日志文件存在异常:[" + e.getMessage() + "/" + e.toString() + "]"); + } + } +} diff --git a/src/main/java/weaver/chaoyang/he/zwl/common/WorkflowData_To_Middle_DB_Action.java b/src/main/java/weaver/chaoyang/he/zwl/common/WorkflowData_To_Middle_DB_Action.java new file mode 100644 index 0000000..bea3a7e --- /dev/null +++ b/src/main/java/weaver/chaoyang/he/zwl/common/WorkflowData_To_Middle_DB_Action.java @@ -0,0 +1,429 @@ +package weaver.chaoyang.he.zwl.common; + +import weaver.conn.RecordSet; +import weaver.conn.RecordSetDataSource; +import weaver.conn.RecordSetTrans; +import weaver.general.BaseBean; +import weaver.general.TimeUtil; +import weaver.general.Util; +import weaver.interfaces.workflow.action.Action; +import weaver.soa.workflow.request.RequestInfo; + +import java.util.ArrayList; +import java.util.HashMap; +import java.util.List; +import java.util.Map; + +/** + * OA流程数据写入中间库 + * @author bleach + * @date 2018-09-01 + */ +public class WorkflowData_To_Middle_DB_Action extends BaseBean implements Action { + private String cus_param = "";//自定义参数 + + private String this_requestid = "";//当前流程请求ID + + private String this_requestname = "";//当前流程请求标题 + + private String this_requestmark = "";//当前流程流程编号 + + private String currentday = "";//当前系统日期 + + private String currentdatetime = "";//当前系统日期时间 + + + /** + * 实现父类方法 + * @param requestInfo + * @return + */ + @Override + public String execute(RequestInfo requestInfo) { + this.writeLog("WorkflowData_To_Middle_DB_Action", "------------------------WorkflowData_To_Middle_DB_Action Begin-----------------------------"); + currentday = TimeUtil.getCurrentDateString(); + + currentdatetime = TimeUtil.getOnlyCurrentTimeString(); + + //获取流程类型ID + String workflowid = Util.null2String(requestInfo.getWorkflowid()); + //获取当前请求ID + this_requestid = Util.null2String(requestInfo.getRequestid()); + //获取当前表单ID + int formid = requestInfo.getRequestManager().getFormid(); + //获取当前流程数据所在表名称 + String workflow_main_tablename = requestInfo.getRequestManager().getBillTableName(); + + //获取流程事务 + RecordSetTrans rsts = requestInfo.getRsTrans(); + + //获取流程基础数据 + String select_base_sql = "select * from workflow_requestbase where requestid = ?"; + try { + if (rsts == null) { + rsts = new RecordSetTrans(); + } + + //查询流程基本信息 + if (rsts.executeQuery(select_base_sql, this_requestid)) { + while (rsts.next()) { + this.this_requestname = Util.null2String(rsts.getString("requestname")); + this.this_requestmark = Util.null2String(rsts.getString("requestmark")); + } + } + + //日志输出 + this.writeLog("this_requestname:[" + this_requestname + "],this_requestmark:[" + this_requestmark + "],workflowid:[" + workflowid + "],this_requestid:[" + this_requestid + "],formid:[" + formid + "]"); + } catch (Exception e1) { + e1.printStackTrace(); + this.writeLog("获取该流程事物数据集异常:[" + e1.toString() + "/" + e1.getMessage() + "]"); + + return Action.FAILURE_AND_CONTINUE; + } + + //获取当前流程的字段映射配置(包含其对应的历史版本) + String select_main_config = "select * from workflow_field_config where workflowid in (select id from workflow_base where activeversionid in (select activeVersionID from workflow_base where id = ?) or id = ?)"; + + if(!"".equals(cus_param)){ + select_main_config += " and cus_param = '" + cus_param + "'"; + } + + RecordSet rs = new RecordSet(); + + int main_config_keyid = -1; + //外部主表名称 + String o_maintable = ""; + //外部明细表名称 + String o_detailtable = ""; + //数据条件 + String o_condition = ""; + //数据源标识 + String datasourceid = ""; + + if (rs.executeQuery(select_main_config, workflowid, workflowid)) { + rs.next(); + + main_config_keyid = Util.getIntValue(rs.getString("id"), 0); + + o_maintable = Util.null2String(rs.getString("o_maintable")).toLowerCase(); + + o_detailtable = Util.null2String(rs.getString("o_detailtable")); + + o_condition = Util.null2String(rs.getString("o_condition")); + + datasourceid = Util.null2String(rs.getString("datasourceid")); + } + + //本地明细表与外部明细表的映射关系<本地明细表名,外部明细表名> + Map detail_l_o_map = new HashMap(); + if (main_config_keyid > 0) {//说明该流程对应的配置存在 + //获取当前流程配置对应明细表映射配置 + String select_detailtb_mapping = "select * from workflow_detail_mapping where configid = ?"; + if (rs.executeQuery(select_detailtb_mapping, main_config_keyid)) { + while (rs.next()) { + String l_detail_tablename = Util.null2String(rs.getString("l_detailtablename")).toLowerCase();//本地明细表名称 + String o_detail_tablename = Util.null2String(rs.getString("o_detailtablename")).toLowerCase();//外部明细表名称 + + detail_l_o_map.put(l_detail_tablename, o_detail_tablename); + } + } + + //是否存在明细字段配置 + boolean ishasdetailfield = false; + + List> field_list = new ArrayList>(); + + //获取所有字段映射配置 + String select_detail_config = "select wm.*,wb.fieldname,wb.viewtype,wb.detailtable from workflow_field_mapping wm left join workflow_billfield wb on wm.l_fieldid = wb.id where wm.configid = ?"; + if (rs.executeQuery(select_detail_config, main_config_keyid)) { + while (rs.next()) { + //外部字段名称 + String o_fieldname = Util.null2String(rs.getString("o_fieldname")); + + if ("".equals(o_fieldname) || "requestid".equals(o_fieldname.toLowerCase())) {//若外部字段名称为空,则该条配置直接跳过 + continue; + } + //本地流程字段ID + String l_fieldid = Util.null2String(rs.getString("l_fieldid")); + //本地流程字段所属 + int l_viewtype = Util.getIntValue(rs.getString("viewtype"), 0); + + if (l_viewtype == 1) {//属于明细表字段 + ishasdetailfield = true; + } + //本地流程字段名 + String l_fieldname = Util.null2String(rs.getString("fieldname")); + + //自定义转换规则 + String cussql = Util.null2String(rs.getString("cussql")); + + //本地流程字段存在的明细表名称 + String l_field_table = Util.null2String(rs.getString("detailtable")); + + //外部字段所属表名称 + String o_field_table = Util.null2String(rs.getString("field_table")).toLowerCase(); + + //字段转换规则 + int changerule = Util.getIntValue(rs.getString("changerule"), 0); + + Map detail_map = new HashMap(); + + detail_map.put("o_fieldname", o_fieldname); + detail_map.put("l_fieldid", l_fieldid); + detail_map.put("l_viewtype", l_viewtype); + detail_map.put("l_fieldname", l_fieldname); + detail_map.put("cussql", cussql); + detail_map.put("o_field_table", o_field_table); + detail_map.put("l_field_table", l_field_table); + detail_map.put("changerule", changerule); + + field_list.add(detail_map); + } + } + + Map workflow_detailtable_map = new HashMap(); + //判断当前流程是否存在明细表 + String select_workflow_detailtable = "select * from workflow_billdetailtable where billid = ? order by orderid"; + + if (rs.executeQuery(select_workflow_detailtable, formid)) { + while (rs.next()) { + int orderid = Util.getIntValue(rs.getString("orderid"), 1); + + String tablename = Util.null2String(rs.getString("tablename")); + + workflow_detailtable_map.put(orderid, tablename); + } + } + + RecordSetDataSource rsds = new RecordSetDataSource(datasourceid); + + //查询流程主表数据SQL + String select_workflow_main = "select m.id as mainkeyid,m.* from " + workflow_main_tablename + " m where m.requestid = ? "; + + //若外部明细表与OA明细表对应关系不存在 + if (detail_l_o_map == null || detail_l_o_map.isEmpty() || detail_l_o_map.size() <= 0) { + if (ishasdetailfield) { //字段对应关系中存在明细表映射 + //判断当前流程存在明细表,且明细序列为1的明细存在 + if (workflow_detailtable_map != null && workflow_detailtable_map.size() > 0 && workflow_detailtable_map.containsKey(1)) { + //获取第一个明细表名称 + String first_detail_table = workflow_detailtable_map.get(1); + + if (!"".equals(first_detail_table)) { + select_workflow_main = "select m.id as mainkeyid,dt.id as detailkeyid,m.*,dt.* from " + first_detail_table + " dt left join " + workflow_main_tablename + " m on dt.mainid = m.id where m.requestid = ? "; + } + } + } + } + + this.writeLog("查询流程主表数据信息:[" + select_workflow_main + "]"); + + if (!"".equals(o_condition)) { + select_workflow_main += " " + o_condition; + } + + boolean main_insert_success = false; + + //当前流程主键数据ID + int workflow_main_keyid = 0; + //查询流程主表数据 + if (rs.executeQuery(select_workflow_main, this_requestid)) { + //插入前先删除该流程存在的历史数据 + rsds.execute("delete from " + o_maintable + " where requestid = '" + this_requestid + "'"); + while (rs.next()) { + workflow_main_keyid = Util.getIntValue(rs.getString("mainkeyid"), 0); + + String insert_o_col = "";//插入的列名 + String insert_o_val = "";//插入的列值 + + for (Map detail_map : field_list) { + //获取外部表字段名称 + String o_fieldname = detail_map.get("o_fieldname").toString(); + //获取字段所属的外部表名 + String o_field_table = detail_map.get("o_field_table").toString(); + + if (!o_field_table.equals(o_maintable)) {//说明该字段不属于当前主表 + continue; + } + + String fieldvalue = getFinalfieldvalue(rs,null,detail_map,0); + + insert_o_col += "," + o_fieldname; + insert_o_val += ",'" + fieldvalue + "'"; + } + + //插入外部主表数据SQL + String insert_o_sql = "insert into " + o_maintable + "(requestid" + insert_o_col + ") values (" + this_requestid + insert_o_val + ")"; + + this.writeLog("插入外部主表SQL:[" + insert_o_sql + "]"); + + if (rsds.execute(insert_o_sql)) { + main_insert_success = true; + } else { + requestInfo.getRequestManager().setMessageid("11111" + requestInfo.getRequestManager().getRequestid() + "22222"); + requestInfo.getRequestManager().setMessagecontent("数据写入中间表接口失败,请联系系统管理员!"); + + return Action.FAILURE_AND_CONTINUE; + } + } + } + + boolean detail_insert_success = true;//明细字段插入成功与否的标志位 + + //主表写入成功,明细表映射存在 + if (main_insert_success && detail_l_o_map != null && detail_l_o_map.size() > 0) { + for (String l_detailtablename : detail_l_o_map.keySet()) {//遍历明细表映射集合 + //获取外部明细表名称 + String o_detailtablename = detail_l_o_map.get(l_detailtablename); + + //获取当前流程明细表记录 + String select_workflow_detail = "select * from " + l_detailtablename + " where mainid = ?"; + + RecordSet rs_detail = new RecordSet(); + + if (rs_detail.executeQuery(select_workflow_detail, workflow_main_keyid)) { + int detail_Index_Row = 0; + while (rs_detail.next()) { + String insert_detail_o_col = "";//插入的列名 + String insert_detail_o_val = "";//插入的列值 + + for (Map detail_map : field_list) { + //获取外部表字段名称 + String o_fieldname = detail_map.get("o_fieldname").toString(); + //获取字段所属的外部表名 + String o_field_table = detail_map.get("o_field_table").toString(); + //获取流程表单字段为明细表 + String l_field_table = detail_map.get("o_field_table").toString(); + //获取流程字段所属 + int l_viewtype = (Integer) detail_map.get("l_viewtype"); + + if (!o_field_table.equals(o_detailtablename) || (l_viewtype == 1 && !l_field_table.equals(l_detailtablename))) {//说明该字段不属于当前主表或者取自流程表单明细表字段但字段不属于当前明细表 + continue; + } + + String fieldvalue = getFinalfieldvalue(rs,rs_detail,detail_map,detail_Index_Row++); + + insert_detail_o_col += "," + o_fieldname; + insert_detail_o_val += ",'" + fieldvalue + "'"; + } + + //插入外部明细表数据SQL + String insert_detail_o_sql = "insert into " + o_detailtablename + "(requestid" + insert_detail_o_col + ") values (" + this_requestid + insert_detail_o_val + ")"; + + this.writeLog("插入外部明细表SQL:[" + insert_detail_o_sql + "]"); + + if(!rsds.execute(insert_detail_o_sql)){ + detail_insert_success = false; + break; + } + } + } + } + + } else {//说明该流程对应的配置不存在 + this.writeLog("当前流程映射配置不存在,流程直接跳过Action!"); + } + } + this.writeLog("WorkflowData_To_Middle_DB_Action", "------------------------WorkflowData_To_Middle_DB_Action End-----------------------------"); + return Action.SUCCESS; + } + /** + * 获取转换后的实际值 + * @param rs 主表数据集 + * @param rs_detail 明细表某一行的数据集 + * @param config_map 字段集合 + * @return + */ + private String getFinalfieldvalue(RecordSet rs,RecordSet rs_detail,Map config_map,int detailTable_Index){ + + //获取外部表字段名称 + String o_fieldname = config_map.get("o_fieldname").toString(); + //获取其对应的OA字段名称 + String l_fieldname = config_map.get("l_fieldname").toString(); + //获取其转换规则 + int changerule = (Integer)config_map.get("changerule"); + //流程字段所属 + int l_viewtype = (Integer)config_map.get("l_viewtype"); + //自定义转换规则 + String cussql = config_map.get("cussql").toString(); + + //this.writeLog("---------->o_fieldname:[" + o_fieldname + "],l_fieldname:[" + l_fieldname + "],changerule:[" + changerule + "],cussql:[" + cussql + "]"); + + String field_workflow_value = ""; + if(!"".equals(l_fieldname)){//对应的流程字段不为空 + if(l_viewtype == 1 && rs_detail != null){//字段为明细表字段 + field_workflow_value = Util.null2String(rs_detail.getString(l_fieldname)); + }else { + field_workflow_value = Util.null2String(rs.getString(l_fieldname)); + } + } + + String final_value = ""; + + switch (changerule){ + case 1://流程requestid + final_value = this_requestid; + break; + case 2://流程标题 + final_value = this_requestname; + break; + case 3://流程编号 + final_value = this_requestmark; + break; + case 4://系统日期 + final_value = currentday; + break; + case 5://系统日期时间 + final_value = currentdatetime; + break; + case 6://固定值 + final_value = cussql; + break; + case 7://自定义规则 + final_value = getValueByChangeRule(cussql,field_workflow_value); + break; + case 8://明细行序号 + final_value = String.valueOf(detailTable_Index); + break; + default: + final_value = field_workflow_value; + break; + } + + final_value = final_value.replace("'","''"); + + return final_value; + } + + /** + * 用数据库值,根据规则转换,获取其最终结果 + * @param cus_sql 自定义转换的规则 + * @param value + * @return + */ + private String getValueByChangeRule(String cus_sql,String value){ + String endValue = ""; + + String sqlString = cus_sql.replace("{?requestid}", this_requestid).replace("?", value); + + RecordSet rs = new RecordSet(); + //this.writeLog("转换后的SQL:[" + sqlString + "]"); + if(rs.execute(sqlString)){ + rs.next(); + + endValue = Util.null2String(rs.getString(1)); + } + return endValue; + } + /** + * @return the cus_param + */ + public String getCus_param() { + return cus_param; + } + /** + * @param cus_param the cus_param to set + */ + public void setCus_param(String cus_param) { + this.cus_param = cus_param; + } +} diff --git a/src/main/java/weaver/chaoyang/he/zwl/common/formmode/ExecuteSQL_Action.java b/src/main/java/weaver/chaoyang/he/zwl/common/formmode/ExecuteSQL_Action.java new file mode 100644 index 0000000..9f04dce --- /dev/null +++ b/src/main/java/weaver/chaoyang/he/zwl/common/formmode/ExecuteSQL_Action.java @@ -0,0 +1,45 @@ +package weaver.chaoyang.he.zwl.common.formmode; + +import weaver.formmode.customjavacode.AbstractModeExpandJavaCode; +import weaver.general.Util; +import weaver.hrm.User; +import weaver.soa.workflow.request.RequestInfo; +import weaver.zwl.common.ToolUtil; + +import java.util.Map; + +/** + * 通用工具表单建模 + * 手动执行自定义SQL + */ +public class ExecuteSQL_Action extends AbstractModeExpandJavaCode { + //当前类名称 + private String className = "ExecuteSQL_Action"; + private ToolUtil toolutil = new ToolUtil(); + + /** + * 执行模块扩展动作 + * @param param + * param包含(但不限于)以下数据 + * user 当前用户 + */ + public void doModeExpand(Map param) throws Exception { + toolutil.writeDebuggerLog(className, "---------------" + className + " BEGIN ---------------"); + + //当前用户信息 + User user = (User) param.get("user"); + int billid = -1;//数据id + //int modeid = -1;//模块id + //模块信息 + RequestInfo requestInfo = (RequestInfo) param.get("RequestInfo"); + if (requestInfo != null) { + billid = Util.getIntValue(requestInfo.getRequestid()); + //modeid = Util.getIntValue(requestInfo.getWorkflowid()); + + ExecuteSQL_Util eu = new ExecuteSQL_Util(); + eu.execute_sql_job(billid,1,user.getUID()); + } + + toolutil.writeDebuggerLog(className, "---------------" + className + " End ---------------"); + } +} diff --git a/src/main/java/weaver/chaoyang/he/zwl/common/formmode/ExecuteSQL_Cron.java b/src/main/java/weaver/chaoyang/he/zwl/common/formmode/ExecuteSQL_Cron.java new file mode 100644 index 0000000..44299fe --- /dev/null +++ b/src/main/java/weaver/chaoyang/he/zwl/common/formmode/ExecuteSQL_Cron.java @@ -0,0 +1,43 @@ +package weaver.chaoyang.he.zwl.common.formmode; + +import weaver.general.Util; +import weaver.interfaces.schedule.BaseCronJob; +import weaver.zwl.common.ToolUtil; + +/** + * 通用功能 + * ִ执行自定义SQL语句的计划任务 + */ +public class ExecuteSQL_Cron extends BaseCronJob { + private String className = "ExecuteSQL_Cron"; + + private String keyvalue = ""; + + private ToolUtil toolUtil = new ToolUtil(); + + /** + * 实现父类方法 + */ + public void execute(){ + toolUtil.writeNewDebuggerLog(className, "-------------" + className + " BEGIN-----------------"); + + toolUtil.writeDebuggerLog(className,"--->keyvalue:[" + keyvalue + "]"); + + ExecuteSQL_Util eu = new ExecuteSQL_Util(); + + if(!"".equals(keyvalue)){ + eu.execute_sql_job(Util.getIntValue(keyvalue,0),0,1); + }else { + eu.execute_sql_job(); + } + toolUtil.writeNewDebuggerLog(className, "-------------" + className + " End-----------------"); + } + + public String getKeyvalue() { + return keyvalue; + } + + public void setKeyvalue(String keyvalue) { + this.keyvalue = keyvalue; + } +} diff --git a/src/main/java/weaver/chaoyang/he/zwl/common/formmode/ExecuteSQL_Util.java b/src/main/java/weaver/chaoyang/he/zwl/common/formmode/ExecuteSQL_Util.java new file mode 100644 index 0000000..409cae8 --- /dev/null +++ b/src/main/java/weaver/chaoyang/he/zwl/common/formmode/ExecuteSQL_Util.java @@ -0,0 +1,130 @@ +package weaver.chaoyang.he.zwl.common.formmode; + +import weaver.conn.RecordSet; +import weaver.conn.RecordSetDataSource; +import weaver.general.TimeUtil; +import weaver.general.Util; +import weaver.zwl.common.ToolUtil; + +/** + * 执行自定义SQL的工具类 + */ +public class ExecuteSQL_Util extends ToolUtil { + //当前类名称 + private String className = "ExecuteSQL_Util"; + + /** + * 执行建模中的SQL语句 + */ + public void execute_sql_job(){ + execute_sql_job(0,0,1); + } + + /** + * 执行建模中的SQL语句 + * @param keyvalue 具体记录ID + * @param sourceType 执行方法 0-自动 1-手动 + * @param userid 用户ID + */ + public void execute_sql_job(int keyvalue,int sourceType,int userid) { + this.writeNewDebuggerLog(className, "-------------" + className + " BEGIN-----------------"); + + //获取建模中未执行的SQL + String select_data = "select * from uf_Pending_SQL where 1=1 "; + + if(keyvalue > 0){ + select_data += " and isopen = 0 and id = " + keyvalue; + }else{ + select_data += " and isopen = 0"; + } + + if(sourceType == 0){ + select_data += " and scope in (0,2)"; + }else if(sourceType == 1){ + select_data += " and scope in (1,2)"; + } + + select_data += " order by exe_order"; + + this.writeNewDebuggerLog(className,"查询满足条件的SQL:[" + select_data + "]"); + + RecordSet rs = new RecordSet(); + + RecordSet rs_o = new RecordSet(); + + if(rs.executeQuery(select_data)){ + while(rs.next()){ + //数据ID + int dataid = Util.getIntValue(rs.getString("id"),0); + //配置名称 + String name = Util.null2String(rs.getString("name")); + //数据源标识 + String dbid = Util.null2String(rs.getString("dbid")); + //待执行的SQL + String mainSQL = Util.null2String(rs.getString("mainSQL")); + + mainSQL = mainSQL.replace("^",""); + //对SQL语句字符串特殊字符的处理 + mainSQL = mainSQL.replace(" "," "); + mainSQL = mainSQL.replace("
"," "); + //再次将全角转成半角 + mainSQL = ToDBC(mainSQL); + + this.writeNewDebuggerLog(className,"--->name:[" + name + "],keyid:[" + dataid + "],DBBase:[" + dbid + "],mainSQL:[" + mainSQL + "]"); + + RecordSetDataSource rsds = null; + + if(!"".equals(dbid)){ + rsds = new RecordSetDataSource(dbid); + } + + boolean issuccess = false; + String exception = ""; + try { + + if(!"".equals(dbid)){ + issuccess = rsds.executeSql(mainSQL); + }else{ + issuccess = rs_o.execute(mainSQL); + + if(!issuccess){ + exception = rs_o.getExceptionMsg(); + } + } + + }catch (Exception e){ + e.printStackTrace(); + exception = e.getMessage(); + + this.writeNewDebuggerLog(className,"---->" + e.getMessage() + "/" + e.toString()); + } + + //插入操作日志 + String insert_log = "insert into uf_Pending_SQL_dt1 (mainid,operatetype,exe_result,exe_operator,exe_datetime,failureReason) values (" + + +dataid + "," + sourceType + "," + (issuccess ? 1 : 0) + "," + userid + ",'" + TimeUtil.getCurrentTimeString() + "','" + exception + "')"; + + rs_o.executeUpdate(insert_log); + } + } + + this.writeNewDebuggerLog(className, "-------------" + className + " END-----------------"); + } + + /** + * 全角转半角 + * @param input + * @return + */ + public String ToDBC(String input) { + char c[] = input.toCharArray(); + for (int i = 0; i < c.length; i++) { + if (c[i] == '\u3000') { + c[i] = ' '; + } else if (c[i] > '\uFF00' && c[i] < '\uFF5F') { + c[i] = (char) (c[i] - 65248); + } + } + String returnString = new String(c); + return returnString; + } +} diff --git a/src/main/java/weaver/chaoyang/he/zwl/common/formmode/SyncLoggerDao.java b/src/main/java/weaver/chaoyang/he/zwl/common/formmode/SyncLoggerDao.java new file mode 100644 index 0000000..c83a221 --- /dev/null +++ b/src/main/java/weaver/chaoyang/he/zwl/common/formmode/SyncLoggerDao.java @@ -0,0 +1,134 @@ +package weaver.chaoyang.he.zwl.common.formmode; + +import java.util.ArrayList; +import java.util.List; + +/** + * 同步外部数据日志实体类 + * @author bleach + * @date 2021-11-15 + * @version 1.0 + */ +public class SyncLoggerDao { + /** + * 总记录条数 + */ + private int totalNum = 0; + /** + * 成功记录条数 + */ + private int successNum = 0; + /** + * 失败记录条数 + */ + private int failNum = 0; + /** + * 操作人员ID + */ + private int operatorid = 0; + /** + * 操作日期 + */ + private String operateDate = ""; + /** + * 操作时间 + */ + private String operateTime = ""; + /** + * 操作方式 0-手动 1-自动 + */ + private int operateType = -1; + /** + * 对应配置ID + */ + private int configId = -1; + /** + * 描述性文字 + */ + private String message = ""; + + /** + * 详细信息集合 + */ + private List detailDaoList = new ArrayList<>(); + + public int getTotalNum() { + return totalNum; + } + + public void setTotalNum(int totalNum) { + this.totalNum = totalNum; + } + + public int getSuccessNum() { + return successNum; + } + + public void setSuccessNum(int successNum) { + this.successNum = successNum; + } + + public int getFailNum() { + return failNum; + } + + public void setFailNum(int failNum) { + this.failNum = failNum; + } + + public int getOperatorid() { + return operatorid; + } + + public void setOperatorid(int operatorid) { + this.operatorid = operatorid; + } + + public String getOperateDate() { + return operateDate; + } + + public void setOperateDate(String operateDate) { + this.operateDate = operateDate; + } + + public String getOperateTime() { + return operateTime; + } + + public void setOperateTime(String operateTime) { + this.operateTime = operateTime; + } + + public int getOperateType() { + return operateType; + } + + public void setOperateType(int operateType) { + this.operateType = operateType; + } + + public int getConfigId() { + return configId; + } + + public void setConfigId(int configId) { + this.configId = configId; + } + + public String getMessage() { + return message; + } + + public void setMessage(String message) { + this.message = message; + } + + public List getDetailDaoList() { + return detailDaoList; + } + + public void setDetailDaoList(List detailDaoList) { + this.detailDaoList = detailDaoList; + } +} diff --git a/src/main/java/weaver/chaoyang/he/zwl/common/formmode/SyncLoggerDetailDao.java b/src/main/java/weaver/chaoyang/he/zwl/common/formmode/SyncLoggerDetailDao.java new file mode 100644 index 0000000..0b3f429 --- /dev/null +++ b/src/main/java/weaver/chaoyang/he/zwl/common/formmode/SyncLoggerDetailDao.java @@ -0,0 +1,70 @@ +package weaver.chaoyang.he.zwl.common.formmode; + +/** + * 同步外部数据详细日志实体类 + * @author bleach + * @date 2021-11-15 + * @version 1.0 + */ +public class SyncLoggerDetailDao { + /** + * 操作的数据ID + */ + private int dataid = -1; + /** + * 数据类型 0-主表 1-明细 + */ + private int datatype = -1; + /** + * 操作类型 0-新增 1-修改 + */ + private int operateType = -1; + /** + * 操作的SQL语句 + */ + private String operateSQL = ""; + /** + * 执行结果 0-失败 1-成功 + */ + private int result = 0; + + public int getDataid() { + return dataid; + } + + public void setDataid(int dataid) { + this.dataid = dataid; + } + + public int getDatatype() { + return datatype; + } + + public void setDatatype(int datatype) { + this.datatype = datatype; + } + + public int getOperateType() { + return operateType; + } + + public void setOperateType(int operateType) { + this.operateType = operateType; + } + + public String getOperateSQL() { + return operateSQL; + } + + public void setOperateSQL(String operateSQL) { + this.operateSQL = operateSQL; + } + + public int getResult() { + return result; + } + + public void setResult(int result) { + this.result = result; + } +} diff --git a/src/main/java/weaver/chaoyang/he/zwl/common/formmode/SyncOtherDBToModeAction.java b/src/main/java/weaver/chaoyang/he/zwl/common/formmode/SyncOtherDBToModeAction.java new file mode 100644 index 0000000..e96bbc3 --- /dev/null +++ b/src/main/java/weaver/chaoyang/he/zwl/common/formmode/SyncOtherDBToModeAction.java @@ -0,0 +1,41 @@ +package weaver.chaoyang.he.zwl.common.formmode; + +import weaver.formmode.customjavacode.AbstractModeExpandJavaCode; +import weaver.general.Util; +import weaver.hrm.User; +import weaver.soa.workflow.request.RequestInfo; +import weaver.zwl.common.ToolUtil; + +import java.util.Map; + +public class SyncOtherDBToModeAction extends AbstractModeExpandJavaCode { + //当前类名称 + private String className = "SyncOtherDBToModeAction"; + private ToolUtil toolutil = new ToolUtil(); + + /** + * 执行模块扩展动作 + * @param param + * param包含(但不限于)以下数据 + * user 当前用户 + */ + public void doModeExpand(Map param) throws Exception { + toolutil.writeDebuggerLog(className, "---------------" + className + " BEGIN ---------------"); + + //当前用户信息 + User user = (User) param.get("user"); + int billid = -1;//数据id + //int modeid = -1;//模块id + //模块信息 + RequestInfo requestInfo = (RequestInfo) param.get("RequestInfo"); + if (requestInfo != null) { + billid = Util.getIntValue(requestInfo.getRequestid()); + //modeid = Util.getIntValue(requestInfo.getWorkflowid()); + + SyncOtherDBToModeUtil modeUtil = new SyncOtherDBToModeUtil(); + modeUtil.dataSync(billid,1,0); + } + + toolutil.writeDebuggerLog(className, "---------------" + className + " End ---------------"); + } +} diff --git a/src/main/java/weaver/chaoyang/he/zwl/common/formmode/SyncOtherDBToModeCron.java b/src/main/java/weaver/chaoyang/he/zwl/common/formmode/SyncOtherDBToModeCron.java new file mode 100644 index 0000000..4a68c97 --- /dev/null +++ b/src/main/java/weaver/chaoyang/he/zwl/common/formmode/SyncOtherDBToModeCron.java @@ -0,0 +1,32 @@ +package weaver.chaoyang.he.zwl.common.formmode; + +import weaver.general.Util; +import weaver.interfaces.schedule.BaseCronJob; +import weaver.zwl.common.ToolUtil; + + +public class SyncOtherDBToModeCron extends BaseCronJob { + private String className = "SyncOtherDBToModeCron"; + + private String keyvalue = ""; + + private ToolUtil toolUtil = new ToolUtil(); + + /** + * 实现父类方 + */ + public void execute() { + toolUtil.writeNewDebuggerLog(className, "-------------" + className + " BEGIN-----------------"); + + toolUtil.writeDebuggerLog(className, "--->keyvalue:[" + keyvalue + "]"); + + SyncOtherDBToModeUtil modeUtil = new SyncOtherDBToModeUtil(); + if(!"".equals(keyvalue)){ + modeUtil.dataSync(Util.getIntValue(keyvalue,-1),1,1); + }else{ + modeUtil.allDataSync(1,1); + } + + toolUtil.writeNewDebuggerLog(className, "-------------" + className + " END-----------------"); + } +} diff --git a/src/main/java/weaver/chaoyang/he/zwl/common/formmode/SyncOtherDBToModeUtil.java b/src/main/java/weaver/chaoyang/he/zwl/common/formmode/SyncOtherDBToModeUtil.java new file mode 100644 index 0000000..580c3cc --- /dev/null +++ b/src/main/java/weaver/chaoyang/he/zwl/common/formmode/SyncOtherDBToModeUtil.java @@ -0,0 +1,641 @@ +package weaver.chaoyang.he.zwl.common.formmode; + +import weaver.conn.RecordSet; +import weaver.conn.RecordSetDataSource; +import weaver.formmode.data.ModeDataIdUpdate; +import weaver.formmode.setup.ModeRightInfo; +import weaver.general.TimeUtil; +import weaver.general.Util; +import weaver.zwl.common.ToolUtil; + +import java.util.ArrayList; +import java.util.HashMap; +import java.util.List; +import java.util.Map; + +/** + * 同步其他数据库中的数据至表单建模 + * @author zhuweilin + * @date 2021-11-09 + * @version 1.0 新建版本 + */ +public class SyncOtherDBToModeUtil extends ToolUtil { + //当前类名称 + private String className = "SyncOtherDBToModeUtil"; + + /** + * 操作日志对应的建模模块ID + */ + private int OPERATOR_LOGGER_MODEID = -1; + /** + * 操作日志对应的建模表名称 + */ + private String OPERATOR_LOGGER_TABLE = "uf_syncOtherLog"; + + /** + * 构造方法 + */ + public SyncOtherDBToModeUtil(){ + this.OPERATOR_LOGGER_MODEID = Util.getIntValue(this.getSystemParamValue("SYNCOTHERDB_OPERATOR_LOGGER_MODEID"),0); + } + + /** + * 构造方法 + * @param logModeId 日志模块ID + */ + public SyncOtherDBToModeUtil(int logModeId){ + this.OPERATOR_LOGGER_MODEID = logModeId; + } + + /** + * 获取配置信息 + * @param modeid 对应的配置模块 + * @return 配置信息集合 + */ + private Map getConfigurationByModeId(int modeid){ + Map cmap = new HashMap<>(); + + String selectMainSQL = "select u.*,w.tablename from uf_othersysToMode u inner join modeinfo m on u.mid = m.id" + + " inner join workflow_bill w on w.id = m.formid" + + " where u.mid = ?"; + + this.writeDebuggerLog(className,"查询配置信息:[" + selectMainSQL + "]"); + + RecordSet rs = new RecordSet(); + + int mainKeyId = -1; + + if(rs.executeQuery(selectMainSQL,modeid)){ + if(rs.next()){ + mainKeyId = Util.getIntValue(rs.getString("id"),0); + //数据源标识 + String sourceid = Util.null2String(rs.getString("sourceid")); + //外部主表名称 + String outMainTbName = Util.null2String(rs.getString("outMainTbName")); + //外部主键字段名 + String outMainKeyField = Util.null2String(rs.getString("outMainKeyField")); + //数据同步方式 0-追加 1-更新 2-覆盖 + int method = Util.getIntValue(rs.getString("method"),0); + //操作类型 + int operateType = Util.getIntValue(rs.getString("operateType"),0); + //数据条件 + String dataCondition = Util.null2String(rs.getString("dataCondition")); + //内部主表名称 + String innerMainTable = Util.null2String(rs.getString("tablename")); + //内部建模主表外键字段ID + int innerMainKeyField = Util.getIntValue(rs.getString("innerMainKeyField"),0); + + if(!"".equals(dataCondition)){ + dataCondition = dataCondition.replace(" "," "); + dataCondition = dataCondition.replace("
"," "); + } + + cmap.put("configId",mainKeyId); + cmap.put("sourceid",sourceid); + cmap.put("outMainTbName",outMainTbName); + cmap.put("innerMainTable",innerMainTable); + cmap.put("outMainKeyField",outMainKeyField); + cmap.put("innerMainKeyField",innerMainKeyField); + cmap.put("method",method); + cmap.put("operateType",operateType); + cmap.put("dataCondition",dataCondition); + } + } + + if(mainKeyId > 0){ + //获取明细表映射关系 + String selectDetailSQL = "select * from uf_othersysToMode_dt1 where mainid = ?"; + + List> dtList = new ArrayList<>(); + if(rs.executeQuery(selectDetailSQL,mainKeyId)){ + while(rs.next()){ + //外部明细表名称 + String outDtName = Util.null2String(rs.getString("outDtName")); + //外部明细主键字段名 + String outKeyField = Util.null2String(rs.getString("outKeyField")); + //建模明细表序列 + int mDtIndex = Util.getIntValue(rs.getString("mDtIndex"),0); + //数据条件 + String dataCondition = Util.null2String(rs.getString("dataCondition")); + //建模明细表外键字段 + String mKeyField = Util.null2String(rs.getString("mKeyField")); + //是否覆盖更新 0-否 1-是 + int isCover = Util.getIntValue(rs.getString("isCover"),0); + //外部关联字段 + String outLinkField = Util.null2String(rs.getString("outLinkField")); + + if(!"".equals(dataCondition)){ + dataCondition = dataCondition.replace(" "," "); + dataCondition = dataCondition.replace("
"," "); + } + + Map detailmap = new HashMap<>(); + detailmap.put("outDtName",outDtName); + detailmap.put("outKeyField",outKeyField); + detailmap.put("mDtIndex",mDtIndex); + detailmap.put("dataCondition",dataCondition); + detailmap.put("mKeyField",mKeyField); + detailmap.put("isCover",isCover); + detailmap.put("outLinkField",outLinkField); + + dtList.add(detailmap); + } + } + + cmap.put("dtList",dtList); + + List> fieldList = new ArrayList<>(); + //获取详细的字段对应配置 + selectDetailSQL = "select dt.*,wb.fieldname,wb.viewtype,wb.detailtable,wb.fielddbtype from uf_othersysToMode_dt2 dt " + + "left join workflow_billfield wb on dt.mFieldID = wb.id where dt.mainid = ?"; + + if(rs.executeQuery(selectDetailSQL,mainKeyId)){ + while(rs.next()){ + //建模字段名称 + String m_fieldName = Util.null2String(rs.getString("fieldname")); + //建模字段所属 0-主表 1-明细表 + int m_viewtype = Util.getIntValue(rs.getString("viewtype"),0); + //字段所属明细表名 + String detialTableName = Util.null2String(rs.getString("detailtable")); + //字段类型 + String fielddbtype = Util.null2String(rs.getString("fielddbtype")).toLowerCase(); + + //数据库类型 0-文本 1-浮点 2-整型 + int dbType = 0; + + if(fielddbtype.contains("decimal") || fielddbtype.contains("float") || fielddbtype.contains("number")){ + dbType = 1; + }else if(fielddbtype.contains("int") || fielddbtype.contains("integer")){ + dbType = 2; + } + + //字段所在明细表序列 + int dtIndex = 0; + + if(m_viewtype == 1 && !"".equals(detialTableName)){ + dtIndex = Util.getIntValue(detialTableName.substring(detialTableName.indexOf("_dt") + 3),-1); + } + + //外部字段名称 + String o_fieldNmae = Util.null2String(rs.getString("outFieldName")); + + //转换规则 + int changerule = Util.getIntValue(rs.getString("changerule"),0); + //自定义规则 + String cussql = Util.null2String(rs.getString("cussql")); + //规则引用数据源 + int ruleDBSouce = Util.getIntValue(rs.getString("ruleDBSouce"),0); + + Map detailmap = new HashMap<>(); + detailmap.put("m_fieldName",m_fieldName); + detailmap.put("m_viewtype",m_viewtype); + detailmap.put("o_fieldNmae",o_fieldNmae); + detailmap.put("changerule",changerule); + detailmap.put("cussql",cussql); + detailmap.put("ruleDBSouce",ruleDBSouce); + detailmap.put("m_dtIndex",dtIndex); + detailmap.put("dbType",dbType); + + fieldList.add(detailmap); + } + cmap.put("fieldList",fieldList); + } + }else{ + return null; + } + + return cmap; + } + + /** + * 所有配置都进行同步 + * @param userid + * @param operateType + */ + public void allDataSync(int userid,int operateType){ + String selectSQL = "select * from uf_othersysToMode"; + + RecordSet rs = new RecordSet(); + + if(rs.executeQuery(selectSQL)){ + while (rs.next()){ + int mid = Util.getIntValue(rs.getString(1),-1); + + dataSync(mid,userid,operateType); + } + } + } + + /** + * 外部数据同步操作 + * @param modeid 建模模块ID + * @param userid 用户ID + * @param operateType 操作方式 0-手动 1-自动 + */ + public void dataSync(int modeid,int userid,int operateType){ + + SyncLoggerDao loggerDao = new SyncLoggerDao(); + loggerDao.setOperatorid(userid); + loggerDao.setOperateDate(TimeUtil.getCurrentDateString()); + loggerDao.setOperateTime(TimeUtil.getOnlyCurrentTimeString()); + loggerDao.setOperateType(operateType); + + //根据模块ID获取其对应的配置信息 + Map cmap = getConfigurationByModeId(modeid); + + if(cmap != null){ + //获取数据源标识 + String sourceid = Util.null2String(cmap.get("sourceid")); + //获取满足的数据条件 + String dataCondition = Util.null2String(cmap.get("dataCondition")); + + if(!"".equals(dataCondition)){ + dataCondition = ToDBC(dataCondition); + } + RecordSetDataSource rsds = new RecordSetDataSource(sourceid); + //外部主表名称 + String outMainTbName = Util.null2String(cmap.get("outMainTbName")); + + String selectOutMainDataSQL = "select * from " + outMainTbName; + + if(!"".equals(dataCondition)){ + selectOutMainDataSQL += " where " + dataCondition; + } + + RecordSet rs = new RecordSet(); + + RecordSetDataSource dt_rsds = new RecordSetDataSource(sourceid); + + //查询外部数据 + if(rsds.executeSql(selectOutMainDataSQL)){ + //配置ID + int configId = (int) cmap.get("configId"); + loggerDao.setConfigId(configId); + //内部表名称 + String innerMainTable = Util.null2String(cmap.get("innerMainTable")); + //内部主表主键字段ID + int innerMainKeyFieldId = (int) cmap.get("innerMainKeyField"); + //内部主表主键字段名称 + String innerMainKeyFieldName = getFieldNameByFieldid(innerMainKeyFieldId); + + //查询当前OA系统中已存在的数据 + Map oadata = getOAModeData(innerMainTable,innerMainKeyFieldName); + //数据同步方式 0-追加 1-更新 2-覆盖 + int dataMethod = (int) cmap.get("method"); + + //数据字段集合 + List> fieldList = (List>) cmap.get("fieldList"); + + List> dtList = (List>) cmap.get("dtList"); + + //外部主表主键字段名称 + String outMainKeyFieldName = Util.null2String(cmap.get("outMainKeyField")); + + ModeDataIdUpdate mdu = ModeDataIdUpdate.getInstance(); + + //总记录条数(主表) + int totalNum = rsds.getCounts(); + + loggerDao.setTotalNum(totalNum); + + int successNum = 0; + int failNum = 0; + + if(dataMethod == 2){//表示覆盖 + //先删除历史记录 + rs.executeUpdate("delete from " + innerMainTable + " where 1=1 "); + oadata.clear(); + } + + + List detailDaoList = new ArrayList<>(); + while(rsds.next()){ + //外部主表主键字段值 + String outMainKeyFieldValue = Util.null2String(rsds.getString(outMainKeyFieldName)); + + boolean isNewData = false; + int oaDataKeyId = -1; + if(oadata.containsKey(outMainKeyFieldValue)){//该记录已存在 + oaDataKeyId = oadata.get(outMainKeyFieldValue); + + if(dataMethod == 0){//表示追加,已存在的记录不进行处理 + continue; + } + + }else{//该记录不存在 + oaDataKeyId = mdu.getModeDataNewId(innerMainTable, modeid, 1, 1, TimeUtil.getCurrentDateString(), TimeUtil.getOnlyCurrentTimeString()); + isNewData = true; + } + + //主表数据操作 + String[] sqlArray = genarateOperateSQL(sourceid,rsds,fieldList,0); + + String updateMainSQL = "update " + innerMainTable + " set modedatacreater=1" + sqlArray[0] + " where id = " + oaDataKeyId; + + SyncLoggerDetailDao detailDao = new SyncLoggerDetailDao(); + + detailDao.setDataid(oaDataKeyId); + detailDao.setDatatype(0); + detailDao.setOperateType(isNewData ? 0 : 1); + detailDao.setOperateSQL(updateMainSQL); + + if(rs.executeUpdate(updateMainSQL)){ + detailDao.setResult(1); + successNum++; + //查询对应的明细操作 + if(dtList != null && dtList.size() > 0){ + for(Map detailmap : dtList){ + //是否覆盖 + int isCover = (int) detailmap.get("isCover"); + //外部明细表 + String outDtName = (String) detailmap.get("outDtName"); + //外部关联字段 + String outLinkField = (String) detailmap.get("outLinkField"); + //外部主键字段名称 + String outKeyField = (String) detailmap.get("outKeyField"); + //数据条件 + String dtDataCondition = (String) detailmap.get("dataCondition"); + //建模明细表序列 + int mDtIndex = (int) detailmap.get("mDtIndex"); + //建模明细表外键字段 + String mKeyField = (String) detailmap.get("mKeyField"); + + String mDtTable = innerMainTable + "_dt" + mDtIndex; + if(isCover == 1 && !isNewData){//说明是覆盖更新,则需要将历史记录清空,进行重新写入 + rs.executeUpdate("delete from " + mDtTable + " where mainid = ?",oaDataKeyId); + } + + //查询外部明细表操作 + String selectOutDetail = "select * from " + outDtName + " where " + outLinkField + "='" + outMainKeyFieldValue + "'"; + + if(!"".equals(dtDataCondition)){ + selectOutDetail += dtDataCondition; + } + this.writeDebugLog("执行查询外部明细表记录SQL:[" + selectOutDetail + "]"); + if(dt_rsds.executeSql(selectOutDetail)){ + while(dt_rsds.next()){ + SyncLoggerDetailDao dtDetailDao = new SyncLoggerDetailDao(); + dtDetailDao.setDatatype(1); + //外部主键字段值 + String outKeyFieldValue = Util.null2String(dt_rsds.getString(outKeyField)); + + String[] dtSQLArray = genarateOperateSQL(sourceid,dt_rsds,fieldList,mDtIndex); + + String dtTableOperateSQL = ""; + + if(isNewData){//主表为新记录 + dtDetailDao.setOperateType(0); + //明细表进行写入 + dtTableOperateSQL = "insert into " + mDtTable + "(mainid" + dtSQLArray[1] + ") values (" + oaDataKeyId + dtSQLArray[2] + ")"; + }else { + if (isCover == 1) { + dtDetailDao.setOperateType(0); + dtTableOperateSQL = "insert into " + mDtTable + "(mainid" + dtSQLArray[1] + ") values (" + oaDataKeyId + dtSQLArray[2] + ")"; + } else { + dtDetailDao.setOperateType(1); + //明细表更新SQL + dtTableOperateSQL = "update " + mDtTable + " set id=id" + dtSQLArray[0] + " where " + mKeyField + " = '" + outKeyFieldValue + "'"; + } + } + dtDetailDao.setOperateSQL(dtTableOperateSQL); + if(rs.executeUpdate(dtTableOperateSQL)){ + dtDetailDao.setResult(1); + this.writeDebugLog("建模明细表操作成功,成功SQL:[" + dtTableOperateSQL + "]"); + }else{ + dtDetailDao.setResult(0); + this.writeErrorLog("操作建模明细表失败,失败SQL:[" + updateMainSQL + "]"); + } + + detailDaoList.add(dtDetailDao); + } + }else{ + this.writeErrorLog("查询外部明细表数据失败,失败SQL:[" + updateMainSQL + "]"); + } + } + }else{ + //this.writeDebugLog("无明细操作表需要操作!"); + } + + //新插入的记录,权限重构 + setModeRight(1,modeid,oaDataKeyId); + }else{//数据操作失败 + failNum++; + detailDao.setResult(1); + this.writeErrorLog("外部主表数操作失败,失败SQL:[" + updateMainSQL + "]"); + + if(isNewData){//删除冗余数据 + rs.executeUpdate("delete from " + innerMainTable + " where id = ?",oaDataKeyId); + } + } + + detailDaoList.add(detailDao); + } + + loggerDao.setSuccessNum(successNum); + loggerDao.setFailNum(failNum); + }else{ + loggerDao.setMessage("外部主表数据查询失败,失败SQL:[" + selectOutMainDataSQL + "]"); + this.writeErrorLog("外部主表数据查询失败,失败SQL:[" + selectOutMainDataSQL + "]"); + } + }else{ + loggerDao.setMessage("该模块对应的配置信息不存在,未进行同步操作!"); + this.writeDebugLog("该模块对应的配置信息不存在!"); + } + + //同步日志操作 + operateLogger(loggerDao); + } + + /** + * SQL语句拼接操作 + * @param sourceid 数据源标识 + * @param rsds 外部数据某行数据的数据集 + * @param fieldList 字段详细配置信息集合 + * @param modeDtIndex 模块明细序列 + * @return + */ + private String[] genarateOperateSQL(String sourceid,RecordSetDataSource rsds,List> fieldList,int modeDtIndex){ + String[] operateArray = new String[3]; + + StringBuffer updateSQL = new StringBuffer(); + StringBuffer insertCol = new StringBuffer(); + StringBuffer insertVal = new StringBuffer(); + + for(Map detailmap : fieldList){ + //获取模块字段所属 + int m_dtIndex = (int) detailmap.get("m_dtIndex"); + if(m_dtIndex != modeDtIndex){ + continue; + } + + //获取模块字段名称 + String m_fieldName = (String) detailmap.get("m_fieldName"); + //外部表字段名称 + String o_fieldNmae = (String) detailmap.get("o_fieldNmae"); + //自定义规则 + String cussql = (String) detailmap.get("cussql"); + + String fieldvalue = ""; + if(!"".equals(o_fieldNmae)){ + fieldvalue = Util.null2String(rsds.getString(o_fieldNmae)); + } + + int changerule = (int) detailmap.get("changerule"); + + int ruleDBSouce = (int) detailmap.get("ruleDBSouce"); + + switch (changerule){ + case 0://不转换 + break; + case 1://系统日期 + fieldvalue = TimeUtil.getCurrentDateString(); + break; + case 2://系统日期时间 + fieldvalue = TimeUtil.getCurrentTimeString(); + break; + case 3://固定值 + fieldvalue = cussql; + break; + case 4://自定义SQL + if(ruleDBSouce == 1){//外部数据源 + fieldvalue = getValueByChangeRule(cussql,fieldvalue,"",0,sourceid); + }else{ + fieldvalue = getValueByChangeRule(cussql,fieldvalue); + } + break; + default: + break; + } + + if("".equals(fieldvalue)){//若最终要操作的值为空值 + //int dbType = (int) detailmap.get("dbType"); + insertCol.append(",").append(m_fieldName); + insertVal.append(",NULL"); + updateSQL.append(",").append(m_fieldName).append("=NULL"); + + }else{ + fieldvalue = fieldvalue.replace("'","''"); + + insertCol.append(",").append(m_fieldName); + insertVal.append(",'").append(fieldvalue).append("'"); + + updateSQL.append(",").append(m_fieldName).append("='").append(fieldvalue).append("'"); + } + } + + operateArray[0] = updateSQL.toString(); + operateArray[1] = insertCol.toString(); + operateArray[2] = insertVal.toString(); + + return operateArray; + } + + /** + * 获取某个建模表OA中已存在的数据 + * @param tbName 建模表名 + * @param keyField 外键字段 + * @return 数据集合 + */ + private Map getOAModeData(String tbName,String keyField){ + Map oadata = new HashMap<>(); + + String selectSQL = "select id," + keyField + " from " + tbName; + + RecordSet rs = new RecordSet(); + + if(rs.executeQuery(selectSQL)){ + while(rs.next()){ + oadata.put(Util.null2String(rs.getString(2)),Util.getIntValue(rs.getString(1),0)); + } + } + + return oadata; + } + + /** + * 操作日志 + * @param loggerDao + */ + private void operateLogger(SyncLoggerDao loggerDao){ + + ModeDataIdUpdate mdu = ModeDataIdUpdate.getInstance(); + //获取新的数据ID + int dataid = mdu.getModeDataNewId(OPERATOR_LOGGER_TABLE, OPERATOR_LOGGER_MODEID, 1, 1, TimeUtil.getCurrentDateString(), TimeUtil.getOnlyCurrentTimeString()); + + if(dataid > 0){ + String message = loggerDao.getMessage(); + + if(!"".equals(message)){ + message = message.replace("'","''"); + } + + //执行更新操作 + String updateLogSQL = "update " + OPERATOR_LOGGER_TABLE + " set configid = " + loggerDao.getConfigId() + ",totalNum = " + loggerDao.getTotalNum() + "," + + "successNum = " + loggerDao.getSuccessNum() + ",failNum = " + loggerDao.getFailNum() + ",operatorid = " + loggerDao.getOperatorid() + "," + + "operateDate = '" + loggerDao.getOperateDate() + "',operateTime = '" + loggerDao.getOperateTime() + "',operateType = '" + loggerDao.getOperateType() + "'," + + "message = '" + message + "' where id = " +dataid; + + RecordSet rs = new RecordSet(); + + if(rs.executeUpdate(updateLogSQL)){ + //获取明细记录 + List detailDaoList = loggerDao.getDetailDaoList(); + + if(detailDaoList.size() > 0){ + for(SyncLoggerDetailDao detailDao : detailDaoList){ + String operateSQL = detailDao.getOperateSQL(); + + if(!"".equals(operateSQL)){ + operateSQL = operateSQL.replace("'","''"); + } + //插入明细操作SQL + String insert_detail = "insert into " + OPERATOR_LOGGER_TABLE + "_dt1 (mainid,dataid,datatype,operateType,operateSQL,result) values (" + + dataid + "," + detailDao.getDataid() + "," + detailDao.getDatatype() + "," + detailDao.getOperateType() + ",'" + operateSQL + "'," + + detailDao.getResult() + ")"; + + rs.executeUpdate(insert_detail); + } + } + + //数据重构 + setModeRight(1,OPERATOR_LOGGER_MODEID,dataid); + }else{ + //删除冗余数据 + rs.executeUpdate("delete from " + OPERATOR_LOGGER_TABLE + " where id = ?",dataid); + } + } + } + + /** + * 给新插入的数据进行赋权操作 + * @param creater + * @param modeid + * @param sourceid + */ + private void setModeRight(int creater,int modeid,int sourceid){ + + ModeRightInfo moderightinfo = new ModeRightInfo(); + + moderightinfo.setNewRight(true); + + moderightinfo.editModeDataShare(creater,modeid,sourceid);//新建的时候添加共享 + } + + /** + * 全角转半角 + * @param input + * @return + */ + public String ToDBC(String input) { + char c[] = input.toCharArray(); + for (int i = 0; i < c.length; i++) { + if (c[i] == '\u3000') { + c[i] = ' '; + } else if (c[i] > '\uFF00' && c[i] < '\uFF5F') { + c[i] = (char) (c[i] - 65248); + } + } + String returnString = new String(c); + return returnString; + } +} diff --git a/src/main/java/weaver/chaoyang/he/zwl/common/logging/Log4JLogger.java b/src/main/java/weaver/chaoyang/he/zwl/common/logging/Log4JLogger.java new file mode 100644 index 0000000..440ee15 --- /dev/null +++ b/src/main/java/weaver/chaoyang/he/zwl/common/logging/Log4JLogger.java @@ -0,0 +1,91 @@ +package weaver.chaoyang.he.zwl.common.logging; + +import weaver.zwl.common.logging.Logger; + +/** + * 写日志(log4j) + * @date 2020-03-10 + * @version 1.0 + */ +public class Log4JLogger implements Logger { + + private org.apache.log4j.Logger log; + //类名 + private String classname; + + @Override + public String getClassname() { + return classname; + } + + @Override + public void setClassname(String classname) { + this.classname = classname; + } + + @Override + public boolean isDebugEnabled() { + return log.isDebugEnabled(); + } + + @Override + public boolean isInfoEnabled() { + return log.isInfoEnabled(); + } + + @Override + public void debug(Object message) { + String method = Thread.currentThread().getStackTrace()[2].getMethodName(); + log.debug(classname+"."+method+"() - "+message); + } + + @Override + public void debug(Object message, Throwable exception) { + String method = Thread.currentThread().getStackTrace()[2].getMethodName(); + log.debug(classname+"."+method+"() - "+message, exception); + } + + @Override + public void info(Object message) { + String method = Thread.currentThread().getStackTrace()[2].getMethodName(); + log.info(classname+"."+method+"() - "+message); + } + + @Override + public void info(Object message, Throwable exception) { + String method = Thread.currentThread().getStackTrace()[2].getMethodName(); + log.info(classname+"."+method+"() - "+message, exception); + } + + @Override + public void warn(Object message) { + String method = Thread.currentThread().getStackTrace()[2].getMethodName(); + log.warn(classname+"."+method+"() - "+message); + } + + @Override + public void warn(Object message, Throwable exception) { + String method = Thread.currentThread().getStackTrace()[2].getMethodName(); + log.warn(classname+"."+method+"() - "+message, exception); + } + + @Override + public void error(Object message) { + String method = Thread.currentThread().getStackTrace()[2].getMethodName(); + log.error(classname+"."+method+"() - "+message); + } + + @Override + public void error(Object message, Throwable exception) { + String method = Thread.currentThread().getStackTrace()[2].getMethodName(); + log.error(classname+"."+method+"() - "+message, exception); + } + + @Override + public void init(String name) { + if("".equals(name)) { + name = "cuslog"; + } + log = org.apache.log4j.Logger.getLogger(name); + } +} diff --git a/src/main/java/weaver/chaoyang/he/zwl/common/logging/Logger.java b/src/main/java/weaver/chaoyang/he/zwl/common/logging/Logger.java new file mode 100644 index 0000000..4582b9c --- /dev/null +++ b/src/main/java/weaver/chaoyang/he/zwl/common/logging/Logger.java @@ -0,0 +1,78 @@ +package weaver.chaoyang.he.zwl.common.logging; + +/** + * 日志接口(写) + * + * @author zwl + * @date 2020-03-10 + */ +public interface Logger extends weaver.integration.logging.Logger { + + public boolean isDebugEnabled(); + + /** + * 打印debug日志 + * @param message 消息 + */ + public void debug(Object message); + + /** + * 打印debug日志 + * @param message 消息 + * @param exception 异常 + */ + public void debug(Object message, Throwable exception); + + public boolean isInfoEnabled(); + + /** + * 打印info日志 + * @param message 消息 + */ + public void info(Object message); + + + /** + * 打印info日志 + * @param message 消息 + * @param exception 异常 + */ + public void info(Object message, Throwable exception); + + /** + * 打印warn日志 + * @param message 消息 + */ + public void warn(Object message); + + /** + * 打印warn日志 + * @param message 消息 + * @param exception 异常 + */ + public void warn(Object message, Throwable exception); + + /** + * 打印error日志 + * @param message + */ + public void error(Object message); + + /** + * 打印error日志 + * @param message 消息 + * @param exception 异常 + */ + public void error(Object message, Throwable exception); + + public String getClassname(); + + public void setClassname(String classname); + + /** + * 初始化 + * + * @param name logger名称 + */ + public void init(String name); +} diff --git a/src/main/java/weaver/chaoyang/he/zwl/common/logging/LoggerFactory.java b/src/main/java/weaver/chaoyang/he/zwl/common/logging/LoggerFactory.java new file mode 100644 index 0000000..62ace9b --- /dev/null +++ b/src/main/java/weaver/chaoyang/he/zwl/common/logging/LoggerFactory.java @@ -0,0 +1,50 @@ +package weaver.chaoyang.he.zwl.common.logging; + + +import weaver.zwl.common.logging.Log4JLogger; +import weaver.zwl.common.logging.Logger; + +/** + * 日志工厂类 + * + * @author zwl + * @date 2020-03-10 + * @version 1.0 + */ +public class LoggerFactory { + private static final String loggerName = "cus"; + public static Logger getLogger(String LogName, String clazz) { + if("".equals(LogName)) { + LogName = loggerName; + } + Logger logger = new Log4JLogger(); + logger.setClassname(clazz); + logger.init(LogName); + return logger; + } + /** + * 获取指定类的logger对象 + * @param clazz + * @return + */ + public static Logger getLogger(Class clazz) { + return getLogger(loggerName,clazz.getCanonicalName()); + } + /** + * 获取指定类的logger对象 + * @param className + * @return + */ + public static Logger getLogger(String className) { + return getLogger(loggerName,className); + } + /** + * 获取未指定指定类的logger对象 + * @param + * @return + */ + public static Logger getLogger() { + String className = Thread.currentThread().getStackTrace()[2].getClassName(); + return getLogger(loggerName, className); + } +} diff --git a/src/main/java/weaver/chaoyang/he/zwl/common/workflow/JsonType.java b/src/main/java/weaver/chaoyang/he/zwl/common/workflow/JsonType.java new file mode 100644 index 0000000..256d81c --- /dev/null +++ b/src/main/java/weaver/chaoyang/he/zwl/common/workflow/JsonType.java @@ -0,0 +1,24 @@ +package weaver.chaoyang.he.zwl.common.workflow; + +/** + * JSON类型 对应配置值 + */ +public class JsonType { + /** + * 文本 - 字符串 + */ + public static final int JSON_TEXT_STRING = 0; + + /** + * 文本 - 数组 + */ + public static final int JSON_TEXT_ARRAY = 1; + /** + * 对象 + */ + public static final int JSON_OBJECT = 2; + /** + * 数组 + */ + public static final int JSON_ARRAY = 3; +} diff --git a/src/main/java/weaver/chaoyang/he/zwl/common/workflow/WorkflowDataToJson.java b/src/main/java/weaver/chaoyang/he/zwl/common/workflow/WorkflowDataToJson.java new file mode 100644 index 0000000..31d6201 --- /dev/null +++ b/src/main/java/weaver/chaoyang/he/zwl/common/workflow/WorkflowDataToJson.java @@ -0,0 +1,311 @@ +package weaver.chaoyang.he.zwl.common.workflow; + +import com.alibaba.fastjson.JSONArray; +import com.alibaba.fastjson.JSONObject; +import com.google.common.base.Strings; +import weaver.conn.RecordSet; +import weaver.general.TimeUtil; +import weaver.general.Util; +import weaver.workflow.workflow.WorkflowVersion; +import weaver.zwl.common.ToolUtil; + +import java.util.ArrayList; +import java.util.HashMap; +import java.util.List; +import java.util.Map; + +/** + * OA流程数据根据配置信息转成JSON对象 + * @author bleach + * @version 1.0 + */ +public class WorkflowDataToJson extends ToolUtil { + + + /** + * 根据流程类型ID获取其对应的配置信息 + * @param workflowId 流程类型ID + * @param cusParam 自定义配置参数值 + * @return 配置信息集合 + */ + public Map getConfigurationByWorkflowId(String workflowId,String cusParam){ + Map configMap = new HashMap<>(); + + //获取当前流程类型对应的所有版本ID + String allWfIds = WorkflowVersion.getAllVersionStringByWFIDs(workflowId); + + RecordSet rs = new RecordSet(); + + //查询配置信息SQL(主表) + String selectMainSQL = "select * from uf_wfdataToJson where wfid in (" + allWfIds + ")"; + + if(!"".equals(cusParam)){ + selectMainSQL += " and cusparamValue = '" + cusParam + "'"; + }else{ + selectMainSQL += " and (cusparamValue is null or cusparamValue = '')"; + } + + int mainKeyId = -1; + if(rs.executeQuery(selectMainSQL)){ + if(rs.next()){ + mainKeyId = Util.getIntValue(rs.getString("id"),-1); + + //自定义数据条件 + String dataCondition = Util.null2String(rs.getString("dataCondition")); + + if(!Strings.isNullOrEmpty(dataCondition)){ + dataCondition = dataCondition.replace(" "," "); + dataCondition = dataCondition.replace("
"," "); + } + + //TODO 防止数据条件的中的SQL出现全角字符 + + configMap.put("mainKeyId",mainKeyId); + configMap.put("dataCondition",dataCondition); + } + } + + if(mainKeyId > 0){ + + List> fieldList = new ArrayList<>(); + //查询JSON与流程字段映射(明细表1) + String selectDetailSQL = "select dt.*,wb.fieldName,wb.viewType,wb.detailTable" + + " from uf_wfdataToJson_dt1 dt left join workflow_billfield wb on dt.wfField = wb.id where dt.mainid = ?"; + + if(rs.executeQuery(selectDetailSQL,mainKeyId)){ + while(rs.next()){ + //JSON名称 + String jsonName = Util.null2String(rs.getString("jsonName")); + //JSON类型 + int jsonType = Util.getIntValue(rs.getString("jsonType"),0); + //父节点名称 + String parentNode = Util.null2String(rs.getString("parentNode")); + //流程表单字段名称 + String fieldName = Util.null2String(rs.getString("fieldName")); + //流程表单字段所属 + int viewType = Util.getIntValue(rs.getString("viewType"),0); + //流程表单字段所在明细表名称 + String detailTable = Util.null2String(rs.getString("detailTable")); + //流程表单字段所在明细表序列 + int dtIndex = 0; + //转换规则 + int changeRule = Util.getIntValue(rs.getString("changeRule"),0); + //自定义规则 + String cusSQL = Util.null2String(rs.getString("cusSQL")); + + if(viewType == 1 && !Strings.isNullOrEmpty(detailTable)){ + dtIndex = Util.getIntValue(detailTable.substring(detailTable.indexOf("_dt") + 3),-1); + } + + Map detailMap = new HashMap<>(); + detailMap.put("jsonName",jsonName); + detailMap.put("jsonType",jsonType); + detailMap.put("parentNode",parentNode); + detailMap.put("fieldName",fieldName); + detailMap.put("viewType",viewType); + detailMap.put("detailTable",detailTable); + detailMap.put("dtIndex",dtIndex); + detailMap.put("changeRule",changeRule); + detailMap.put("cusSQL",cusSQL); + fieldList.add(detailMap); + } + } + + configMap.put("fieldList",fieldList); + + List> jsonArrayDtList = new ArrayList<>(); + //查询JSON数组与明细表映射关系(明细表2) + selectDetailSQL = "select * from uf_wfdataToJson_dt2 where mainid = ?"; + + if(rs.executeQuery(selectDetailSQL,mainKeyId)){ + while (rs.next()){ + //JSON数组名称 + String jsonArrayName = Util.null2String(rs.getString("arrayJsonName")); + //对应流程明细表序列 + int dtIndex = Util.getIntValue(rs.getString("dtIndex"),0); + //数据条件 + String dtCondition = Util.null2String(rs.getString("dtCondition")); + + if(!Strings.isNullOrEmpty(dtCondition)){ + dtCondition = dtCondition.replace(" "," "); + dtCondition = dtCondition.replace("
"," "); + } + //TODO 防止数据条件的中的SQL出现全角字符 + + Map detailMap = new HashMap<>(); + detailMap.put("jsonArrayName",jsonArrayName); + detailMap.put("dtIndex",dtIndex); + detailMap.put("dtCondition",dtCondition); + + jsonArrayDtList.add(detailMap); + } + } + + configMap.put("jsonArrayDtList",jsonArrayDtList); + }else{//说明该流程类型该参数对应的配置不存在 + return null; + } + + return configMap; + } + + /** + * 根据配置递归生成JSON对象 + * @param baseArray 流程基础信息数组 [请求ID,请求标题,请求编号,流程表单名称,流程主表主键ID] + * @param parentNode 父节点名称 + * @param rs 流程主表数据集 + * @param rs_detail 流程明细表某行记录数据集 + * @param fieldList 字段配置信息集合 + * @param arrayDtList 明细表与JSONArray映射配置集合 + * @param dtIndex 明细表序列 + * @return + */ + public JSONObject recursionGenerateJSON(String[] baseArray,String parentNode,RecordSet rs,RecordSet rs_detail,List> fieldList,List> arrayDtList,int dtIndex,int sequence){ + JSONObject obj = new JSONObject(); + + if(fieldList != null && fieldList.size() > 0){ + for(Map fieldMap : fieldList){ + //父节点名称 + String _parentNode = (String) fieldMap.get("parentNode"); + + if(!parentNode.equals(_parentNode)){ + continue; + } + + //字段所属 + int _viewType = (int) fieldMap.get("viewType"); + //流程字段所在明细序列 + int _dtIndex = (int) fieldMap.get("dtIndex"); + + if(_viewType == 1 && _dtIndex != dtIndex){ + continue; + } + + String _jsonName = (String) fieldMap.get("jsonName"); + //当前节点类型 + int _jsonType = (int) fieldMap.get("jsonType"); + + if (_jsonType == JsonType.JSON_TEXT_STRING){//文本 - 文本 + obj.put(_jsonName,getFieldValue(baseArray,fieldMap,rs,rs_detail,sequence)); + }else if(_jsonType == JsonType.JSON_TEXT_ARRAY){//文本 - 数组 + JSONArray array = new JSONArray(); + array.add(getFieldValue(baseArray,fieldMap,rs,rs_detail,sequence)); + obj.put(_jsonName,array); + }else if(_jsonType == JsonType.JSON_OBJECT){//对象 + obj.put(_jsonName,recursionGenerateJSON(baseArray,_jsonName,rs,rs_detail,fieldList,arrayDtList,dtIndex,sequence)); + }else if(_jsonType == JsonType.JSON_ARRAY){//数组 + JSONArray array = new JSONArray(); + + if(arrayDtList != null && arrayDtList.size() > 0) { + for (Map dtMap : arrayDtList) { + //JSON数组名称 + String jsonArrayName = (String) dtMap.get("jsonArrayName"); + + if(!_jsonName.equals(jsonArrayName)){ + continue; + } + + //明细序列ID + int _dtx = (int) dtMap.get("dtIndex"); + + String selectDetailSQl = "select * from " + baseArray[3] + "_dt" + _dtx + " where mainid = ?"; + + int rowNum = 0; + if(rs_detail.executeQuery(selectDetailSQl,baseArray[4])){ + while(rs_detail.next()){ + JSONObject detailJson = recursionGenerateJSON(baseArray,_jsonName,rs,rs_detail,fieldList,arrayDtList,_dtx,++rowNum); + + array.add(detailJson); + } + } + } + } + } + + } + } + + return obj; + } + + /** + * 根据配置获取最终需要传输的字段值 + * @param baseArray 流程基础信息数组 + * @param fieldMap 字段配置信息集合 + * @param rs 流程主表数据集 + * @param rs_detail 明细表某行记录数据集 + * @param sequence 明细序列号 + * @return + */ + private String getFieldValue(String[] baseArray,Map fieldMap,RecordSet rs,RecordSet rs_detail,int sequence){ + String fieldValue = ""; + //字段名称 + String _fieldName = (String) fieldMap.get("fieldName"); + //字段所属 + int _viewType = (int) fieldMap.get("viewType"); + + //转换规则 + int _changeRule = (int) fieldMap.get("changeRule"); + //自定义SQL + String _cusSQL = (String) fieldMap.get("cusSQL"); + + if(!Strings.isNullOrEmpty(fieldValue)){ + if(_viewType == 1 && rs_detail != null){ + fieldValue = Util.null2String(rs_detail.getString(_fieldName)); + }else if(_viewType == 0){ + fieldValue = Util.null2String(rs.getString(_fieldName)); + } + } + + switch (_changeRule){ + case 0 ://不转换 + break; + case 1 ://流程请求ID + fieldValue = baseArray[0]; + break; + case 2 ://流程请求标题 + fieldValue = baseArray[1]; + break; + case 3 ://流程请求编号 + fieldValue = baseArray[2]; + break; + case 4 ://系统日期 + fieldValue = TimeUtil.getCurrentDateString(); + break; + case 5 ://系统日期时间 + fieldValue = TimeUtil.getCurrentTimeString(); + break; + case 6 ://固定值 + fieldValue = _cusSQL; + break; + case 7 ://明细序列 + fieldValue = String.valueOf(sequence); + break; + case 8://自定义转换 + int detailKeyId = -1; + if(!Strings.isNullOrEmpty(_cusSQL) && _cusSQL.indexOf("{dt.id}") > 0 && rs_detail != null){ + detailKeyId = Util.getIntValue(rs_detail.getString("id"),-1); + } + fieldValue = getValueByChangeRule(_cusSQL,fieldValue,baseArray[0],detailKeyId); + break; + } + + return fieldValue; + } + + /** + * 调用接口信息,获取接口返回信息 + * @param object 发送的JSON对象 + * @param type 接口类型 0-预算校验 1-预算扣除 2-预算释放 + */ + public void callInterface(int type,JSONObject object){ + String interfaceURL = ""; + if(type == 0){ + interfaceURL = this.getSystemParamValue(""); + }else if(type == 1){ + + }else if(type == 2){ + + } + } +}