add dzpzk bizdata interface

This commit is contained in:
刘鹏 2024-08-12 00:12:16 +08:00
parent ef4dd86c90
commit d2e407cca3
7 changed files with 364 additions and 74 deletions

View File

@ -21,7 +21,7 @@ public class Attr {
private String entryAccountFlag; private String entryAccountFlag;
private String usedFlag; private String usedFlag;
private String usedConfirmation; private String usedConfirmation;
private Date usedPeriod; private String usedPeriod;
private String paidFlag; private String paidFlag;
private String bankElectronicReceipt; private String bankElectronicReceipt;
private String transferFlag; private String transferFlag;
@ -93,10 +93,10 @@ public class Attr {
return usedConfirmation; return usedConfirmation;
} }
public void setUsedPeriod(Date usedPeriod) { public void setUsedPeriod(String usedPeriod) {
this.usedPeriod = usedPeriod; this.usedPeriod = usedPeriod;
} }
public Date getUsedPeriod() { public String getUsedPeriod() {
return usedPeriod; return usedPeriod;
} }

View File

@ -13,7 +13,7 @@ import java.util.Date;
public class Head { public class Head {
private String sourceSys; private String sourceSys;
private Date requestTime; private String requestTime;
private String requestNo; private String requestNo;
public void setSourceSys(String sourceSys) { public void setSourceSys(String sourceSys) {
this.sourceSys = sourceSys; this.sourceSys = sourceSys;
@ -22,10 +22,10 @@ public class Head {
return sourceSys; return sourceSys;
} }
public void setRequestTime(Date requestTime) { public void setRequestTime(String requestTime) {
this.requestTime = requestTime; this.requestTime = requestTime;
} }
public Date getRequestTime() { public String getRequestTime() {
return requestTime; return requestTime;
} }

View File

@ -2,7 +2,6 @@
* Copyright 2024 bejson.com * Copyright 2024 bejson.com
*/ */
package shkd.fi.fi.common.dzpzk.bizdata.req; package shkd.fi.fi.common.dzpzk.bizdata.req;
import java.util.Date;
/** /**
* Auto-generated: 2024-08-03 17:26:28 * Auto-generated: 2024-08-03 17:26:28
@ -14,8 +13,8 @@ public class JournalHeads {
private String accEntityCode; private String accEntityCode;
private String journalNumber; private String journalNumber;
private Date accountDate; private String accountDate;
private Date accountPeriod; private String accountPeriod;
private String accountYear; private String accountYear;
private String journalSummary; private String journalSummary;
public void setAccEntityCode(String accEntityCode) { public void setAccEntityCode(String accEntityCode) {
@ -32,17 +31,17 @@ public class JournalHeads {
return journalNumber; return journalNumber;
} }
public void setAccountDate(Date accountDate) { public void setAccountDate(String accountDate) {
this.accountDate = accountDate; this.accountDate = accountDate;
} }
public Date getAccountDate() { public String getAccountDate() {
return accountDate; return accountDate;
} }
public void setAccountPeriod(Date accountPeriod) { public void setAccountPeriod(String accountPeriod) {
this.accountPeriod = accountPeriod; this.accountPeriod = accountPeriod;
} }
public Date getAccountPeriod() { public String getAccountPeriod() {
return accountPeriod; return accountPeriod;
} }

View File

@ -5,7 +5,7 @@ package shkd.fi.fi.common.dzpzk.guidangquery.res;
import java.util.Date; import java.util.Date;
/** /**
* Auto-generated: 2024-08-06 20:54:33 * Auto-generated: 2024-08-08 18:3:44
* *
* @author bejson.com (i@bejson.com) * @author bejson.com (i@bejson.com)
* @website http://www.bejson.com/java2pojo/ * @website http://www.bejson.com/java2pojo/
@ -15,21 +15,20 @@ public class Attr {
private String companyCode; private String companyCode;
private double taxExcludedAmount; private double taxExcludedAmount;
private String companyName; private String companyName;
private String journalSummary;
private String sellerName;
private String accountYear; private String accountYear;
private String sellerName;
private Date accountPeriod; private Date accountPeriod;
private Date invoiceDate;
private String buyerName; private String buyerName;
private String invoiceCode; private Date invoiceDate;
private String buyerTin; private String buyerTin;
private String invoiceCode;
private String invoiceNumber; private String invoiceNumber;
private String invoiceType; private String invoiceType;
private String journalNumber; private String journalNumber;
private double taxAmount;
private String sourceDocNumber; private String sourceDocNumber;
private double taxIncludedAmount; private double taxAmount;
private String sourceDocCategory; private String sourceDocCategory;
private double taxIncludedAmount;
private String remarks; private String remarks;
private String sellerTin; private String sellerTin;
public void setCompanyCode(String companyCode) { public void setCompanyCode(String companyCode) {
@ -53,11 +52,11 @@ public class Attr {
return companyName; return companyName;
} }
public void setJournalSummary(String journalSummary) { public void setAccountYear(String accountYear) {
this.journalSummary = journalSummary; this.accountYear = accountYear;
} }
public String getJournalSummary() { public String getAccountYear() {
return journalSummary; return accountYear;
} }
public void setSellerName(String sellerName) { public void setSellerName(String sellerName) {
@ -67,13 +66,6 @@ public class Attr {
return sellerName; return sellerName;
} }
public void setAccountYear(String accountYear) {
this.accountYear = accountYear;
}
public String getAccountYear() {
return accountYear;
}
public void setAccountPeriod(Date accountPeriod) { public void setAccountPeriod(Date accountPeriod) {
this.accountPeriod = accountPeriod; this.accountPeriod = accountPeriod;
} }
@ -81,13 +73,6 @@ public class Attr {
return accountPeriod; return accountPeriod;
} }
public void setInvoiceDate(Date invoiceDate) {
this.invoiceDate = invoiceDate;
}
public Date getInvoiceDate() {
return invoiceDate;
}
public void setBuyerName(String buyerName) { public void setBuyerName(String buyerName) {
this.buyerName = buyerName; this.buyerName = buyerName;
} }
@ -95,11 +80,11 @@ public class Attr {
return buyerName; return buyerName;
} }
public void setInvoiceCode(String invoiceCode) { public void setInvoiceDate(Date invoiceDate) {
this.invoiceCode = invoiceCode; this.invoiceDate = invoiceDate;
} }
public String getInvoiceCode() { public Date getInvoiceDate() {
return invoiceCode; return invoiceDate;
} }
public void setBuyerTin(String buyerTin) { public void setBuyerTin(String buyerTin) {
@ -109,6 +94,13 @@ public class Attr {
return buyerTin; return buyerTin;
} }
public void setInvoiceCode(String invoiceCode) {
this.invoiceCode = invoiceCode;
}
public String getInvoiceCode() {
return invoiceCode;
}
public void setInvoiceNumber(String invoiceNumber) { public void setInvoiceNumber(String invoiceNumber) {
this.invoiceNumber = invoiceNumber; this.invoiceNumber = invoiceNumber;
} }
@ -130,13 +122,6 @@ public class Attr {
return journalNumber; return journalNumber;
} }
public void setTaxAmount(double taxAmount) {
this.taxAmount = taxAmount;
}
public double getTaxAmount() {
return taxAmount;
}
public void setSourceDocNumber(String sourceDocNumber) { public void setSourceDocNumber(String sourceDocNumber) {
this.sourceDocNumber = sourceDocNumber; this.sourceDocNumber = sourceDocNumber;
} }
@ -144,11 +129,11 @@ public class Attr {
return sourceDocNumber; return sourceDocNumber;
} }
public void setTaxIncludedAmount(double taxIncludedAmount) { public void setTaxAmount(double taxAmount) {
this.taxIncludedAmount = taxIncludedAmount; this.taxAmount = taxAmount;
} }
public double getTaxIncludedAmount() { public double getTaxAmount() {
return taxIncludedAmount; return taxAmount;
} }
public void setSourceDocCategory(String sourceDocCategory) { public void setSourceDocCategory(String sourceDocCategory) {
@ -158,6 +143,13 @@ public class Attr {
return sourceDocCategory; return sourceDocCategory;
} }
public void setTaxIncludedAmount(double taxIncludedAmount) {
this.taxIncludedAmount = taxIncludedAmount;
}
public double getTaxIncludedAmount() {
return taxIncludedAmount;
}
public void setRemarks(String remarks) { public void setRemarks(String remarks) {
this.remarks = remarks; this.remarks = remarks;
} }

View File

@ -4,7 +4,7 @@
package shkd.fi.fi.common.dzpzk.guidangquery.res; package shkd.fi.fi.common.dzpzk.guidangquery.res;
/** /**
* Auto-generated: 2024-08-06 20:54:33 * Auto-generated: 2024-08-08 18:3:44
* *
* @author bejson.com (i@bejson.com) * @author bejson.com (i@bejson.com)
* @website http://www.bejson.com/java2pojo/ * @website http://www.bejson.com/java2pojo/

View File

@ -22,6 +22,9 @@ import kd.bos.servicehelper.operation.SaveServiceHelper;
import kd.bos.util.HttpClientUtils; import kd.bos.util.HttpClientUtils;
import kd.bos.util.StringUtils; import kd.bos.util.StringUtils;
import shkd.fi.fi.common.AppflgConstant; import shkd.fi.fi.common.AppflgConstant;
import shkd.fi.fi.common.dzpzk.bizdata.req.DzpzBizDataBean;
import shkd.fi.fi.common.dzpzk.bizdata.req.Evouchers;
import shkd.fi.fi.common.dzpzk.bizdata.req.JournalHeads;
import shkd.fi.fi.common.dzpzk.guidang.req.*; import shkd.fi.fi.common.dzpzk.guidang.req.*;
import shkd.fi.fi.common.dzpzk.guidang.res.GuidangResponseBean; import shkd.fi.fi.common.dzpzk.guidang.res.GuidangResponseBean;
import shkd.fi.fi.common.dzpzk.guidangquery.req.GuidangQueryReqBean; import shkd.fi.fi.common.dzpzk.guidangquery.req.GuidangQueryReqBean;
@ -63,6 +66,7 @@ public class DzpzkOPPlugin extends AbstractOperationServicePlugIn {
queryGuidangResult(e); queryGuidangResult(e);
break; break;
case "shkd_dzpzk_biz": case "shkd_dzpzk_biz":
synBizData(e);
break; break;
case "shkd_dzpzk_biz_res": case "shkd_dzpzk_biz_res":
break; break;
@ -351,24 +355,11 @@ public class DzpzkOPPlugin extends AbstractOperationServicePlugIn {
String fileHexString = ""; String fileHexString = "";
ByteArrayOutputStream out = new ByteArrayOutputStream(); ByteArrayOutputStream out = new ByteArrayOutputStream();
FileServiceFactory.getAttachmentFileService().download(url,out,null); FileServiceFactory.getAttachmentFileService().download(url,out,null);
ByteArrayInputStream bis = new ByteArrayInputStream(out.toByteArray()); // ByteArrayInputStream bis = new ByteArrayInputStream(out.toByteArray());
// byte[] data = new byte[bis.available()];
try { // bis.read(data);
byte[] data = new byte[bis.available()]; byte[] bytes = out.toByteArray();
bis.read(data); fileHexString = FileUtils.byteArrToHexString(bytes);
StringBuilder hexString = new StringBuilder();
for (byte b : data) {
String hex = Integer.toHexString(0xff & b);
if (hex.length() == 1) {
hexString.append('0');
}
hexString.append(hex);
}
fileHexString = hexString.toString();
} catch (IOException e) {
throw new RuntimeException(e);
}
// String fileHexString = FileUtils.fileToHex((FileInputStream)inputStream); // String fileHexString = FileUtils.fileToHex((FileInputStream)inputStream);
String name = (String)attach.get("name"); String name = (String)attach.get("name");
Long size = (Long)attach.get("size"); Long size = (Long)attach.get("size");
@ -385,6 +376,65 @@ public class DzpzkOPPlugin extends AbstractOperationServicePlugIn {
} }
return elements; return elements;
} }
private static List<Evouchers> buildBizDataElements(DynamicObject[] sourcebillid, String org_shkd_sap_number, DynamicObject org, DynamicObject voucher, List<Evouchers> evouchers) {
DynamicObject[] ap_finapbillObjects = sourcebillid;
for (DynamicObject apBillObj : ap_finapbillObjects) {
DynamicObjectCollection inventry = apBillObj.getDynamicObjectCollection("shkd_inventry");
for (DynamicObject apInvoice: inventry) {
Evouchers evoucher = new Evouchers();
evoucher.setEvcTypeCode("EINV");
shkd.fi.fi.common.dzpzk.bizdata.req.Attr attr = new shkd.fi.fi.common.dzpzk.bizdata.req.Attr();
DynamicObject shkd_invoicereceipt = apInvoice.getDynamicObject("shkd_invoicereceipt");//发票识别单
DynamicObject invoiceBill = BusinessDataServiceHelper.loadSingle(shkd_invoicereceipt.getPkValue(), "shkd_invoicereceipt");
attr.setInvoiceNumber(invoiceBill.getString("shkd_invoiceno"));
attr.setInvoiceType("");
attr.setContractNumber("");
attr.setAssetsDepreciationMethod("");
attr.setSecurityFlag("");
attr.setEntryAccountFlag("1");
attr.setUsedFlag("1");
// attr.setUsedConfirmation();
attr.setUsedPeriod(DateUtils.format(invoiceBill.getDate("shkd_invoicedate"),DateUtils.COMPACT_YY_MM));//2024-07
attr.setPaidFlag("");
attr.setBankElectronicReceipt("");
attr.setTransferFlag("0");
attr.setTransferAmount("0");
attr.setIncomeTaxDeduct("");
attr.setIncomeTaxYearFrom("");
attr.setIncomeTaxYearTo("");
attr.setExpensePeriodFrom("");
attr.setExpensePeriodTo("");
attr.setInvoiceType("02");
attr.setPurchaserName("");
attr.setPurchaserTaxNumber("");
attr.setCompanyCode(org_shkd_sap_number);
attr.setSysDocNumber(voucher.getString("billno"));
List<JournalHeads> journalHeads = new ArrayList<JournalHeads>();
JournalHeads jh = new JournalHeads();
jh.setAccEntityCode(org_shkd_sap_number);
jh.setJournalNumber(voucher.getString("shkd_belnr"));
jh.setAccountDate(DateUtils.format(voucher.getDate("bookeddate"),DateUtils.COMPACT_YY_MM_DD));
jh.setAccountPeriod(DateUtils.format(voucher.getDate("bookeddate"),DateUtils.COMPACT_YY_MM));
jh.setAccountYear(DateUtils.format(voucher.getDate("bookeddate"),DateUtils.COMPACT_YEAR));
jh.setJournalSummary("");
journalHeads.add(jh);
attr.setJournalHeads(journalHeads);
evoucher.setAttr(attr);
evouchers.add(evoucher);
}
}
return evouchers;
}
public void queryGuidangResult(AfterOperationArgs e){ public void queryGuidangResult(AfterOperationArgs e){
//1.校验不满足条件的凭证移除不传输 //1.校验不满足条件的凭证移除不传输
@ -564,12 +614,233 @@ public class DzpzkOPPlugin extends AbstractOperationServicePlugIn {
} }
Integer integer = 0; Integer integer = 0;
//2.组装转换参数 //2.组装转换参数
for (DynamicObject dataEntity : voucherColl) { String requstTime = DateUtils.formatDate(new Date(), DateUtils.PATTERN_CLASSICAL);
String requstNo = DateUtils.formatDate(new Date(), DateUtils.COMPACT_TIME);
Random random = new Random();
int randomNumber = 1000 + random.nextInt(9000); // 生成1000到9999之间的随机数
requstNo = AppflgConstant.SYS_NUMBER+requstNo+randomNumber;
for (DynamicObject voucher : voucherColl) {
DynamicObject org = voucher.getDynamicObject("org");
String org_shkd_sap_number = org.getString("shkd_sap_number");
DzpzBizDataBean bizDataBean = new DzpzBizDataBean();
shkd.fi.fi.common.dzpzk.bizdata.req.Head head = new shkd.fi.fi.common.dzpzk.bizdata.req.Head();
head.setRequestNo(requstNo);
head.setRequestTime(requstTime);
head.setSourceSys(AppflgConstant.SYS_NUMBER);
bizDataBean.setHead(head);
shkd.fi.fi.common.dzpzk.bizdata.req.Body body = new shkd.fi.fi.common.dzpzk.bizdata.req.Body();
List<Evouchers> evouchers = new ArrayList<>();
//DAP关系
QFilter filter = new QFilter("voucherid",QCP.equals,voucher.getPkValue());
List<String> billTypeList = new ArrayList<String>();
billTypeList.add(im_purinbill);
billTypeList.add(ap_finapbill);
QFilter filter2 = new QFilter("billtype.number",QCP.in,billTypeList);
DynamicObject[] ai_daptrackers = BusinessDataServiceHelper.load("ai_daptracker", "id,billtype.number,voucherid,sourcebillid", new QFilter[]{filter.and(filter2)});
for (int i = 0; i < ai_daptrackers.length; i++) {
DynamicObject ai_daptracker = ai_daptrackers[i];
DynamicObject billtype = ai_daptracker.getDynamicObject("billtype");
String number = billtype.getString("number");
DynamicObject dynamicObject = BusinessDataServiceHelper.newDynamicObject(ap_finapbill);
long sourcebillid = ai_daptracker.getLong("sourcebillid");
if(im_purinbill.equals(number)){//来源单据是采购入库单需查询下游单据财务应付单
List<Long> apBillIdList = down(im_purinbill, sourcebillid);
buildBizDataElements(BusinessDataServiceHelper.load(apBillIdList.toArray(), dynamicObject.getDynamicObjectType()), org_shkd_sap_number, org, voucher, evouchers);
}else if(ap_finapbill.equals(number)){//来源单据是财务应付单
buildBizDataElements(BusinessDataServiceHelper.load(new Long[]{sourcebillid}, dynamicObject.getDynamicObjectType()), org_shkd_sap_number, org, voucher, evouchers);
}
}
body.setEvouchers(evouchers);
bizDataBean.setBody(body);
//同步
//1.缓存有token 则取缓存里的token
String token ="";
if (cache.contains(AppflgConstant.DZPZK_TOKEN)) {
token = cache.get(AppflgConstant.DZPZK_TOKEN);
} else {
//2.缓存无token,通过接口调用获取token
//1.1.请求头
//1.3.通过接口调用获取token
try {
Map<String, String> hd = new HashMap<>();
Map<String, Object> bd = new HashMap<>();
String dzpzkTokenURL = AppflgConstant.getDzpzkTokenURL();
String getTokenResult = HttpClientUtils.post(dzpzkTokenURL, hd,bd);
LogBillUtils.SaveLogBill(dzpzkTokenURL, getTokenResult, AppflgConstant.DZPZK_TOKE_URL_NAME, "");
if (StringUtils.isEmpty(getTokenResult)) {
this.operationResult.setShowMessage(true);
this.operationResult.setSuccess(false);
this.operationResult.setMessage("同步失败:获取电子凭证库系统token失败");
return;
}
DzpzTokenBean dzpzTokenBean = JSONObject.parseObject(getTokenResult, DzpzTokenBean.class);
token = dzpzTokenBean.getAccess_token();
int expires_in = dzpzTokenBean.getExpires_in();
cache.put(AppflgConstant.DZPZK_TOKEN, token, expires_in);//将自定义参数加入缓存
} catch (IOException ex) {
throw new RuntimeException(ex);
}
}
try {
String url = System.getProperty(AppflgConstant.SHKD_DZPZK_BIZ_URL);
Map<String, String> header = new HashMap<String, String>();
header.put("Authorization","Bearer "+token);
String jsonBody = JSONObject.toJSONString(bizDataBean);
String postjson = HttpClientUtils.postjson(url, header, jsonBody);
LogBillUtils.SaveLogBill(url, postjson, AppflgConstant.DZPZK_GUIDANG_URL_NAME, jsonBody);
GuidangResponseBean guidangResponseBean = JSONObject.parseObject(postjson, GuidangResponseBean.class);
if("success".equals(guidangResponseBean.getCode())){
this.operationResult.setShowMessage(true);
this.operationResult.setSuccess(true);
this.operationResult.setMessage("同步成功");
voucher.set("shkd_gd_reqno",requstNo);
voucher.set("shkd_dzpzkstatus","0");
SaveServiceHelper.save(new DynamicObject[]{voucher});
}else {
this.operationResult.setShowMessage(true);
this.operationResult.setSuccess(false);
this.operationResult.setMessage("同步失败");
voucher.set("shkd_gd_reqno",requstNo);
voucher.set("shkd_dzpzkstatus","2");
SaveServiceHelper.save(new DynamicObject[]{voucher});
}
} catch (IOException ex) {
throw new RuntimeException(ex);
}
} }
System.out.println(integer);
} }
public void queryBizDataResult(AfterOperationArgs e){
//1.校验不满足条件的凭证移除不传输
DynamicObjectCollection voucherColl = new DynamicObjectCollection();
StringBuffer errStr = new StringBuffer();
DynamicObject[] dataEntities = e.getDataEntities();
for (DynamicObject voucher : dataEntities) {
String voucherNo = voucher.getString("billno");//凭证号
if(!"C".equals(voucher.getString("billstatus"))){
errStr.append("凭证号:").append(voucherNo).append("不满足同步条件,原因:");
errStr.append(" 凭证未审核").append("\r");
this.operationResult.setShowMessage(true);
this.operationResult.setSuccess(false);
this.operationResult.setMessage("数据校验不通过:"+errStr.toString());
break;
}
if(!"0".equals(voucher.getString("shkd_dzpzkstatus"))){
errStr.append("凭证号:").append(voucherNo).append("不满足查询条件,原因:");
errStr.append(" 凭证归档状态不是 附件已归档待处理").append("\r");
this.operationResult.setShowMessage(true);
this.operationResult.setSuccess(false);
this.operationResult.setMessage("数据校验不通过:"+errStr.toString());
break;
}
if(StringUtils.isEmpty(voucher.getString("shkd_gd_reqno"))){
errStr.append("凭证号:").append(voucherNo).append("不满足查询条件,原因:");
errStr.append(" 附件归档请求编号为空").append("\r");
this.operationResult.setShowMessage(true);
this.operationResult.setSuccess(false);
this.operationResult.setMessage("数据校验不通过:"+errStr.toString());
break;
}
voucherColl.add(voucher);
}
//数据校验不通过则不进行同步
if(StringUtils.isNotEmpty(errStr.toString())){
this.operationResult.setShowMessage(true);
this.operationResult.setSuccess(false);
this.operationResult.setMessage("数据校验不通过:"+errStr.toString());
return;
}
//2.组装转换参数
for (DynamicObject voucher : voucherColl) {
DynamicObject org = voucher.getDynamicObject("org");
String shkd_gd_reqno = voucher.getString("shkd_gd_reqno");
//同步
//1.缓存有token 则取缓存里的token
//1.缓存有token 则取缓存里的token
String token ="";
if (cache.contains(AppflgConstant.DZPZK_TOKEN)) {
token = cache.get(AppflgConstant.DZPZK_TOKEN);
} else {
//2.缓存无token,通过接口调用获取token
//1.1.请求头
//1.3.通过接口调用获取token
try {
Map<String, String> hd = new HashMap<>();
Map<String, Object> bd = new HashMap<>();
String dzpzkTokenURL = AppflgConstant.getDzpzkTokenURL();
String getTokenResult = HttpClientUtils.post(dzpzkTokenURL, hd,bd);
LogBillUtils.SaveLogBill(dzpzkTokenURL, getTokenResult, AppflgConstant.DZPZK_TOKE_URL_NAME, "");
if (StringUtils.isEmpty(getTokenResult)) {
this.operationResult.setShowMessage(true);
this.operationResult.setSuccess(false);
this.operationResult.setMessage("同步失败:获取电子凭证库系统token失败");
return;
}
DzpzTokenBean dzpzTokenBean = JSONObject.parseObject(getTokenResult, DzpzTokenBean.class);
token = dzpzTokenBean.getAccess_token();
int expires_in = dzpzTokenBean.getExpires_in();
cache.put(AppflgConstant.DZPZK_TOKEN, token, expires_in);//将自定义参数加入缓存
} catch (IOException ex) {
throw new RuntimeException(ex);
}
}
try {
String url = System.getProperty(AppflgConstant.SHKD_DZPZK_BIZ_RES_URL);
Map<String, String> header = new HashMap<String, String>();
header.put("Authorization","Bearer "+token);
GuidangQueryReqBean guidangQueryReqBean = new GuidangQueryReqBean();
shkd.fi.fi.common.dzpzk.guidangquery.req.Head head = new shkd.fi.fi.common.dzpzk.guidangquery.req.Head();
String requstTime = DateUtils.formatDate(new Date(), DateUtils.PATTERN_CLASSICAL);
String requstNo = DateUtils.formatDate(new Date(), DateUtils.COMPACT_TIME);
Random random = new Random();
int randomNumber = 1000 + random.nextInt(9000); // 生成1000到9999之间的随机数
requstNo = AppflgConstant.SYS_NUMBER+requstNo+randomNumber;
head.setRequestNo(requstNo);
head.setRequestTime(requstTime);
head.setSourceSys(AppflgConstant.SYS_NUMBER);
guidangQueryReqBean.setHead(head);
shkd.fi.fi.common.dzpzk.guidangquery.req.Body body = new shkd.fi.fi.common.dzpzk.guidangquery.req.Body();
body.setLinkRequestNo(shkd_gd_reqno);
guidangQueryReqBean.setBody(body);
String jsonBody = JSONObject.toJSONString(guidangQueryReqBean);
String postjson = HttpClientUtils.postjson(url, header, jsonBody);
LogBillUtils.SaveLogBill(url, postjson, AppflgConstant.SHKD_DZPZK_BIZ_RES_URL_NAME, jsonBody);
GuidangQueryResBean guidangResponseBean = JSONObject.parseObject(postjson, GuidangQueryResBean.class);
if("1".equals(guidangResponseBean.getProcessingResult())){
this.operationResult.setShowMessage(true);
this.operationResult.setSuccess(true);
this.operationResult.setMessage("同步成功");
voucher.set("shkd_dzpzkstatus","1");
SaveServiceHelper.save(new DynamicObject[]{voucher});
}else {
this.operationResult.setShowMessage(true);
this.operationResult.setSuccess(false);
this.operationResult.setMessage("同步失败");
voucher.set("shkd_dzpzkstatus","2");
SaveServiceHelper.save(new DynamicObject[]{voucher});
}
} catch (IOException ex) {
throw new RuntimeException(ex);
}
}
}
public static void updateVoucher (DynamicObject voucher,Item item) { public static void updateVoucher (DynamicObject voucher,Item item) {
String zstatus = item.getZstatus(); String zstatus = item.getZstatus();
String packgid = item.getPackgid(); String packgid = item.getPackgid();

View File

@ -1,4 +1,5 @@
package shkd.fi.fi.util; package shkd.fi.fi.util;
import java.io.ByteArrayInputStream;
import java.io.FileInputStream; import java.io.FileInputStream;
import java.io.IOException; import java.io.IOException;
import java.util.ArrayList; import java.util.ArrayList;
@ -60,4 +61,31 @@ public class FileUtils {
} }
return hexString; return hexString;
} }
// 将字节转换为16进制字符串
private static String bytesToHex(byte[] bytes) {
StringBuilder hexString = new StringBuilder();
for (byte b : bytes) {
String hex = Integer.toHexString(0xff & b);
if (hex.length() == 1) {
hexString.append('0');
}
hexString.append(hex);
}
return hexString.toString();
}
/**
* 字节数组转16进制字符串
* @param b
* @return
*/
public static String byteArrToHexString(byte[] b){
String result="";
for (int i=0; i < b.length; i++) {
result += Integer.toString( ( b[i] & 0xff ) + 0x100, 16).substring(1);
}
return result;
}
} }