提交内容:获取电子回单附件URL

备注:获取电子回单附件URL
提交人:邹江涛
This commit is contained in:
zoujiangtao 2024-12-24 16:52:25 +08:00
parent f19bc810ae
commit 4f3165d808
3 changed files with 81 additions and 199 deletions

View File

@ -3,6 +3,7 @@ package shkd.sys.sys.mservice;
import com.alibaba.fastjson.JSON; import com.alibaba.fastjson.JSON;
import com.alibaba.fastjson.JSONArray; import com.alibaba.fastjson.JSONArray;
import com.alibaba.fastjson.JSONObject; import com.alibaba.fastjson.JSONObject;
import kd.bos.bill.BillShowParameter;
import kd.bos.cache.CacheFactory; import kd.bos.cache.CacheFactory;
import kd.bos.cache.TempFileCache; import kd.bos.cache.TempFileCache;
import kd.bos.context.RequestContext; import kd.bos.context.RequestContext;
@ -11,16 +12,21 @@ import kd.bos.dataentity.entity.DynamicObjectCollection;
import kd.bos.dataentity.entity.LocaleString; import kd.bos.dataentity.entity.LocaleString;
import kd.bos.dataentity.resource.ResManager; import kd.bos.dataentity.resource.ResManager;
import kd.bos.dataentity.utils.StringUtils; import kd.bos.dataentity.utils.StringUtils;
import kd.bos.entity.MainEntityType;
import kd.bos.exception.KDBizException; import kd.bos.exception.KDBizException;
import kd.bos.form.IFormView;
import kd.bos.logging.Log; import kd.bos.logging.Log;
import kd.bos.logging.LogFactory; import kd.bos.logging.LogFactory;
import kd.bos.metadata.dao.MetadataDao; import kd.bos.metadata.dao.MetadataDao;
import kd.bos.mvc.FormConfigFactory;
import kd.bos.mvc.SessionManager;
import kd.bos.orm.query.QCP; import kd.bos.orm.query.QCP;
import kd.bos.orm.query.QFilter; import kd.bos.orm.query.QFilter;
import kd.bos.print.core.service.PrtAttach; import kd.bos.print.core.service.PrtAttach;
import kd.bos.print.matchtpl.MatcherTpl; import kd.bos.print.matchtpl.MatcherTpl;
import kd.bos.print.matchtpl.ViewType; import kd.bos.print.matchtpl.ViewType;
import kd.bos.servicehelper.BusinessDataServiceHelper; import kd.bos.servicehelper.BusinessDataServiceHelper;
import kd.bos.servicehelper.MetadataServiceHelper;
import kd.bos.servicehelper.PrintServiceHelper; import kd.bos.servicehelper.PrintServiceHelper;
import kd.bos.servicehelper.QueryServiceHelper; import kd.bos.servicehelper.QueryServiceHelper;
import kd.bos.servicehelper.print.NotePrintService; import kd.bos.servicehelper.print.NotePrintService;
@ -307,10 +313,12 @@ public class ApiService {
} }
dynamicObjects.add(dynamic); dynamicObjects.add(dynamic);
logger.info("付款处理(支付结果) → BIP推送接口 → 成功\n成功单据编号{}\n成功请求体{}\n推送成功接口返回数据{}", dynamic.getString("billno"), saveRequestBody, saveResponseBody); logger.info("付款处理(支付结果) → BIP推送接口 → 成功\n成功单据编号{}\n成功请求体{}\n推送成功接口返回数据{}",
dynamic.getString("billno"), saveRequestBody, saveResponseBody);
result = "推送 → 付款处理(支付结果) → 成功"; result = "推送 → 付款处理(支付结果) → 成功";
} else { } else {
logger.info("付款处理(支付结果) → BIP推送接口 → 失败\n失败单据编号{}\n失败请求体{}\n推送失败接口返回数据{}", dynamic.getString("billno"), saveRequestBody, saveResponseBody); logger.info("付款处理(支付结果) → BIP推送接口 → 失败\n失败单据编号{}\n失败请求体{}\n推送失败接口返回数据{}",
dynamic.getString("billno"), saveRequestBody, saveResponseBody);
result = "推送 → 付款处理(支付结果) → 失败"; result = "推送 → 付款处理(支付结果) → 失败";
} }
break; break;
@ -322,16 +330,21 @@ public class ApiService {
if ("200".equals(code)) { if ("200".equals(code)) {
dynamic.set("shkd_pushstatus", "已推送"); dynamic.set("shkd_pushstatus", "已推送");
dynamicObjects.add(dynamic); dynamicObjects.add(dynamic);
logger.info("电子回单查询 → BIP推送接口 → 成功\n成功单据编号{}\n成功请求体{}\n推送成功接口返回数据{}", dynamic.getString("billno"), saveRequestBody, saveResponseBody); logger.info("电子回单查询 → BIP推送接口 → 成功\n成功单据编号{}\n成功请求体{}\n推送成功接口返回数据{}",
dynamic.getString("billno"), saveRequestBody, saveResponseBody);
result = "推送 → 电子回单查询 → 成功"; result = "推送 → 电子回单查询 → 成功";
/*List<String> errMsgList = new ArrayList<>(); DynamicObject dynamicObject = BusinessDataServiceHelper.loadSingle(dynamic.getPkValue(), dynamic.getDynamicObjectType().getName());
String pdfUrl = getPdfUrl(view.getPageId(), receipts, errMsgList); IFormView viewByDynamicObj = createViewByDynamicObj(dynamicObject);
if (!errMsgList.isEmpty()) { List<String> errMsgList = new ArrayList<>();
view.showErrorNotification(String.join(",", errMsgList)); DynamicObjectCollection receipts = QueryServiceHelper.query("bei_elecreceipt", "id,bank," +
}*/ "fileflag,filepath,biztype,bankcheckflag,fileserverurl,tcpurl,uploadfilename,username,password," +
"bank.bank_cate bankcate", new QFilter[]{new QFilter("id", QCP.equals, dynamic.getPkValue())});
String pdfUrl = getPdfUrl(viewByDynamicObj.getPageId(), receipts, errMsgList);
logger.info("获取回单附件pdfUrl{}", pdfUrl);
} else { } else {
logger.info("电子回单查询 → BIP推送接口 → 失败\n失败单据编号{}\n失败请求体{}\n推送失败接口返回数据{}", dynamic.getString("billno"), saveRequestBody, saveResponseBody); logger.info("电子回单查询 → BIP推送接口 → 失败\n失败单据编号{}\n失败请求体{}\n推送失败接口返回数据{}",
dynamic.getString("billno"), saveRequestBody, saveResponseBody);
result = "推送 → 电子回单查询 → 失败"; result = "推送 → 电子回单查询 → 失败";
} }
break; break;
@ -709,7 +722,7 @@ public class ApiService {
errMsgList.add(ResManager.loadKDString("请求打印电子回单数量超过1000条请分批处理。", "ViewReceiptService_6", "tmc-bei-business", new Object[0])); errMsgList.add(ResManager.loadKDString("请求打印电子回单数量超过1000条请分批处理。", "ViewReceiptService_6", "tmc-bei-business", new Object[0]));
return null; return null;
} else { } else {
Set<Long> pkIds = (Set<Long>)receipts.stream().map((receiptx) -> { Set<Long> pkIds = (Set<Long>) receipts.stream().map((receiptx) -> {
return receiptx.getLong("id"); return receiptx.getLong("id");
}).collect(Collectors.toSet()); }).collect(Collectors.toSet());
Map<Object, Set<MatcherTpl>> receiptTemplate = ReceiptPrintHelper.getMatchReceiptTemplate("bei", "bei_elecreceipt", pkIds, ViewType.LIST, pageId); Map<Object, Set<MatcherTpl>> receiptTemplate = ReceiptPrintHelper.getMatchReceiptTemplate("bei", "bei_elecreceipt", pkIds, ViewType.LIST, pageId);
@ -778,6 +791,7 @@ public class ApiService {
} }
} else { } else {
PrtAttach attach = ReceiptPrintHelper.doNewPrint(pageId, "bei_elecreceipt", templateId, receipt.get("id")); PrtAttach attach = ReceiptPrintHelper.doNewPrint(pageId, "bei_elecreceipt", templateId, receipt.get("id"));
logger.info("ViewReceiptService attach=" + attach);
if (Objects.nonNull(attach)) { if (Objects.nonNull(attach)) {
List<PrtAttach.AttachDetail> attachDetail = attach.getAttachDetail(); List<PrtAttach.AttachDetail> attachDetail = attach.getAttachDetail();
@ -785,6 +799,7 @@ public class ApiService {
byte[] pdfPutStream = BeiHelper.getPdfPutStream(detail.getFilePath(), "new"); byte[] pdfPutStream = BeiHelper.getPdfPutStream(detail.getFilePath(), "new");
resList.add(pdfPutStream); resList.add(pdfPutStream);
} }
logger.info("ViewReceiptService resList.size=" + resList.size());
} }
} }
} }
@ -804,6 +819,7 @@ public class ApiService {
String pdfUrl = null; String pdfUrl = null;
try { try {
logger.info("resList{}", resList);
pdfUrl = finlyOpenForm(resList); pdfUrl = finlyOpenForm(resList);
} catch (Exception var27) { } catch (Exception var27) {
logger.error("mergeMultiPdf Fail", ExceptionUtils.getExceptionStackTraceMessage(var27)); logger.error("mergeMultiPdf Fail", ExceptionUtils.getExceptionStackTraceMessage(var27));
@ -825,7 +841,7 @@ public class ApiService {
throw new KDBizException(ExceptionUtils.getExceptionStackTraceMessage(var5)); throw new KDBizException(ExceptionUtils.getExceptionStackTraceMessage(var5));
} }
} else { } else {
mergeMultiPdf = (byte[]) resList.get(0); mergeMultiPdf = resList.get(0);
} }
NotePrintService notePrintService = new NotePrintService(); NotePrintService notePrintService = new NotePrintService();
@ -865,4 +881,38 @@ public class ApiService {
} }
} }
/**
* 按照动态对象来创建页面视图可在后端模拟操作并且修改值触发对应插件
*
* @return
*/
public static IFormView createViewByDynamicObj(DynamicObject dynamicObj) {
MainEntityType type = MetadataServiceHelper.getDataEntityType(dynamicObj.getDataEntityType().getName());
String appId = type.getAppId();
IFormView view = createView(dynamicObj.getDataEntityType().getName(), appId, dynamicObj.getPkValue());
if (view != null) {
view.getModel().createNewData(dynamicObj);
}
return view;
}
/**
* 创建视图
*
* @param formId:表单标识
* @param appId:应用id
* @return
*/
public static IFormView createView(String formId, String appId, Object pkId) {
BillShowParameter para = new BillShowParameter();
para.setFormId(formId);
para.setAppId(appId);
para.setPkId(pkId);
// 创建单据配置
FormConfigFactory.createConfigInCurrentAppService(para);
// 获取单据页面视图
SessionManager sm = SessionManager.getCurrent();
return sm.getView(para.getPageId());
}
} }

