package com.fzzy.push.gd2020.v2;
|
|
|
import com.fzzy.api.data.AuthToken;
|
import com.fzzy.api.entity.Api1209;
|
import com.fzzy.api.entity.ApiConfs;
|
import com.fzzy.push.gd2020.GDResult;
|
import com.fzzy.push.gd2020.GDUtils;
|
import com.fzzy.push.gd2020.InvokeResult;
|
import com.fzzy.push.gd2020.JaxbUtil;
|
import lombok.extern.slf4j.Slf4j;
|
import org.apache.cxf.endpoint.Client;
|
import org.apache.cxf.jaxws.endpoint.dynamic.JaxWsDynamicClientFactory;
|
|
import javax.xml.namespace.QName;
|
|
|
/**
|
* @Desc: 损溢单数据接口
|
* @author: Andy
|
* @update-time: 2022/10/16
|
*/
|
@Slf4j
|
public class IncomeStatementWebservice {
|
|
public static IncomeStatementWebservice newInstance() {
|
return new IncomeStatementWebservice();
|
}
|
|
public String xml_webservice = "<?xml version=\"1.0\" encoding=\"utf8\"?><root><row id=\"income_statement\"><cksl desc=\"出库数量\" type=\"decimal\" length=\"9\" requir=\"必填\">{}</cksl><rksj desc=\"入库时间\" type=\"varchar\" length=\"19\" requir=\"必填\">{}</rksj><sydbh desc=\"损溢单编号\" type=\"varchar\" length=\"32\" requir=\"必填\">{}</sydbh><hwbm desc=\"货位编码\" type=\"varchar\" length=\"30\" requir=\"必填\">{}</hwbm><rksl desc=\"入库数量\" type=\"decimal\" length=\"9\" requir=\"必填\">{}</rksl><cksj desc=\"出库时间\" type=\"varchar\" length=\"19\" requir=\"必填\">{}</cksj><sysl desc=\"损溢数量\" type=\"decimal\" length=\"9\" requir=\"必填\">{}</sysl><syyy desc=\"损溢原因\" type=\"varchar\" length=\"200\" requir=\"必填\">{}</syyy><czbz desc=\"操作标志\" type=\"varchar\" length=\"1\" requir=\"必填\">{}</czbz><ywrq desc=\"业务日期\" type=\"varchar\" length=\"10\" requir=\"必填\">{}</ywrq><zhgxsj desc=\"最后更新时间\" type=\"varchar\" length=\"19\" requir=\"必填\">{}</zhgxsj><kddm desc=\"库点代码\" type=\"varchar\" length=\"32\" requir=\"必填\">{}</kddm><ccshr desc=\"仓储审核人\" type=\"varchar\" length=\"32\" requir=\"可选\">{}</ccshr><zjshr desc=\"质检审核人\" type=\"varchar\" length=\"32\" requir=\"可选\">{}</zjshr><tjshr desc=\"统计审核人\" type=\"varchar\" length=\"32\" requir=\"可选\">{}</tjshr><kjshr desc=\"会计审核人\" type=\"varchar\" length=\"32\" requir=\"可选\">{}</kjshr><ldshr desc=\"领导审核人\" type=\"varchar\" length=\"32\" requir=\"可选\">{}</ldshr><bz desc=\"备注\" type=\"varchar\" length=\"200\" requir=\"可选\">{}</bz><ckzz desc=\"出库杂质\" type=\"decimal\" length=\"9\" requir=\"可选\">{}</ckzz><rksf desc=\"入库水分\" type=\"decimal\" length=\"9\" requir=\"可选\">{}</rksf><rkzz desc=\"入库杂质\" type=\"decimal\" length=\"9\" requir=\"可选\">{}</rkzz><cksf desc=\"出库水分\" type=\"decimal\" length=\"9\" requir=\"可选\">{}</cksf></row></root>";
|
|
private String method = "incomeStatementSaveRecordDetail";// 填写数据方法名
|
private String wsdl = "/incomeStatementWebservice?wsdl";//填写调用库点信息接口服务
|
private String nameSpace = "http://service.sljt.com";// 填写调用省平台命名空间
|
|
|
/**
|
* @Desc: 损溢单-数据接口
|
*/
|
public InvokeResult webService(AuthToken authToken,ApiConfs conf, Api1209 data) {
|
InvokeResult invokeResult = new InvokeResult();
|
|
ClassLoader cl = Thread.currentThread().getContextClassLoader();
|
|
|
|
String url = conf.getApiUrl() + wsdl; // 填写调用油脂库存数据接口服务
|
|
Thread.currentThread().setContextClassLoader(cl);
|
JaxWsDynamicClientFactory dcf = JaxWsDynamicClientFactory.newInstance();
|
Client client = dcf.createClient(url);
|
QName name = new QName(nameSpace, method);
|
Object[] objects;
|
|
try {
|
|
String xmlStr = webserviceXml(data);// 获取接口的输入报文,根据需要填写相应的报文
|
|
log.debug("------xmlStr--{}", xmlStr);
|
|
|
objects = client.invoke(name, new Object[]{authToken.getToken(), xmlStr});
|
|
log.debug("-----------返回信息---{}", objects[0].toString());
|
|
invokeResult = JaxbUtil.converyToJavaBean(objects[0].toString(), InvokeResult.class);
|
|
} catch (Exception e) {
|
log.error("----执行异常----{}", e);
|
invokeResult.setCode(GDResult.CODE_500.getCode());
|
invokeResult.setData("后端服务执行异常:+" + e.getMessage());
|
return invokeResult;
|
}
|
|
return invokeResult;
|
}
|
|
private String webserviceXml(Api1209 data) {
|
String xmlStr = xml_webservice;
|
xmlStr = xmlStr.replace("{sydbh}", GDUtils.formatStr(data.getSydh()));//损溢单编号
|
xmlStr = xmlStr.replace("{kddm}", GDUtils.formatStr(data.getKqdm()));//库点代码
|
xmlStr = xmlStr.replace("{hwbm}", GDUtils.formatStr(data.getHwdm()));//货位编码
|
xmlStr = xmlStr.replace("{ywrq}", GDUtils.formatDate(data.getYwrq(), "yyyy-MM-dd"));//业务日期
|
xmlStr = xmlStr.replace("{rksl}", GDUtils.formatNum(data.getRkjz()));//入库数量
|
xmlStr = xmlStr.replace("{rksj}", GDUtils.formatDate(data.getRksj(), "yyyy-MM-dd HH:mm:ss"));//入库时间
|
xmlStr = xmlStr.replace("{rksf}", GDUtils.formatNum(data.getRksf()));//入库水分
|
xmlStr = xmlStr.replace("{rkzz}", GDUtils.formatNum(data.getRkzz()));//入库杂质
|
xmlStr = xmlStr.replace("{cksl}", GDUtils.formatNum(data.getCkjz()));//出库数量
|
xmlStr = xmlStr.replace("{cksj}", GDUtils.formatDate(data.getCksj(), "yyyy-MM-dd HH:mm:ss"));//出库时间
|
xmlStr = xmlStr.replace("{ckzz}", GDUtils.formatNum(data.getCkzz()));//出库杂质
|
xmlStr = xmlStr.replace("{sysl}", GDUtils.formatNum(data.getJzsysl()));//损溢数量
|
xmlStr = xmlStr.replace("{syyy}", GDUtils.formatStr(data.getSyyy()));//损溢原因
|
xmlStr = xmlStr.replace("{ccshr}", GDUtils.formatStr(data.getCcshr()));//仓储审核人
|
xmlStr = xmlStr.replace("{zjshr}", GDUtils.formatStr(data.getZjshr()));//质检审核人
|
xmlStr = xmlStr.replace("{tjshr}", GDUtils.formatStr(data.getTjshr()));//统计审核人
|
xmlStr = xmlStr.replace("{ldshr}", GDUtils.formatStr(data.getLdshr()));//领导审核人
|
xmlStr = xmlStr.replace("{bz}", GDUtils.formatStr(data.getBz()));//备注
|
|
xmlStr = xmlStr.replace("{czbz}", GDUtils.formatStr(data.getCzbz()));//操作标志
|
xmlStr = xmlStr.replace("{zhgxsj}", GDUtils.formatDate(data.getZhgxsj(), "yyyy-MM-dd HH:mm:ss"));//最后更新时间
|
|
return xmlStr;
|
|
}
|
}
|