View File

@ -75,6 +75,10 @@ public class PayBillApiSavePlugin implements ApiSavePlugin {
map.put("payeeformid", "other"); map.put("payeeformid", "other");
} }
if ("bd_supplier".equals(payeetype) || "bd_customer".equals(payeetype)) {
// BusinessDataServiceHelper.load(payeetype, "id,number,name,societycreditcode",)
}
logger.info("进入付款处理单API"); logger.info("进入付款处理单API");
//收款人类型 //收款人类型

View File

@ -1,6 +1,7 @@
package shkd.sys.sys.plugin.form; package shkd.sys.sys.plugin.form;
import kd.bos.bill.AbstractBillPlugIn; import kd.bos.bill.AbstractBillPlugIn;
import kd.bos.bill.BillShowParameter;
import kd.bos.cache.CacheFactory; import kd.bos.cache.CacheFactory;
import kd.bos.cache.TempFileCache; import kd.bos.cache.TempFileCache;
import kd.bos.context.RequestContext; import kd.bos.context.RequestContext;
@ -9,17 +10,22 @@ import kd.bos.dataentity.entity.DynamicObjectCollection;
import kd.bos.dataentity.entity.LocaleString; import kd.bos.dataentity.entity.LocaleString;
import kd.bos.dataentity.resource.ResManager; import kd.bos.dataentity.resource.ResManager;
import kd.bos.dataentity.utils.StringUtils; import kd.bos.dataentity.utils.StringUtils;
import kd.bos.entity.MainEntityType;
import kd.bos.exception.KDBizException; import kd.bos.exception.KDBizException;
import kd.bos.form.IFormView;
import kd.bos.form.control.Toolbar; import kd.bos.form.control.Toolbar;
import kd.bos.form.control.events.ItemClickEvent; import kd.bos.form.control.events.ItemClickEvent;
import kd.bos.logging.Log; import kd.bos.logging.Log;
import kd.bos.logging.LogFactory; import kd.bos.logging.LogFactory;
import kd.bos.metadata.dao.MetadataDao; import kd.bos.metadata.dao.MetadataDao;
import kd.bos.mvc.FormConfigFactory;
import kd.bos.mvc.SessionManager;
import kd.bos.orm.query.QCP; import kd.bos.orm.query.QCP;
import kd.bos.orm.query.QFilter; import kd.bos.orm.query.QFilter;
import kd.bos.print.core.service.PrtAttach; import kd.bos.print.core.service.PrtAttach;
import kd.bos.print.matchtpl.MatcherTpl; import kd.bos.print.matchtpl.MatcherTpl;
import kd.bos.print.matchtpl.ViewType; import kd.bos.print.matchtpl.ViewType;
import kd.bos.servicehelper.MetadataServiceHelper;
import kd.bos.servicehelper.PrintServiceHelper; import kd.bos.servicehelper.PrintServiceHelper;
import kd.bos.servicehelper.QueryServiceHelper; import kd.bos.servicehelper.QueryServiceHelper;
import kd.bos.servicehelper.operation.SaveServiceHelper; import kd.bos.servicehelper.operation.SaveServiceHelper;
@ -60,203 +66,25 @@ public class PaymentProcessingBillPlugin extends AbstractBillPlugIn implements P
if ("shkd_hitback".equals(itemKey)) { if ("shkd_hitback".equals(itemKey)) {
DynamicObject dataEntity = this.getModel().getDataEntity(true); DynamicObject dataEntity = this.getModel().getDataEntity(true);
String bankpaystatus = dataEntity.getString("bankpaystatus"); String bankpaystatus = dataEntity.getString("bankpaystatus");
if (!"共享系统".equals(dataEntity.getString("shkd_businessname"))) {
this.getView().showTipNotification("只允许打回BIP推送单据");
return;
}
if ("TF、NC、OF".contains(bankpaystatus)) { if ("TF、NC、OF".contains(bankpaystatus)) {
List<DynamicObject> dynamicObjects = new ArrayList<>(); List<DynamicObject> dynamicObjects = new ArrayList<>();
String result = ApiService.paymentSlipsJson(dataEntity, "BIPNO", dynamicObjects, null); String result = ApiService.paymentSlipsJson(dataEntity, "BIPNO", dynamicObjects, null);
logger.info("result信息{}", result);
if (result.contains("成功")) { if (result.contains("成功")) {
SaveServiceHelper.save(dynamicObjects.toArray(new DynamicObject[0])); SaveServiceHelper.save(dynamicObjects.toArray(new DynamicObject[0]));
this.getView().showSuccessNotification("打回成功"); this.getView().showSuccessNotification("打回成功");
} else {
this.getView().showTipNotification("打回失败");
} }
} else { } else {
this.getView().showErrorNotification("打回失败,请确认银行支付状态"); this.getView().showTipNotification("打回失败,请确认银行支付状态");
} }
} }
if ("shkd_getpageid".equals(itemKey)) {
// this.getView().showTipNotification("本单PageId" + this.getView().getPageId());
List<String> errMsgList = new ArrayList<>();
Long pkValue = (Long) this.getView().getModel().getDataEntity().getPkValue();
DynamicObjectCollection receipts = QueryServiceHelper.query("bei_elecreceipt", "id,bank," +
"fileflag,filepath,biztype,bankcheckflag,fileserverurl,tcpurl,uploadfilename,username,password," +
"bank.bank_cate bankcate", new QFilter[]{new QFilter("id", QCP.equals, pkValue)});
String pdfUrl = getPdfUrl(this.getView().getPageId(), receipts, errMsgList);
if (!errMsgList.isEmpty()) {
this.getView().showErrorNotification(String.join(",", errMsgList));
}
logger.info("PageId{}\npdfUrl{}", this.getView().getPageId(), pdfUrl);
}
}
private static String getPdfUrl(String pageId, DynamicObjectCollection receipts, List<String> errMsgList) {
List<String> listPdf = new ArrayList<>(10);
List<byte[]> resList = new ArrayList<>(10);
String getEreceipturlError = (new BeiBizResource()).getGetEreceipturlError();
String templateError = (new BeiBizResource()).getTemplateError();
String getTemplateError = (new BeiBizResource()).getGetTemplateError();
logger.info("ViewReceiptService.getPdfUrl receipts.size=" + receipts.size());
if (receipts.size() > 1000) {
errMsgList.add(ResManager.loadKDString("请求打印电子回单数量超过1000条请分批处理。", "ViewReceiptService_6", "tmc-bei-business", new Object[0]));
return null;
} else {
Set<Long> pkIds = (Set<Long>) receipts.stream().map((receiptx) -> {
return receiptx.getLong("id");
}).collect(Collectors.toSet());
Map<Object, Set<MatcherTpl>> receiptTemplate = ReceiptPrintHelper.getMatchReceiptTemplate("bei", "bei_elecreceipt", pkIds, ViewType.LIST, pageId);
receiptTemplate.remove("");
long timeMillis = System.currentTimeMillis();
for (DynamicObject receipt : receipts) {
Long receiptID = receipt.getLong("id");
try {
logger.info("ViewReceiptService templateForm.size=" + receiptTemplate.size());
if (receiptTemplate.isEmpty()) {
errMsgList.add(templateError);
} else {
for (Object o : (Set) receiptTemplate.get(receiptID)) {
MatcherTpl template = (MatcherTpl) o;
String templateId = template.getTplId();
logger.info("ViewReceiptService templateForm.keySet=" + templateId);
String templateFormId = "";
if (EmptyUtil.isNoEmpty(templateId)) {
templateFormId = MetadataDao.getNumberById(templateId);
logger.info("ViewReceiptService templateFormId=" + templateFormId);
}
String url = PrintServiceHelper.createPdfUrl(pageId, "bei_elecreceipt", templateFormId, new Long[]{receiptID});
logger.info("ViewReceiptService url4old=" + url);
if (StringUtils.isNotEmpty(url)) {
if (receipt.getBoolean("fileflag")) {
logger.info("设置username-------" + receipt.getString("username"));
System.setProperty("ereceipt.authuser", receipt.getString("username"));
String uploadFileName = ReceiptPrintHelper.getRealUploadUrl(receipt);
if (StringUtils.isBlank(uploadFileName)) {
errMsgList.add(getEreceipturlError);
}
String fileServerUrl = receipt.getString("fileserverurl");
try {
if (!EmptyUtil.isEmpty(fileServerUrl)) {
ScanSystemFactory.getScanService();
Long userId = RequestContext.get().getCurrUserId();
DynamicObjectCollection userObj = QueryServiceHelper.query("bos_user", "id,phone", (new QFilter("id", "=", userId)).toArray());
DynamicObjectCollection configObj = QueryServiceHelper.query("bas_imageconfig", "imageurl,clientid,clientsecret", (new QFilter("enable", "=", "A")).toArray());
InputStream image = ScanServiceImpl.getImage(((DynamicObject) configObj.get(0)).getString("clientid"), ((DynamicObject) configObj.get(0)).getString("clientsecret"), ((DynamicObject) configObj.get(0)).getString("imageurl"), ((DynamicObject) userObj.get(0)).getString("phone"), fileServerUrl);
ReceiptPrintHelper.imageConvertPdf("", resList, image);
} else if (!uploadFileName.endsWith("pdf") && !uploadFileName.endsWith("PDF")) {
if (!uploadFileName.endsWith("ofd") && !uploadFileName.endsWith("OFD")) {
logger.info("fileReceipt url" + uploadFileName);
ReceiptPrintHelper.imageConvertPdf(uploadFileName, resList, (InputStream) null);
} else {
logger.info("ofdReceipt url" + uploadFileName);
byte[] bytes = OfdConvertUtil.convertToPdfNew(BeiHelper.getPdfPutStream(uploadFileName, "old"));
resList.add(bytes);
}
} else {
logger.info("pdfReceipt url" + uploadFileName);
BeiHelper.getPdfPutStream(uploadFileName, resList);
}
} catch (Exception var28) {
logger.info(ExceptionUtils.getExceptionStackTraceMessage(var28));
errMsgList.add(getEreceipturlError);
}
} else {
listPdf.add(url);
}
} else {
PrtAttach attach = ReceiptPrintHelper.doNewPrint(pageId, "bei_elecreceipt", templateId, receipt.get("id"));
logger.info("ViewReceiptService attach=" + attach);
if (Objects.nonNull(attach)) {
List<PrtAttach.AttachDetail> attachDetail = attach.getAttachDetail();
for (PrtAttach.AttachDetail detail : attachDetail) {
byte[] pdfPutStream = BeiHelper.getPdfPutStream(detail.getFilePath(), "new");
resList.add(pdfPutStream);
}
logger.info("ViewReceiptService resList.size=" + resList.size());
}
}
}
logger.info("ViewReceiptService listPdf=" + listPdf);
logger.info("ViewReceiptService resList.size=" + resList.size());
}
} catch (KDBizException var29) {
errMsgList.add(var29.getMessage());
} catch (Exception var30) {
logger.info(ExceptionUtils.getExceptionStackTraceMessage(var30));
errMsgList.add(getTemplateError);
}
}
readTemplate(listPdf, resList);
String pdfUrl = null;
try {
logger.info("resList{}", resList);
pdfUrl = finlyOpenForm(resList);
} catch (Exception var27) {
logger.error("mergeMultiPdf Fail", ExceptionUtils.getExceptionStackTraceMessage(var27));
errMsgList.add((new BeiBizResource()).dealPdfError());
}
logger.info("printTimeCost: " + (System.currentTimeMillis() - timeMillis) + " generatePdfUrl: " + pdfUrl);
return pdfUrl;
}
}
private static String finlyOpenForm(List<byte[]> resList) {
if (!resList.isEmpty()) {
byte[] mergeMultiPdf;
if (resList.size() > 1) {
try {
mergeMultiPdf = ReceiptPrintHelper.mergeMultiPdf(resList);
} catch (Exception var5) {
throw new KDBizException(ExceptionUtils.getExceptionStackTraceMessage(var5));
}
} else {
mergeMultiPdf = (byte[]) resList.get(0);
}
NotePrintService notePrintService = new NotePrintService();
LocaleString localeString = new LocaleString("receipt");
return notePrintService.createPdfUrl(localeString, mergeMultiPdf);
} else {
return null;
}
}
private static void readTemplate(List<String> listPdf, List<byte[]> resList) {
if (listPdf != null && !listPdf.isEmpty()) {
TempFileCache tempFileCache = CacheFactory.getCommonCacheFactory().getTempFileCache();
for (String string : listPdf) {
InputStream ins = tempFileCache.getInputStream(string);
try {
byte[] bytes = new byte[ins.available()];
int bytesRead = 0;
int bytesToRead = ins.available();
while (bytesRead < bytesToRead) {
int result = ins.read(bytes, bytesRead, bytesToRead - bytesRead);
bytesRead += result;
if (result == -1) {
break;
}
}
resList.add(bytes);
ins.close();
} catch (IOException var11) {
logger.info("IO流失败" + ExceptionUtils.getExceptionStackTraceMessage(var11));
}
}
}
} }
} }