作者 zhangFan

some message

正在显示 45 个修改的文件 包含 1226 行增加116 行删除
#登录账号
#\u767B\u5F55\u8D26\u53F7
loginname = KKW1
#登录密码
#\u5361\u53E3\u6570\u636E\u63A5\u6536KKW1\uFF0C\u5361\u53E3\u53D1\u9001\u6570\u636EKAKO\uFF0C\u653E\u884C\u62A5\u6587 KKFX
#\u767B\u5F55\u5BC6\u7801
loginpass = KKW1
#发送报文目录,相对程序目录
#\u53D1\u9001\u62A5\u6587\u76EE\u5F55,\u76F8\u5BF9\u7A0B\u5E8F\u76EE\u5F55
readDirectory = D:/bw/sendDirectory
#接收存储报文目录
#\u63A5\u6536\u5B58\u50A8\u62A5\u6587\u76EE\u5F55
bakDirectory = D:/bw/receiveDirectory
#IMF MEAT报头配置
#IMF MEAT\u62A5\u5934\u914D\u7F6E
RCVR=
TYPE=KAKO
STYP=CARM
#载重与称重的可控范围 ?%
grossWt=15%
#\u8F7D\u91CD\u4E0E\u79F0\u91CD\u7684\u53EF\u63A7\u8303\u56F4 ?%
grossWt=5%
#二维码存放路径,项目启动时设置,后期不能更改。
barCode = barcode/
#\u4E8C\u7EF4\u7801\u5B58\u653E\u8DEF\u5F84\uFF0C\u9879\u76EE\u542F\u52A8\u65F6\u8BBE\u7F6E\uFF0C\u540E\u671F\u4E0D\u80FD\u66F4\u6539\u3002
#barCode = barcode/
... ...
... ... @@ -403,6 +403,23 @@
<scope>system</scope>
<systemPath>${project.basedir}/lib/connector.jar</systemPath>
</dependency>
<dependency>
<groupId>org.apache.httpcomponents</groupId>
<artifactId>httpclient</artifactId>
<version>4.5.5</version>
</dependency>
<dependency>
<groupId>org.apache.httpcomponents</groupId>
<artifactId>httpclient</artifactId>
<version>4.5.5</version>
</dependency>
<!--
<dependency>
<groupId>org.springframework</groupId>
<artifactId>spring-context</artifactId>
<version>5.2.0.M1</version>
</dependency>
-->
</dependencies>
... ...
Manifest-Version: 1.0
Class-Path: spring-boot-autoconfigure-2.1.0.RELEASE.jar geronimo-stax-
api_1.0_spec-1.0.1.jar spring-boot-starter-json-2.1.0.RELEASE.jar Xml
Schema-1.4.7.jar snakeyaml-1.23.jar log4j-to-slf4j-2.11.1.jar stax-ap
i-1.0.1.jar com.ibm.mq.defaultconfig.jar javax.annotation-api-1.3.2.j
ar ProcessService.jar jul-to-slf4j-1.7.25.jar druid-1.1.9.jar pagehel
per-spring-boot-autoconfigure-1.2.3.jar spring-boot-starter-web-2.1.0
.RELEASE.jar logback-core-1.2.3.jar wsdl4j-1.6.2.jar com.ibm.mq.fta.j
ar jackson-annotations-2.9.0.jar druid-spring-boot-starter-1.1.9.jar
commons-lang-2.4.jar jboss-logging-3.3.2.Final.jar xml-apis-1.4.01.ja
r com.ibm.mq.jms.Nojndi.jar jackson-databind-2.9.7.jar spring-boot-2.
1.0.RELEASE.jar hibernate-validator-6.0.13.Final.jar mybatis-spring-b
oot-starter-1.3.2.jar mybatis-spring-boot-autoconfigure-1.3.2.jar mys
ql-connector-java-8.0.13.jar UploadService.jar com.ibm.mq.jmqi.jar co
m.ibm.mqjms.jar fastjson-1.2.47.jar spring-jcl-5.1.2.RELEASE.jar xmls
ec-1.4.4.jar jackson-datatype-jdk8-2.9.7.jar apiConfig.jar sigar.jar
com.ibm.mq.axis2.jar spring-aop-5.1.2.RELEASE.jar spring-webmvc-5.1.2
.RELEASE.jar log4j-1.2.17.jar CL3Export.jar mybatis-spring-1.3.2.jar
geronimo-javamail_1.4_spec-1.2.jar mybatis-3.4.6.jar log4j-api-2.11.1
.jar commons-codec-1.11.jar spring-tx-5.1.2.RELEASE.jar com.ibm.mq.so
ap.jar com.ibm.mqetclient.jar jackson-core-2.9.7.jar com.ibm.mq.postc
ard.jar spring-core-5.1.2.RELEASE.jar xmlpull-1.1.3.1.jar xpp3_min-1.
1.4c.jar geronimo-activation_1.1_spec-1.0.1.jar HikariCP-3.2.0.jar sp
ring-boot-starter-2.1.0.RELEASE.jar xmlbeans-2.4.0.jar cxf-2.3.2.jar
spring-boot-starter-logging-2.1.0.RELEASE.jar logback-classic-1.2.3.j
ar jsqlparser-1.0.jar axiom-api-1.2.7.jar com.ibm.mq.pcf.jar jackson-
module-parameter-names-2.9.7.jar cxf-xjc-bug671-2.3.2.jar validation-
api-2.0.1.Final.jar IMFClient.1.0.0.jar httpcore-4.4.10.jar Heartbeat
Service.jar slf4j-api-1.7.25.jar axiom-impl-1.2.7.jar xstream-1.4.10.
jar commons-logging-1.1.1.jar neethi-2.0.4.jar pagehelper-spring-boot
-starter-1.2.3.jar com.ibm.mq.headers.jar com.ibm.mq.jar core-3.3.0.j
ar spring-jdbc-5.1.2.RELEASE.jar httpclient-4.5.5.jar mybatis-generat
or-core-1.3.6.jar spring-beans-5.1.2.RELEASE.jar CL3Nonexport.jar dom
4j-2.1.0.jar jaxen-1.1.6.jar imfmsg.jar com.ibm.mq.tools.ras.jar clas
smate-1.4.0.jar wstx-asl-3.2.4.jar returnXml.jar cxf-xjc-boolean-3.2.
3.jar spring-expression-5.1.2.RELEASE.jar cxf-xjc-dv-2.3.2.jar pagehe
lper-5.1.2.jar cxf-manifest.jar com.ibm.mq.commonservices.jar cxf-xjc
-ts-2.3.2.jar spring-context-5.1.2.RELEASE.jar jackson-datatype-jsr31
0-2.9.7.jar spring-web-5.1.2.RELEASE.jar spring-boot-starter-jdbc-2.1
.0.RELEASE.jar commons-io-2.5.jar connector.jar
Main-Class: com.sy.AnalysisImfApplication
... ...
... ... @@ -34,21 +34,19 @@ public class IMF_Tesk {
logger.info("*********KAKO读取线程已开启-不再启动线程*********");
}
if(!KAKO_Sender.isrunning){
/* if(!KAKO_Sender.isrunning){
KAKO_Sender kako_sender = new KAKO_Sender(client);
kako_sender.start();
logger.info("<<<<<<<<<KAKO发送线程已开启>>>>>>>>>>>>");
}else {
logger.info("<<<<<<<<<KAKO发送线程已开启-不再启动线程>>>>>>>>>>>>");
}
}*/
}
if (!LOGIN_OK){
loginIMF(client, loginname, loginpass, "config/imf_config.properties");
}
}
private static void loginIMF(IMFClient client, String userName, String password, String confFileName) {
... ...
... ... @@ -21,7 +21,7 @@ public class KAKO_Reader extends Thread{
if (IMF_Tesk.LOGIN_OK) synchronized (this) {
String message = this.client.getMSG();
if (message != null) {
logger.info(message);
// logger.info(message);
AnalysisRoute.analysis(message);
}
}
... ...
... ... @@ -31,7 +31,7 @@ public class KAKO_Sender extends Thread{
String TYPE = FileTool.readProperties("TYPE");
String STYP = FileTool.readProperties("STYP");
String RCVR = FileTool.readProperties("RCVR");
String DDTM = DateTimeConverter.getFormat();
String DDTM = DateTimeConverter.dateFormat();
String SEQN = DDTM;
if (this.client == null) {
... ...
... ... @@ -5,6 +5,7 @@ import com.sy.logic.LogicOperation;
import com.sy.model.*;
import com.sy.service.*;
import org.apache.log4j.Logger;
import org.apache.log4j.PropertyConfigurator;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Component;
... ... @@ -36,6 +37,9 @@ public class AnalysisRoute {
@Autowired
private LandBusListService listService;
@Autowired
private ResMessageService resMessageService;
protected static final Logger logger = Logger.getLogger(AnalysisRoute.class);
private static AnalysisRoute route;
... ... @@ -47,6 +51,7 @@ public class AnalysisRoute {
private static GATAnaluysis gatAnaluysis = new GATAnaluysis();
private static GatherInfoAnalysis gatherInfoAnalysis = new GatherInfoAnalysis();
private static CommandInfoAnalysis commandInfoAnalysis = new CommandInfoAnalysis();
private static ResMessageAnalysis resMessageAnalysis = new ResMessageAnalysis();
@PostConstruct
public void init(){
... ... @@ -58,10 +63,13 @@ public class AnalysisRoute {
route.infoService = this.infoService;
route.commandService = this.commandService;
route.listService = this.listService;
route.resMessageService = this.resMessageService;
}
public static void analysis(String string) {
Message message = analysis.readTicketsXml(string);
PropertyConfigurator.configure("config/log4j.properties");
string = string.replace("Msg","MSG");
Message message = analysis.readTicketsXml(string);;
String stype = message.getMeta().getSmType();
if (stype.equals("CARM")) {
if(message.getComInfo() !=null){
... ... @@ -69,8 +77,25 @@ public class AnalysisRoute {
route.commandService.save(info);
}else{
GatherInfo info = gatherInfoAnalysis.toJavaBean(message);
if(LogicOperation.operation(info)){
logger.info("进出站业务申请成功");
if(info.getBarcode().length()>0){
if(LogicOperation.operation(info)){
String type = null;
if("I".equals(info.getIetype())){
type="进入";
}else{
type="离开";
}
logger.info("进出站业务申请成功");
logger.info("------->>>>>>>"+info.getVename()+"已"+type+info.getAreaid()+"场站<<<<<<<-----");
}
}else{
if("4604000000".equals(info.getAreaid())){
if("I".equals(info.getIetype())){
LogicOperation.sendData("HK05",info.getVename(),false);
}else{
LogicOperation.sendData("HK06",info.getVename(),false);
}
}
}
route.infoService.save(info);
}
... ... @@ -92,6 +117,14 @@ public class AnalysisRoute {
}
port_manifest_head_stat portStat = gatAnaluysis.toPortStat(message);
route.gatService.savePortStat(portStat);
} else if(stype.equals("CDHZ")){
if("MT9999".equals(message.getManifest().getHead().getMessageType())){
RESMESSAGE resmessage = resMessageAnalysis.saveEntry(message.getManifest());
RESMESSAGE msg =route.resMessageService.selectByManifest(resmessage.getManifest());
if(msg==null){
route.resMessageService.saveEnter(resmessage);
}
}
}
}
... ...
package com.sy.bwAnalysis;
import com.sy.bwAssist.CommandInfo;
import com.sy.bwAssist.commandInfo.CommandInfo;
import com.sy.bwAssist.Message;
import com.sy.bwAssist.Meta;
import com.sy.model.commandInfo;
... ...
package com.sy.bwAnalysis;
import com.sy.bwAssist.GatherInfoAssist;
import com.sy.bwAssist.gatherInfo.GatherInfoAssist;
import com.sy.bwAssist.Message;
import com.sy.bwAssist.Meta;
import com.sy.model.GatherInfo;
... ...
... ... @@ -7,7 +7,7 @@ import com.thoughtworks.xstream.io.xml.XmlFriendlyNameCoder;
public class MessageAnalysis {
public static Message msg = null;
public static Message message = null;
public Message readTicketsXml(String str) {
return getMessage(str);
... ... @@ -16,10 +16,30 @@ public class MessageAnalysis {
static Message getMessage(String str) {
XStream xstream = new XStream(new DomDriver("UTF-8", new XmlFriendlyNameCoder("_-", "_")));
xstream.processAnnotations(Message.class);
msg = (Message) xstream.fromXML(str);
System.out.println("解析后的Message对象" + msg);
return msg;
//对xstream对象设置默认的安全防护
XStream.setupDefaultSecurity(xstream);
//对xstream对象设置默认的安全防护时,允许设置类
xstream.allowTypes(new Class[]{Message.class});
message = (Message) xstream.fromXML(str);
return message;
}
/* public static void main(String[] args) {
Message msg = new MessageAnalysis().readTicketsXml("<MSG> \n" +
" <META> \n" +
" <SNDR>NXCD</SNDR> \n" +
" <RCVR/> \n" +
" <SEQN>20190423105931</SEQN> \n" +
" <DDTM>20190423105931</DDTM> \n" +
" <TYPE>CUST</TYPE> \n" +
" <STYP>CDHZ</STYP> \n" +
" </META> \n" +
" <Manifest><Head><MessageID>CN_MT5202_1P0_460470678920X_20190423105611544</MessageID><FunctionCode>2</FunctionCode><MessageType>MT5202</MessageType><SenderID>EPORT</SenderID><ReceiverID>460470678920X_DXPENT0000019806</ReceiverID><SendTime>20190423105647834</SendTime><Version>1.0</Version></Head><Response><BorderTransportMeans><JourneyID>7L062/20190420</JourneyID><ID>7L062</ID></BorderTransportMeans><Consignment><TransportContractDocument><ID>50106370991</ID></TransportContractDocument><ResponseType><Code>01</Code><Text>35301 理货报告传输成功。比对结果为:理货正常。</Text></ResponseType></Consignment></Response></Manifest>\n" +
" </MSG>");
RESMESSAGE resmessage = new ResMessageAnalysis().saveEntry(msg.getManifest());
System.out.println(resmessage);
}*/
}
... ...
package com.sy.bwAnalysis;
import com.sy.bwAssist.ResMessage.Manifest;
import com.sy.model.RESMESSAGE;
/**
* @author
* @time 2019-${MOUTH}-22 21:28
*/
public class ResMessageAnalysis {
public RESMESSAGE saveEntry(Manifest manifest){
RESMESSAGE resmessage = new RESMESSAGE();
resmessage.setId(String.valueOf(System.currentTimeMillis()));
resmessage.setJourneyid(manifest.getResponse().getBorderTransportMeans().getJourneyID());
resmessage.setManifest(manifest.getResponse().getConsignment().getTransportContractDocument().getId());
resmessage.setResponsecode(manifest.getResponse().getConsignment().getResponseType().getCode());
resmessage.setResponsetext(manifest.getResponse().getConsignment().getResponseType().getText());
return resmessage;
}
}
... ...
package com.sy.bwAssist;
import com.sy.bwAssist.ResMessage.Manifest;
import com.sy.bwAssist.commandInfo.CommandInfo;
import com.sy.bwAssist.gatherInfo.GatherInfoAssist;
import com.thoughtworks.xstream.annotations.XStreamAlias;
import org.springframework.stereotype.Component;
... ... @@ -19,6 +22,10 @@ public class Message {
@XStreamAlias("DTC_Message")
private DTC_Message message;
@XStreamAlias("Manifest")
private Manifest manifest;
public DTC_Message getMessage() {
return message;
}
... ... @@ -50,6 +57,16 @@ public class Message {
public void setComInfo(CommandInfo comInfo) {
ComInfo = comInfo;
}
public Manifest getManifest() {
return manifest;
}
public void setManifest(Manifest manifest) {
this.manifest = manifest;
}
}
... ...
package com.sy.bwAssist.ResMessage;
import com.thoughtworks.xstream.annotations.XStreamAlias;
/**
* @author
* @time 2019-${MOUTH}-23 10:55
*/
public class AssociatedTransportDocument {
@XStreamAlias("ID")
private String ID;
public String getID() {
return ID;
}
public void setID(String ID) {
this.ID = ID;
}
}
... ...
package com.sy.bwAssist.ResMessage;
import com.thoughtworks.xstream.annotations.XStreamAlias;
import com.thoughtworks.xstream.annotations.XStreamOmitField;
import org.springframework.stereotype.Component;
/**
* @author
* @time 2019-${MOUTH}-22 19:27
*/
@Component
public class BorderTransportMeans {
@XStreamAlias("JourneyID")
private String JourneyID;
@XStreamAlias("ID")
@XStreamOmitField
private String id;
public String getJourneyID() {
return JourneyID;
}
public void setJourneyID(String journeyID) {
JourneyID = journeyID;
}
public String getId() {
return id;
}
public void setId(String id) {
this.id = id;
}
}
... ...
package com.sy.bwAssist.ResMessage;
import com.thoughtworks.xstream.annotations.XStreamAlias;
import com.thoughtworks.xstream.annotations.XStreamOmitField;
import org.springframework.stereotype.Component;
/**
* @author
* @time 2019-${MOUTH}-22 19:27
*/
@Component
public class Consignment {
@XStreamAlias("ResponseType")
private ResponseType responseType;
@XStreamAlias("TransportContractDocument")
private TransportContractDocument transportContractDocument;
@XStreamOmitField
@XStreamAlias("AssociatedTransportDocument")
private AssociatedTransportDocument associatedTransportDocument;
public ResponseType getResponseType() {
return responseType;
}
public void setResponseType(ResponseType responseType) {
this.responseType = responseType;
}
public TransportContractDocument getTransportContractDocument() {
return transportContractDocument;
}
public void setTransportContractDocument(TransportContractDocument transportContractDocument) {
this.transportContractDocument = transportContractDocument;
}
}
... ...
package com.sy.bwAssist.ResMessage;
import com.sy.utils.DateTimeConverter;
import com.thoughtworks.xstream.annotations.XStreamAlias;
import com.thoughtworks.xstream.annotations.XStreamConverter;
import java.util.Date;
/**
* @author
* @time 2019-${MOUTH}-22 19:22
*/
public class Head {
@XStreamAlias("MessageID")
private String MessageID;
@XStreamAlias("FunctionCode")
private String FunctionCode;
@XStreamAlias("MessageType")
private String MessageType;
@XStreamAlias("SenderID")
private String SenderID;
@XStreamAlias("ReceiverID")
private String ReceiverID;
@XStreamAlias("SendTime")
@XStreamConverter(value=DateTimeConverter.class)
private Date SendTime;
@XStreamAlias("Version")
private String Version;
public String getMessageID() {
return MessageID;
}
public void setMessageID(String messageID) {
MessageID = messageID;
}
public String getFunctionCode() {
return FunctionCode;
}
public void setFunctionCode(String functionCode) {
FunctionCode = functionCode;
}
public String getMessageType() {
return MessageType;
}
public void setMessageType(String messageType) {
MessageType = messageType;
}
public String getSenderID() {
return SenderID;
}
public void setSenderID(String senderID) {
SenderID = senderID;
}
public String getReceiverID() {
return ReceiverID;
}
public void setReceiverID(String receiverID) {
ReceiverID = receiverID;
}
public Date getSendTime() {
return SendTime;
}
public void setSendTime(Date sendTime) {
SendTime = sendTime;
}
public String getVersion() {
return Version;
}
public void setVersion(String version) {
Version = version;
}
}
... ...
package com.sy.bwAssist.ResMessage;
import com.thoughtworks.xstream.annotations.XStreamAlias;
/**
* @author
* @time 2019-${MOUTH}-22 19:21
*/
public class Manifest {
@XStreamAlias("Head")
private Head head;
@XStreamAlias("Response")
private Response response;
public Head getHead() {
return head;
}
public void setHead(Head head) {
this.head = head;
}
public Response getResponse() {
return response;
}
public void setResponse(Response response) {
this.response = response;
}
}
... ...
package com.sy.bwAssist.ResMessage;
import com.thoughtworks.xstream.annotations.XStreamAlias;
import org.springframework.stereotype.Component;
/**
* @author
* @time 2019-${MOUTH}-22 19:22
*/
@Component
public class Response {
@XStreamAlias("BorderTransportMeans")
private BorderTransportMeans borderTransportMeans;
@XStreamAlias("Consignment")
private Consignment consignment;
public BorderTransportMeans getBorderTransportMeans() {
return borderTransportMeans;
}
public void setBorderTransportMeans(BorderTransportMeans borderTransportMeans) {
this.borderTransportMeans = borderTransportMeans;
}
public Consignment getConsignment() {
return consignment;
}
public void setConsignment(Consignment consignment) {
this.consignment = consignment;
}
}
... ...
package com.sy.bwAssist.ResMessage;
import com.thoughtworks.xstream.annotations.XStreamAlias;
/**
* @author
* @time 2019-${MOUTH}-22 19:29
*/
public class ResponseType {
@XStreamAlias("Code")
private String code;
@XStreamAlias("Text")
private String text;
public String getCode() {
return code;
}
public void setCode(String code) {
this.code = code;
}
public String getText() {
return text;
}
public void setText(String text) {
this.text = text;
}
}
... ...
package com.sy.bwAssist.ResMessage;
import com.thoughtworks.xstream.annotations.XStreamAlias;
import org.springframework.stereotype.Component;
/**
* @author
* @time 2019-${MOUTH}-22 19:29
*/
@Component
public class TransportContractDocument {
@XStreamAlias("ID")
private String id;
public String getId() {
return id;
}
public void setId(String id) {
this.id = id;
}
}
... ...
package com.sy.bwAssist;
package com.sy.bwAssist.commandInfo;
import com.sy.bwAssist.gatherInfo.Seal;
import com.thoughtworks.xstream.annotations.XStreamAlias;
import com.thoughtworks.xstream.annotations.XStreamAsAttribute;
import org.springframework.stereotype.Component;
... ...
package com.sy.bwAssist;
package com.sy.bwAssist.commandInfo;
import com.thoughtworks.xstream.annotations.XStreamAlias;
/**
* @author zhangfan
* @web www.sy.com
* @company 郑州商友科技有限公司
* @company
* @time 2018-12-27 16:10
*/
public class GPS {
... ...
package com.sy.bwAssist;
package com.sy.bwAssist.gatherInfo;
import com.sy.utils.NumberConverter;
import com.thoughtworks.xstream.annotations.XStreamAlias;
... ...
package com.sy.bwAssist;
package com.sy.bwAssist.gatherInfo;
import com.thoughtworks.xstream.annotations.XStreamAlias;
... ...
package com.sy.bwAssist;
package com.sy.bwAssist.gatherInfo;
import com.thoughtworks.xstream.annotations.XStreamAlias;
import com.thoughtworks.xstream.annotations.XStreamAsAttribute;
... ...
package com.sy.bwAssist;
package com.sy.bwAssist.gatherInfo;
import com.sy.utils.DateTimeConverter;
import com.sy.utils.NumberConverter;
... ...
package com.sy.bwAssist;
package com.sy.bwAssist.gatherInfo;
import com.thoughtworks.xstream.annotations.XStreamAlias;
... ...
package com.sy.bwAssist;
package com.sy.bwAssist.gatherInfo;
import com.thoughtworks.xstream.annotations.XStreamAlias;
... ...
... ... @@ -7,11 +7,20 @@ import com.sy.crossDomain.buildBarCode;
import com.sy.model.GatherInfo;
import com.sy.model.LandBusinessTypeList;
import com.sy.model.LandRoadVe;
import com.sy.model.RESMESSAGE;
import com.sy.service.LandBusListService;
import com.sy.service.LandRoadVeService;
import com.sy.service.ResMessageService;
import com.sy.socket.CommandClient;
import com.sy.utils.FileTool;
import org.apache.http.HttpEntity;
import org.apache.http.HttpResponse;
import org.apache.http.client.HttpClient;
import org.apache.http.client.methods.HttpGet;
import org.apache.http.impl.client.DefaultHttpClient;
import org.apache.http.util.EntityUtils;
import org.apache.log4j.Logger;
import org.apache.log4j.PropertyConfigurator;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Component;
... ... @@ -19,13 +28,13 @@ import javax.annotation.PostConstruct;
import java.io.BufferedReader;
import java.io.IOException;
import java.io.InputStreamReader;
import java.math.BigDecimal;
import java.net.MalformedURLException;
import java.net.URL;
import java.net.URLConnection;
import java.text.DecimalFormat;
import java.text.NumberFormat;
import java.text.ParseException;
import java.util.Date;
import java.util.List;
import java.util.Map;
... ... @@ -40,6 +49,9 @@ public class LogicOperation {
@Autowired
private LandRoadVeService veService;
@Autowired
private ResMessageService resMessageService;
private static LogicOperation logic;
//读取配置文件里的载重与称重的可控范围
... ... @@ -48,16 +60,19 @@ public class LogicOperation {
//逻辑判断后的结果定义
private static String PERMITTHOUGH = "直接放行";
private static String GROWSSEXCETION = "禁止通行,重量不在可控范围";
private static String NORECORD = "车辆未备案";
private static String NORECORD = "车辆未备案或者识别错误,车牌号:";
private static String INPUTSTATION = "此车辆未做进站申请";
private static String ENTERSTATION = "此车辆未做出站申请";
private static String ISVALID = "二维码已失效或者此车辆未做出入申请";
private static String ISVALID = "二维码数据异常,请使用正确的二维码数据";
private static String ERRORWT="出起始场站的重量和进目的场站的重量不一致";
private static String IEPORSE="无相对应进出场申请";
@PostConstruct
public void init() {
logic = this;
logic.listService = this.listService;
logic.veService = this.veService;
logic.resMessageService = this.resMessageService;
}
/**
... ... @@ -65,60 +80,157 @@ public class LogicOperation {
* @Result 计算卡口采集数据并发送报文
*/
public static boolean operation(GatherInfo info) {
PropertyConfigurator.configure("config/log4j.properties");
boolean result = false;
if(info.getBarcode()==null || info.getBarcode().length()<=0 ){
return result;
}
BigDecimal grosswt = info.getGrosswt();
//转为double类型
double growssWt = grosswt.doubleValue();
String ietype = info.getIetype();
List<LandBusinessTypeList> lists = null;
double growssWt = info.getGrosswt().doubleValue();
String vaName = info.getVename();
if(vaName==null || vaName.length()<=0 ){
if (vaName.length() <= 0) {
CommandClient.Client(info, NORECORD + vaName);
return result;
}
LandRoadVe ve = logic.veService.selectByFrameNo(vaName);
LandBusinessTypeList list = logic.listService.selectForOne(info.getVename(),info.getBarcode(),info.getAreaid
(),info.getChnlno(),info.getIetype());
if("0".equals(list.getIsvalid())){
if (ve == null) {
CommandClient.Client(info, NORECORD + vaName);
return result;
}
LandBusinessTypeList list = logic.listService.selectForOne(info.getVename(), info.getBarcode(), info.getAreaid
(), info.getChnlno(), info.getIetype());
if(list == null) {
CommandClient.Client(info, IEPORSE);
return result;
}
//判断是否失效
if ("0".equals(list.getIsvalid())) {
//获取总重
double goodsWt = 0.0;
if (list.getMasterList()!=null || list.getMasterList().length()>0 ) {
goodsWt = GoodsWt(list.getMasterList(), info.getIetype());
if (list.getMasterList() != null || list.getMasterList().length() > 0) {
String type = null;
if ("进口提货".equals(list.getBusinesstype()) || "分拨业务".equals(list.getBusinesstype())) {
type = "I";
}
if ("出口送货".equals(list.getBusinesstype()) || "调拨业务".equals(list.getBusinesstype())) {
type = "E";
}
logger.info("=======================>>>>>>>>>>" + type + "<<<<<<<<<<========================");
goodsWt = GoodsWt(list.getMasterList(), type);
}
//车自重
double selfWt = Double.parseDouble(ve.getSelfWt());
if (sendBw(info, growssWt, selfWt, goodsWt)) {
if (!logic.checkFlag(growssWt, (selfWt+goodsWt))) {
List<LandBusinessTypeList> typeLists = logic.listService.selectMessageId(list.getMassageId());
for (int i = 0; i < typeLists.size(); i++) {
if ("进口提货".equals(list.getBusinesstype())) {
if ("E".equals(list.getTurnoverflag())) {
if ("I".equals(typeLists.get(i).getTurnoverflag()) && typeLists.get(i).getContrastflag() != null) {
selfWt = typeLists.get(i).getAislewt() > 1 ? typeLists.get(i).getAislewt() : selfWt;
break;
}
}
}
if ("出口送货".equals(list.getBusinesstype())){
if ("E".equals(list.getTurnoverflag())) {
if ("I".equals(typeLists.get(i).getTurnoverflag()) && typeLists.get(i).getContrastflag() != null) {
if("1".equals(list.getIsfull())){
if(list.getMasterList().length()>0){
selfWt = typeLists.get(i).getAislewt()-Double.parseDouble(typeLists.get(i).getRemark());
}else {
selfWt=growssWt;
}
}
break;
}
}
}
if(list.getBusinesstype().endsWith("流转")){
if(list.getMasterList().length()>0){
if ("E".equals(list.getTurnoverflag())) {
if ("I".equals(typeLists.get(i).getTurnoverflag()) && typeLists.get(i).getContrastflag() != null) {
selfWt = typeLists.get(i).getAislewt() > 1 ? typeLists.get(i).getAislewt() : selfWt;
break;
}
}
if ("I".equals(list.getTurnoverflag())) {
if ("E".equals(typeLists.get(i).getTurnoverflag()) && typeLists.get(i).getContrastflag() != null) {
if(!logic.checkFlag(growssWt,typeLists.get(i).getAislewt())){
logger.info("-------->>>>>>>>出起始场站的重量和进目的场站的总量不一致<<<<<<<<--------");
CommandClient.Client(info, ERRORWT);
return result;
}
}
}
}
}
}
}
boolean check = checkResult(growssWt, selfWt, goodsWt);
boolean checkMainfest = logic.checkManifest(list.getMasterList());
boolean checkResult = false;
if ("E".equals(list.getTurnoverflag())) {
checkResult = checkMainfest || check;
} else {
checkResult = check || checkMainfest;
}
//宽进
if ("I".equals(info.getIetype())) {
if (check == false && checkResult == false) {
checkResult = true;
}
}
logger.info("重量校验结果:"+check+",运单校验结果:"+checkMainfest+",最终校验结果:"+checkResult);
if (sendBw(info, checkResult)) {
if ("I".equals(info.getIetype())) {
System.out.println(info.getGrosswt().doubleValue());
list.setAislewt(info.getGrosswt().doubleValue());
list.setUpdateDate(new Date());
list.setRemark(String.format("%.1f",goodsWt));
list.setContrastflag("已进站");
logic.checkData(list);
} else {
list.setAislewt(info.getGrosswt().doubleValue());
list.setUpdateDate(new Date());
list.setRemark(String.format("%.1f",goodsWt));
list.setContrastflag("已出站");
logic.checkData(list);
}
logic.listService.updateById(list);
int row = logic.listService.updateById(list);
System.out.println(row);
List<LandBusinessTypeList> businessTypeLists = logic.listService.selectByBarcode(info.getBarcode());
int count = 0;
for(int i=0; i<businessTypeLists.size(); i++){
for (int i = 0; i < businessTypeLists.size(); i++) {
String flag1 = businessTypeLists.get(i).getContrastflag();
if(flag1 != null){
if (flag1 != null) {
count++;
}
}
if("货物流转".equals(list.getBusinesstype())){
if(count==4){
if (list.getBusinesstype().indexOf("业务") > 0) {
if (count == 4) {
buildBarCode.cancleBarCode(vaName);
logic.listService.updateByBarcode(info.getBarcode());
}
}else{
if(count==2){
} else {
if (count == 2) {
buildBarCode.cancleBarCode(vaName);
logic.listService.updateByBarcode(info.getBarcode());
}
}
result = true;
}
}else{
CommandClient.Client(info, ISVALID);
} else {
sendError(info);
logger.error("------->>>>>>>二维码数据异常,请使用正确的二维码数据<<<<<<<-----");
}
return result;
}
... ... @@ -136,20 +248,21 @@ public class LogicOperation {
}
/**
* 校验载重和称重是否在合理的范围
*
* @Param grossWt 地磅称重
* @Param wt 车辆自重
* @Param goodsWt 货物总重
* @Result 获取运单重量
*/
//校验载重和称重是否在合理的范围
public static boolean checkResult(double grossWt, double wt, double goodsWt) {
DecimalFormat df=new DecimalFormat("0.00");
DecimalFormat df = new DecimalFormat("0.00");
boolean flag = false;
double result = 0.0;
if (goodsWt > 0) {
result = Double.parseDouble(df.format(Math.abs((goodsWt+wt-grossWt)/grossWt)));
result = Double.parseDouble(df.format(Math.abs((goodsWt + wt - grossWt)) / grossWt));
} else {
result = Double.parseDouble(df.format(Math.abs((grossWt - wt)/grossWt)));
result = Double.parseDouble(df.format(Math.abs((grossWt - wt)) / grossWt));
}
if (result <= valueDob()) {
flag = true;
... ... @@ -173,6 +286,31 @@ public class LogicOperation {
return sum;
}
/**
* 查询运单是否全部放行
*
* @param manifestList
* @return
*/
public boolean checkManifest(String manifestList) {
if (manifestList.length() < 1) return false;
manifestList = manifestList.replace("-", "");
String[] maifest = manifestList.split(",");
boolean flag = false;
int count = 0;
for (int i = 0; i < maifest.length; i++) {
RESMESSAGE resmessage = logic.resMessageService.selectByManifest(maifest[i]);
if(resmessage !=null){
if ("11".equals(resmessage.getResponsecode())) {
count++;
}
}
}
if (count == maifest.length) {
flag = true;
}
return flag;
}
/**
* @Param waybill 主单号
... ... @@ -180,7 +318,9 @@ public class LogicOperation {
* @Result 获取运单重量
*/
public static double getGrossWt(String waybill, String imp) {
String url = "http://tjfx.15miaoo.com:8003/tj/orig/orig?waybill=" + waybill + "&imp=" + imp;
// logger.info("进入获取重量action");
String url = "http://10.50.3.64:8080/tj/orig/orig?waybill=" + waybill + "&imp=" + imp;
// String url = "http://tjfx.15miaoo.com:8003/tj/orig/orig=" + waybill + "&imp=" + imp;
StringBuilder json = new StringBuilder();
Map map = null;
double bg = 0;
... ... @@ -192,37 +332,121 @@ public class LogicOperation {
while ((inputLine = in.readLine()) != null) {
json.append(inputLine);
}
// logger.info("返回数据:" + json);
JSONArray array = JSONArray.parseArray(json.toString());
for (int i = 0; i < array.size(); i++) {
map = JSON.parseObject(array.getString(i));
if (map.get("receiptinformation").toString().startsWith("41301") || map.get("receiptinformation")
.toString().startsWith("41106")) {
bg = Double.parseDouble((String) map.get("totalweight"));
return bg;
System.out.println(map);
if(map.containsKey("receiptinformation")){
if (map.get("receiptinformation").toString().startsWith("41301") || map.get("receiptinformation")
.toString().startsWith("41106") || map.get("receiptinformation")
.toString().startsWith("31301") || map.get("receiptinformation")
.toString().startsWith("31106") || map.get("receiptinformation")
.toString().indexOf("提运单放行")!=-1) {
bg = Double.parseDouble((String) map.get("totalweight"));
logger.info("for循环取重量:" + bg);
return bg;
}
}
}
// logger.info("访问返回的数据重量:" + bg);
in.close();
} catch (MalformedURLException e) {
e.getMessage();
// logger.info(e.toString());
} catch (IOException e) {
e.getMessage();
// logger.info(e.toString());
}
return bg;
}
/**
* 给码头发送卡口数据
*
* @param stationCode
* @param carNo
* @param IEtype
*/
public static void sendData(String stationCode, String carNo, boolean IEtype) {
String url = "http://10.50.3.73:8080/air-api/car/channelCar?stationCode=" + stationCode + "&carNo=" + carNo + "&isPickup=" + IEtype;
try {
HttpClient httpClient = new DefaultHttpClient();
HttpGet httpGet = new HttpGet(url);
HttpResponse httpResponse = httpClient.execute(httpGet);
HttpEntity entity = httpResponse.getEntity();
String entityStr = EntityUtils.toString(entity);
logger.info("------------>>>>>>>>>>>>>>发送车辆信息:{stationCode:" + stationCode + ",carNo:" + carNo + ",isPickup:" + IEtype + "}");
logger.info("------------>>>>>>>>>>>>>>响应返回内容:" + entityStr + "<<<<<<<<<<<<-----------");
} catch (Exception e) {
logger.info(e.toString());
}
}
/**
* 给码头发送卡口数据
*
* @param list
*/
public void checkData(LandBusinessTypeList list) {
String sationCode = null;
boolean flag = false;
if ("出口送货".equals(list.getBusinesstype()) || "出口流转".equals(list.getBusinesstype())) {
flag = false;
}
if ("进口提货".equals(list.getBusinesstype()) || "进口流转".equals(list.getBusinesstype())) {
flag = true;
}
if ("4604000000".equals(list.getEndstation())) {
if ("I".equals(list.getTurnoverflag())) {
sationCode = "HK05";
} else {
sationCode = "HK06";
}
}
sendData(sationCode, list.getTrailerFrameNo(), flag);
}
/**
* 校验重量并发送报文
*/
public static boolean sendBw(GatherInfo info, double growsswWt, double selfWt, double goodsWt) {
public static boolean sendBw(GatherInfo info, boolean check) {
boolean flag = false;
if (checkResult(growsswWt, selfWt, goodsWt)) {
if (check) {
CommandClient.Client(info, PERMITTHOUGH);
logger.info("=============>>>>>>>>放行报文发送成功<<<<<<<<<==============");
flag = true;
} else {
CommandClient.Client(info, GROWSSEXCETION);
logger.info("=============>>>>>>>>重量异常报文发送成功<<<<<<<<<==============");
}
return flag;
}
/**
* 排除当前系统问题发送错误commandInfo
*/
public static void sendError(GatherInfo info) {
CommandClient.Client(info, ISVALID);
}
/**
* 判断空车车与地磅称重是否在合理范围
*
* @param grossWt
* @param wt
* @return
*/
public boolean checkFlag(double grossWt, double wt) {
DecimalFormat df = new DecimalFormat("0.00");
boolean flag = false;
double reult = Double.parseDouble(df.format(Math.abs((grossWt - wt)) / grossWt));
if (reult <= valueDob()) {
flag = true;
}
return flag;
}
}
... ...
... ... @@ -30,5 +30,9 @@ public interface LandBusinessTypeListMapper {
List<LandBusinessTypeList> selectByBarcode(@Param("barcode")String barcode);
int updateByBarCode(@Param("barcode")String barcode);
List<LandBusinessTypeList> selectMessageId(@Param("massageId")String messageId);
}
\ No newline at end of file
... ...
package com.sy.mapper;
import com.sy.model.LandRoadVe;
import org.apache.ibatis.annotations.Param;
import org.springframework.stereotype.Component;
@Component
... ... @@ -17,5 +18,5 @@ public interface LandRoadVeMapper {
int updateByPrimaryKey(LandRoadVe record);
//根据车牌号查询
LandRoadVe selectByFrameNo(String frameNo);
LandRoadVe selectByFrameNo(@Param("domesticLisenceNo") String frameNo);
}
\ No newline at end of file
... ...
package com.sy.mapper;
import com.sy.model.RESMESSAGE;
import org.apache.ibatis.annotations.Param;
import org.springframework.stereotype.Component;
@Component
public interface RESMESSAGEMapper {
int deleteByPrimaryKey(String id);
int insert(RESMESSAGE record);
int insertSelective(RESMESSAGE record);
RESMESSAGE selectByPrimaryKey(String id);
int updateByPrimaryKeySelective(RESMESSAGE record);
int updateByPrimaryKey(RESMESSAGE record);
RESMESSAGE selectByManifest(@Param("manifest") String manifest);
}
\ No newline at end of file
... ...
... ... @@ -55,6 +55,16 @@ public class LandBusinessTypeList {
private String isvalid;
private Double aislewt;
private String isfull;
private String remark;
private String remark1;
private String remark2;
public String getId() {
return id;
}
... ... @@ -262,4 +272,44 @@ public class LandBusinessTypeList {
public void setIsvalid(String isvalid) {
this.isvalid = isvalid == null ? null : isvalid.trim();
}
public Double getAislewt() {
return aislewt;
}
public void setAislewt(Double aislewt) {
this.aislewt = aislewt;
}
public String getIsfull() {
return isfull;
}
public void setIsfull(String isfull) {
this.isfull = isfull == null ? null : isfull.trim();
}
public String getRemark() {
return remark;
}
public void setRemark(String remark) {
this.remark = remark == null ? null : remark.trim();
}
public String getRemark1() {
return remark1;
}
public void setRemark1(String remark1) {
this.remark1 = remark1 == null ? null : remark1.trim();
}
public String getRemark2() {
return remark2;
}
public void setRemark2(String remark2) {
this.remark2 = remark2 == null ? null : remark2.trim();
}
}
\ No newline at end of file
... ...
package com.sy.model;
public class RESMESSAGE {
private String id;
private String journeyid;
private String manifest;
private String responsecode;
private String responsetext;
public String getId() {
return id;
}
public void setId(String id) {
this.id = id == null ? null : id.trim();
}
public String getJourneyid() {
return journeyid;
}
public void setJourneyid(String journeyid) {
this.journeyid = journeyid == null ? null : journeyid.trim();
}
public String getManifest() {
return manifest;
}
public void setManifest(String manifest) {
this.manifest = manifest == null ? null : manifest.trim();
}
public String getResponsecode() {
return responsecode;
}
public void setResponsecode(String responsecode) {
this.responsecode = responsecode == null ? null : responsecode.trim();
}
public String getResponsetext() {
return responsetext;
}
public void setResponsetext(String responsetext) {
this.responsetext = responsetext == null ? null : responsetext.trim();
}
@Override
public String toString() {
return "RESMESSAGE{" +
"id='" + id + '\'' +
", journeyid='" + journeyid + '\'' +
", manifest='" + manifest + '\'' +
", responsecode='" + responsecode + '\'' +
", responsetext='" + responsetext + '\'' +
'}';
}
}
\ No newline at end of file
... ...
... ... @@ -18,4 +18,6 @@ public interface LandBusListService {
List<LandBusinessTypeList> selectByBarcode(String barcode);
int updateByBarcode(String barcode);
List<LandBusinessTypeList> selectMessageId(String messageId);
}
... ...
package com.sy.service;
import com.sy.model.RESMESSAGE;
/**
* @author
* @time 2019-${MOUTH}-22 21:31
*/
public interface ResMessageService {
int saveEnter(RESMESSAGE resmessage);
RESMESSAGE selectByManifest(String manifest);
}
... ...
... ... @@ -69,4 +69,9 @@ public class LandBusListServiceImpl implements LandBusListService {
public int updateByBarcode(String barcode) {
return listMapper.updateByBarCode(barcode);
}
public List<LandBusinessTypeList> selectMessageId(String messageiD){
return listMapper.selectMessageId(messageiD);
}
}
... ...
package com.sy.service.impl;
import com.sy.mapper.RESMESSAGEMapper;
import com.sy.model.RESMESSAGE;
import com.sy.service.ResMessageService;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Service;
/**
* @author
* @time 2019-${MOUTH}-22 21:32
*/
@Service
public class ResMessageServiceImpl implements ResMessageService {
@Autowired
private RESMESSAGEMapper mapper;
public int saveEnter(RESMESSAGE resmessage){
return mapper.insertSelective(resmessage);
}
public RESMESSAGE selectByManifest(String manifest){
return mapper.selectByManifest(manifest);
}
}
... ...
... ... @@ -91,10 +91,21 @@ public class CommandClient {
StringBuffer buffer = new StringBuffer();
buffer.append("<COMMAND_INFO AREA_ID=\""+info.getAreaid()+"\" CHNL_NO=\""+info.getChnlno()+"\" I_E_TYPE=\""+info
.getIetype()+"\" SEQ_NO=\""+info.getSeqno()+"\">");
buffer.append("<CHECK_RESULT>"+flag+"000000000000000000</CHECK_RESULT><OP_HINT>"+message+"</OP_HINT>");
String type = null;
if("I".equals(info.getIetype())){
type="000000200000000000";
}else{
type="000000100000000000";
}
buffer.append("<CHECK_RESULT>"+flag+type+"</CHECK_RESULT><OP_HINT>"+message+"</OP_HINT>");
buffer.append("<SEAL>");
buffer.append("<ESEAL_ID>"+info.getEsealid()+"</ESEAL_ID>");
buffer.append("<SEAL_KEY>"+info.getSealkey()+"</SEAL_KEY>");
if(flag == "00"){
buffer.append("<SEAL_KEY>1234567890</SEAL_KEY>");
}else{
buffer.append("<SEAL_KEY>"+info.getSealkey()+"</SEAL_KEY>");
}
buffer.append("<OPEN_TIMES></OPEN_TIMES>");
buffer.append("<ESEAL_IC_NO></ESEAL_IC_NO>");
buffer.append("</SEAL>");
... ...
... ... @@ -14,8 +14,8 @@ public class DateTimeConverter extends AbstractSingleValueConverter {
private static final DateFormat DATETIME = new SimpleDateFormat("yyyyMMddHHmmss");
private static final DateFormat DATETIME_FORMAT = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss");
private static final DateFormat DEFAULT_DATEFORMAT = new SimpleDateFormat("yyyy-MM-dd'T'HH:mm:ss");
private static SimpleDateFormat dateFormat = new SimpleDateFormat("yyyyMMddHHmmss");
private static SimpleDateFormat date = new SimpleDateFormat("yyyyy-MM-dd");
private static final SimpleDateFormat dateFormat = new SimpleDateFormat("yyyyMMddHHmmss");
private static final SimpleDateFormat date = new SimpleDateFormat("yyyyy-MM-dd");
public boolean canConvert(Class type) {
return type.equals(Date.class);
... ... @@ -36,6 +36,10 @@ public class DateTimeConverter extends AbstractSingleValueConverter {
if(str.length()==10) {
return DATE.parseObject(str);
}
if(str.length()>14){
str= str.substring(0,15);
return DATETIME.parseObject(str);
}
}else {
return null;
}
... ... @@ -48,6 +52,15 @@ public class DateTimeConverter extends AbstractSingleValueConverter {
public static String getFormat() {
return dateFormat.format(new Date());
}
public static String dateFormat() {
SimpleDateFormat simpleDateFormat = new SimpleDateFormat("yyyyMMddHHmmss");
return simpleDateFormat.format(new Date());
}
public static String dateTimeFormat() {
SimpleDateFormat simpleDateFormat = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss");
return simpleDateFormat.format(new Date());
}
public static String getDay() {
return date.format(new Date());
}
... ...
Manifest-Version: 1.0
Class-Path: pagehelper-5.1.2.jar logback-classic-1.2.3.jar xstream-1.4
.10.jar jsqlparser-1.0.jar axiom-impl-1.2.7.jar geronimo-javamail_1.4
_spec-1.2.jar cxf-xjc-boolean-3.2.3.jar mybatis-spring-boot-autoconfi
gure-1.3.2.jar xmlpull-1.1.3.1.jar com.ibm.mq.pcf.jar com.ibm.mq.soap
.jar wstx-asl-3.2.4.jar com.ibm.mqjms.jar hibernate-validator-6.0.13.
Final.jar spring-tx-5.1.2.RELEASE.jar xpp3_min-1.1.4c.jar neethi-2.0.
4.jar commons-io-2.5.jar jackson-databind-2.9.7.jar spring-core-5.1.2
.RELEASE.jar core-3.3.0.jar slf4j-api-1.7.25.jar jul-to-slf4j-1.7.25.
jar spring-boot-starter-logging-2.1.0.RELEASE.jar jackson-module-para
meter-names-2.9.7.jar validation-api-2.0.1.Final.jar spring-boot-star
ter-json-2.1.0.RELEASE.jar HeartbeatService.jar jboss-logging-3.3.2.F
inal.jar commons-lang-2.4.jar com.ibm.mq.fta.jar classmate-1.4.0.jar
spring-boot-starter-2.1.0.RELEASE.jar ProcessService.jar mysql-connec
tor-java-8.0.13.jar mybatis-3.4.6.jar geronimo-stax-api_1.0_spec-1.0.
1.jar spring-beans-5.1.2.RELEASE.jar mybatis-spring-boot-starter-1.3.
2.jar com.ibm.mq.axis2.jar jackson-datatype-jdk8-2.9.7.jar cxf-xjc-bu
g671-2.3.2.jar spring-web-5.1.2.RELEASE.jar com.ibm.mq.headers.jar co
m.ibm.mq.postcard.jar spring-aop-5.1.2.RELEASE.jar snakeyaml-1.23.jar
CL3Nonexport.jar druid-spring-boot-starter-1.1.9.jar com.ibm.mqetcli
ent.jar com.ibm.mq.tools.ras.jar spring-context-5.1.2.RELEASE.jar com
.ibm.mq.defaultconfig.jar xml-apis-1.4.01.jar mybatis-spring-1.3.2.ja
r connector.jar mybatis-generator-core-1.3.6.jar geronimo-activation_
1.1_spec-1.0.1.jar com.ibm.mq.jmqi.jar javax.annotation-api-1.3.2.jar
wsdl4j-1.6.2.jar imfmsg.jar CL3Export.jar axiom-api-1.2.7.jar druid-
1.1.9.jar cxf-xjc-dv-2.3.2.jar IMFClient.1.0.0.jar spring-boot-autoco
nfigure-2.1.0.RELEASE.jar spring-webmvc-5.1.2.RELEASE.jar pagehelper-
spring-boot-starter-1.2.3.jar xmlbeans-2.4.0.jar jackson-datatype-jsr
310-2.9.7.jar UploadService.jar jackson-core-2.9.7.jar logback-core-1
.2.3.jar jaxen-1.1.6.jar stax-api-1.0.1.jar dom4j-2.1.0.jar xmlsec-1.
4.4.jar spring-expression-5.1.2.RELEASE.jar fastjson-1.2.47.jar cxf-m
anifest.jar sigar.jar spring-boot-2.1.0.RELEASE.jar log4j-api-2.11.1.
jar com.ibm.mq.jar pagehelper-spring-boot-autoconfigure-1.2.3.jar Hik
ariCP-3.2.0.jar com.ibm.mq.commonservices.jar apiConfig.jar cxf-xjc-t
s-2.3.2.jar log4j-to-slf4j-2.11.1.jar cxf-2.3.2.jar XmlSchema-1.4.7.j
ar spring-jdbc-5.1.2.RELEASE.jar returnXml.jar commons-logging-1.1.1.
jar spring-boot-starter-web-2.1.0.RELEASE.jar spring-boot-starter-jdb
c-2.1.0.RELEASE.jar jackson-annotations-2.9.0.jar spring-jcl-5.1.2.RE
LEASE.jar log4j-1.2.17.jar com.ibm.mq.jms.Nojndi.jar httpclient-4.5.5
.jar httpcore-4.4.10.jar commnons-codec-1.11.jar
Main-Class: com.sy.AnalysisImfApplication
... ...
#设置访问端口
#\u8BBE\u7F6E\u8BBF\u95EE\u7AEF\u53E3
server.port=8848
#eureka注册中心服务器地址
#eureka\u6CE8\u518C\u4E2D\u5FC3\u670D\u52A1\u5668\u5730\u5740
#eureka.client.service-url.defaultZone=http://10.50.3.82:19527/eureka/
#服务名
#\u670D\u52A1\u540D
#spring.application.name=AnalysisForStation
#设置热部署
#开启热部署
#\u8BBE\u7F6E\u70ED\u90E8\u7F72
#\u5F00\u542F\u70ED\u90E8\u7F72
spring.devtools.restart.enabled=true
#重启范围
#\u91CD\u542F\u8303\u56F4
spring.devtools.restart.additional-paths=src/main/java
#映射前缀
#\u6620\u5C04\u524D\u7F00
spring.mvc.view.suffix=/WEB-INF/jsp/
#映射后缀
#\u6620\u5C04\u540E\u7F00
spring.mvc.view.prefix=.jsp
#设置本地数据源
#\u8BBE\u7F6E\u672C\u5730\u6570\u636E\u6E90
#spring.datasource.username=root
#spring.datasource.password=root
#spring.datasource.driver-class-name=com.mysql.cj.jdbc.Driver
#spring.datasource.url=jdbc:mysql://localhost:3306/bysj?useUnicode=true&characterEncoding=utf8&autoReconnect=true&failOverReadOnly=false&allowMultiQueries=true&useSSL=true&serverTimezone=Asia/Shanghai
#设置线上数据源
#spring.datasource.url=jdbc:mysql://localhost:3306/station?useUnicode=true&characterEncoding=utf8&autoReconnect=true&failOverReadOnly=false&allowMultiQueries=true&useSSL=true&serverTimezone=Asia/Shanghai
#\u8BBE\u7F6E\u7EBF\u4E0A\u6570\u636E\u6E90
spring.datasource.driver-class-name=com.mysql.cj.jdbc.Driver
spring.datasource.url=jdbc:mysql://10.50.7.10:3306/station?characterEncoding=utf8&useSSL=false&serverTimezone=UTC&rewriteBatchedStatements=true
spring.datasource.username=kako
spring.datasource.password=mysql10.50.7.10
#连接池类
spring.datasource.url=jdbc:mysql://10.50.7.70:3306/station?useUnicode=true&characterEncoding=utf8&autoReconnect=true&failOverReadOnly=false&allowMultiQueries=true&useSSL=true&serverTimezone=Asia/Shanghai
spring.datasource.username=station
spring.datasource.password=station@10.50.7.70
#\u8FDE\u63A5\u6C60\u7C7B
spring.datasource.type=com.alibaba.druid.pool.DruidDataSource
#连接池配置,因为springboot默认是开启了连接池的,它有默认配置,这一段可以忽略
# 初始化大小,最小,最大
#\u8FDE\u63A5\u6C60\u914D\u7F6E\uFF0C\u56E0\u4E3Aspringboot\u9ED8\u8BA4\u662F\u5F00\u542F\u4E86\u8FDE\u63A5\u6C60\u7684\uFF0C\u5B83\u6709\u9ED8\u8BA4\u914D\u7F6E\uFF0C\u8FD9\u4E00\u6BB5\u53EF\u4EE5\u5FFD\u7565
# \u521D\u59CB\u5316\u5927\u5C0F\uFF0C\u6700\u5C0F\uFF0C\u6700\u5927
spring.datasource.druid.initial-size=5
spring.datasource.druid.min-idle=5
spring.datasource.druid.max-active=20
# 配置获取连接等待超时的时间
# \u914D\u7F6E\u83B7\u53D6\u8FDE\u63A5\u7B49\u5F85\u8D85\u65F6\u7684\u65F6\u95F4
spring.datasource.druid.max-wait=60000
# 配置间隔多久才进行一次检测,检测需要关闭的空闲连接,单位是毫秒
# \u914D\u7F6E\u95F4\u9694\u591A\u4E45\u624D\u8FDB\u884C\u4E00\u6B21\u68C0\u6D4B\uFF0C\u68C0\u6D4B\u9700\u8981\u5173\u95ED\u7684\u7A7A\u95F2\u8FDE\u63A5\uFF0C\u5355\u4F4D\u662F\u6BEB\u79D2
spring.datasource.druid.time-between-eviction-runs-millis=60000
# 配置一个连接在池中最小生存的时间,单位是毫秒
# \u914D\u7F6E\u4E00\u4E2A\u8FDE\u63A5\u5728\u6C60\u4E2D\u6700\u5C0F\u751F\u5B58\u7684\u65F6\u95F4\uFF0C\u5355\u4F4D\u662F\u6BEB\u79D2
spring.datasource.druid.min-evictable-idle-time-millis=300000
spring.datasource.druid.validation-query=SELECT 1 FROM DUAL
spring.datasource.druid.test-while-idle=true
spring.datasource.druid.test-on-borrow=false
spring.datasource.druid.test-on-return=false
# 打开PSCache,并且指定每个连接上PSCache的大小
# \u6253\u5F00PSCache\uFF0C\u5E76\u4E14\u6307\u5B9A\u6BCF\u4E2A\u8FDE\u63A5\u4E0APSCache\u7684\u5927\u5C0F
spring.datasource.druid.pool-prepared-statements=true
spring.datasource.druid.max-pool-prepared-statement-per-connection-size=20
# 配置监控统计拦截的filters,去掉后监控界面sql无法统计,'wall'用于防火墙
# \u914D\u7F6E\u76D1\u63A7\u7EDF\u8BA1\u62E6\u622A\u7684filters\uFF0C\u53BB\u6389\u540E\u76D1\u63A7\u754C\u9762sql\u65E0\u6CD5\u7EDF\u8BA1\uFF0C'wall'\u7528\u4E8E\u9632\u706B\u5899
spring.datasource.druid.filters=stat,wall,log4j
# 通过connectProperties属性来打开mergeSql功能;慢SQL记录
# \u901A\u8FC7connectProperties\u5C5E\u6027\u6765\u6253\u5F00mergeSql\u529F\u80FD\uFF1B\u6162SQL\u8BB0\u5F55
spring.datasource.druid.connection-properties=druid.stat.mergeSql=true;druid.stat.slowSqlMillis=500
#配置mybatis
#\u914D\u7F6Emybatis
mybatis.mapper-locations=classpath:mapping/*.xml
#全局的映射,不用在xml文件写实体类的全路径
#\u5168\u5C40\u7684\u6620\u5C04\uFF0C\u4E0D\u7528\u5728xml\u6587\u4EF6\u5199\u5B9E\u4F53\u7C7B\u7684\u5168\u8DEF\u5F84
mybatis.type-aliases-package=com.sy.model
#开启驼峰映射
#\u5F00\u542F\u9A7C\u5CF0\u6620\u5C04
mybatis.configuration.map-underscore-to-camel-case=true
#配置分页插件
#pagehelper分页插件
#\u914D\u7F6E\u5206\u9875\u63D2\u4EF6
#pagehelper\u5206\u9875\u63D2\u4EF6
pagehelper.helper-dialect=mysql
pagehelper.reasonable=true
pagehelper.support-methods-arguments=true
... ...
... ... @@ -13,7 +13,7 @@
</commentGenerator>
<!--数据库链接URL,用户名、密码 -->
<jdbcConnection driverClass="com.mysql.jdbc.Driver"
connectionURL="jdbc:mysql://localhost:3306/bysj"
connectionURL="jdbc:mysql://localhost:3306/station"
userId="root" password="root">
</jdbcConnection>
<javaTypeResolver>
... ... @@ -68,7 +68,13 @@
<!-- <table tableName="land_businesstype_list" domainObjectName="LandBusinessTypeList" enableCountByExample="false"
enableUpdateByExample="false"
enableDeleteByExample="false" enableSelectByExample="false" selectByExampleQueryId="false"></table>-->
<table tableName="land_road_ve_record" domainObjectName="LandRoadVe" enableCountByExample="false"
<!-- <table tableName="land_businesstype_list" domainObjectName="LandBusinessTypeList" enableCountByExample="false"
enableUpdateByExample="false"
enableDeleteByExample="false" enableSelectByExample="false" selectByExampleQueryId="false"></table>-->
<!-- <table tableName="ResMessage" domainObjectName="RESMESSAGE" enableCountByExample="false"
enableUpdateByExample="false"
enableDeleteByExample="false" enableSelectByExample="false" selectByExampleQueryId="false"></table>-->
<table tableName="land_businesstype_list" domainObjectName="LandBusinessTypeList" enableCountByExample="false"
enableUpdateByExample="false"
enableDeleteByExample="false" enableSelectByExample="false" selectByExampleQueryId="false"></table>
</context>
... ...
... ... @@ -28,12 +28,18 @@
<result column="UPDATE_BY" jdbcType="VARCHAR" property="updateBy" />
<result column="UPDATE_DATE" jdbcType="TIMESTAMP" property="updateDate" />
<result column="ISVALID" jdbcType="VARCHAR" property="isvalid" />
<result column="AISLEWT" jdbcType="DOUBLE" property="aislewt" />
<result column="ISFULL" jdbcType="VARCHAR" property="isfull" />
<result column="REMARK" jdbcType="VARCHAR" property="remark" />
<result column="REMARK1" jdbcType="VARCHAR" property="remark1" />
<result column="REMARK2" jdbcType="VARCHAR" property="remark2" />
</resultMap>
<sql id="Base_Column_List">
id, MASSAGE_ID, TRAILER_FRAME_NO, TRAILER_LICENSE_NO, MASTER_LIST, PRODECT_TIME,
IS_DELETE, AGENTNO, AGENTNAME, COCODE, DRIVERNAME, DRIVERID, STARTPORT, ENDPORT,
STARTSATATION, ENDSTATION, AISLE, BUSINESSTYPE, TURNOVERFLAG, BARCODE, CONTRASTFLAG,
CREATE_BY, CREATE_DATE, UPDATE_BY, UPDATE_DATE, ISVALID
CREATE_BY, CREATE_DATE, UPDATE_BY, UPDATE_DATE, ISVALID, AISLEWT, ISFULL, REMARK,
REMARK1, REMARK2
</sql>
<select id="selectByPrimaryKey" parameterType="java.lang.String" resultMap="BaseResultMap">
select
... ... @@ -66,14 +72,21 @@
from land_businesstype_list
where BARCODE = #{barcode,jdbcType=VARCHAR}
</select>
<delete id="deleteByPrimaryKey" parameterType="java.lang.String">
delete from land_businesstype_list
where id = #{id,jdbcType=VARCHAR}
</delete>
<select id="selectMessageId" parameterType="java.lang.String" resultMap="BaseResultMap">
select
<include refid="Base_Column_List" />
from land_businesstype_list
where MASSAGE_ID = #{massageId,jdbcType=VARCHAR}
</select>
<update id="updateByBarCode" parameterType="java.lang.String">
update land_businesstype_list set ISVALID = "1" where BARCODE=#{barcode,jdbcType=VARCHAR};
</update>
<delete id="deleteByPrimaryKey" parameterType="java.lang.String">
delete from land_businesstype_list
where id = #{id,jdbcType=VARCHAR}
</delete>
<insert id="insert" parameterType="com.sy.model.LandBusinessTypeList">
insert into land_businesstype_list (id, MASSAGE_ID, TRAILER_FRAME_NO,
TRAILER_LICENSE_NO, MASTER_LIST, PRODECT_TIME,
... ... @@ -83,7 +96,9 @@
ENDSTATION, AISLE, BUSINESSTYPE,
TURNOVERFLAG, BARCODE, CONTRASTFLAG,
CREATE_BY, CREATE_DATE, UPDATE_BY,
UPDATE_DATE, ISVALID)
UPDATE_DATE, ISVALID, AISLEWT,
ISFULL, REMARK, REMARK1,
REMARK2)
values (#{id,jdbcType=VARCHAR}, #{massageId,jdbcType=VARCHAR}, #{trailerFrameNo,jdbcType=VARCHAR},
#{trailerLicenseNo,jdbcType=VARCHAR}, #{masterList,jdbcType=VARCHAR}, #{prodectTime,jdbcType=TIMESTAMP},
#{isDelete,jdbcType=VARCHAR}, #{agentno,jdbcType=VARCHAR}, #{agentname,jdbcType=VARCHAR},
... ... @@ -92,7 +107,9 @@
#{endstation,jdbcType=VARCHAR}, #{aisle,jdbcType=VARCHAR}, #{businesstype,jdbcType=VARCHAR},
#{turnoverflag,jdbcType=VARCHAR}, #{barcode,jdbcType=VARCHAR}, #{contrastflag,jdbcType=VARCHAR},
#{createBy,jdbcType=VARCHAR}, #{createDate,jdbcType=TIMESTAMP}, #{updateBy,jdbcType=VARCHAR},
#{updateDate,jdbcType=TIMESTAMP}, #{isvalid,jdbcType=VARCHAR})
#{updateDate,jdbcType=TIMESTAMP}, #{isvalid,jdbcType=VARCHAR}, #{aislewt,jdbcType=DOUBLE},
#{isfull,jdbcType=VARCHAR}, #{remark,jdbcType=VARCHAR}, #{remark1,jdbcType=VARCHAR},
#{remark2,jdbcType=VARCHAR})
</insert>
<insert id="insertSelective" parameterType="com.sy.model.LandBusinessTypeList">
insert into land_businesstype_list
... ... @@ -175,6 +192,21 @@
<if test="isvalid != null">
ISVALID,
</if>
<if test="aislewt != null">
AISLEWT,
</if>
<if test="isfull != null">
ISFULL,
</if>
<if test="remark != null">
REMARK,
</if>
<if test="remark1 != null">
REMARK1,
</if>
<if test="remark2 != null">
REMARK2,
</if>
</trim>
<trim prefix="values (" suffix=")" suffixOverrides=",">
<if test="id != null">
... ... @@ -255,6 +287,21 @@
<if test="isvalid != null">
#{isvalid,jdbcType=VARCHAR},
</if>
<if test="aislewt != null">
#{aislewt,jdbcType=DOUBLE},
</if>
<if test="isfull != null">
#{isfull,jdbcType=VARCHAR},
</if>
<if test="remark != null">
#{remark,jdbcType=VARCHAR},
</if>
<if test="remark1 != null">
#{remark1,jdbcType=VARCHAR},
</if>
<if test="remark2 != null">
#{remark2,jdbcType=VARCHAR},
</if>
</trim>
</insert>
<update id="updateByPrimaryKeySelective" parameterType="com.sy.model.LandBusinessTypeList">
... ... @@ -335,6 +382,21 @@
<if test="isvalid != null">
ISVALID = #{isvalid,jdbcType=VARCHAR},
</if>
<if test="aislewt != null">
AISLEWT = #{aislewt,jdbcType=DOUBLE},
</if>
<if test="isfull != null">
ISFULL = #{isfull,jdbcType=VARCHAR},
</if>
<if test="remark != null">
REMARK = #{remark,jdbcType=VARCHAR},
</if>
<if test="remark1 != null">
REMARK1 = #{remark1,jdbcType=VARCHAR},
</if>
<if test="remark2 != null">
REMARK2 = #{remark2,jdbcType=VARCHAR},
</if>
</set>
where id = #{id,jdbcType=VARCHAR}
</update>
... ... @@ -364,7 +426,12 @@
CREATE_DATE = #{createDate,jdbcType=TIMESTAMP},
UPDATE_BY = #{updateBy,jdbcType=VARCHAR},
UPDATE_DATE = #{updateDate,jdbcType=TIMESTAMP},
ISVALID = #{isvalid,jdbcType=VARCHAR}
ISVALID = #{isvalid,jdbcType=VARCHAR},
AISLEWT = #{aislewt,jdbcType=DOUBLE},
ISFULL = #{isfull,jdbcType=VARCHAR},
REMARK = #{remark,jdbcType=VARCHAR},
REMARK1 = #{remark1,jdbcType=VARCHAR},
REMARK2 = #{remark2,jdbcType=VARCHAR}
where id = #{id,jdbcType=VARCHAR}
</update>
</mapper>
\ No newline at end of file
... ...
<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE mapper PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN" "http://mybatis.org/dtd/mybatis-3-mapper.dtd">
<mapper namespace="com.sy.mapper.RESMESSAGEMapper">
<resultMap id="BaseResultMap" type="com.sy.model.RESMESSAGE">
<id column="id" jdbcType="VARCHAR" property="id" />
<result column="JourneyID" jdbcType="VARCHAR" property="journeyid" />
<result column="Manifest" jdbcType="VARCHAR" property="manifest" />
<result column="ResponseCode" jdbcType="VARCHAR" property="responsecode" />
<result column="ResponseText" jdbcType="VARCHAR" property="responsetext" />
</resultMap>
<sql id="Base_Column_List">
id, JourneyID, Manifest, ResponseCode, ResponseText
</sql>
<select id="selectByPrimaryKey" parameterType="java.lang.String" resultMap="BaseResultMap">
select
<include refid="Base_Column_List" />
from resmessage
where id = #{id,jdbcType=VARCHAR}
</select>
<select id="selectByManifest" parameterType="java.lang.String" resultMap="BaseResultMap">
select
<include refid="Base_Column_List" />
from resmessage
where Manifest = #{manifest,jdbcType=VARCHAR}
</select>
<delete id="deleteByPrimaryKey" parameterType="java.lang.String">
delete from resmessage
where id = #{id,jdbcType=VARCHAR}
</delete>
<insert id="insert" parameterType="com.sy.model.RESMESSAGE">
insert into resmessage (id, JourneyID, Manifest,
ResponseCode, ResponseText)
values (#{id,jdbcType=VARCHAR}, #{journeyid,jdbcType=VARCHAR}, #{manifest,jdbcType=VARCHAR},
#{responsecode,jdbcType=VARCHAR}, #{responsetext,jdbcType=VARCHAR})
</insert>
<insert id="insertSelective" parameterType="com.sy.model.RESMESSAGE">
insert into resmessage
<trim prefix="(" suffix=")" suffixOverrides=",">
<if test="id != null">
id,
</if>
<if test="journeyid != null">
JourneyID,
</if>
<if test="manifest != null">
Manifest,
</if>
<if test="responsecode != null">
ResponseCode,
</if>
<if test="responsetext != null">
ResponseText,
</if>
</trim>
<trim prefix="values (" suffix=")" suffixOverrides=",">
<if test="id != null">
#{id,jdbcType=VARCHAR},
</if>
<if test="journeyid != null">
#{journeyid,jdbcType=VARCHAR},
</if>
<if test="manifest != null">
#{manifest,jdbcType=VARCHAR},
</if>
<if test="responsecode != null">
#{responsecode,jdbcType=VARCHAR},
</if>
<if test="responsetext != null">
#{responsetext,jdbcType=VARCHAR},
</if>
</trim>
</insert>
<update id="updateByPrimaryKeySelective" parameterType="com.sy.model.RESMESSAGE">
update resmessage
<set>
<if test="journeyid != null">
JourneyID = #{journeyid,jdbcType=VARCHAR},
</if>
<if test="manifest != null">
Manifest = #{manifest,jdbcType=VARCHAR},
</if>
<if test="responsecode != null">
ResponseCode = #{responsecode,jdbcType=VARCHAR},
</if>
<if test="responsetext != null">
ResponseText = #{responsetext,jdbcType=VARCHAR},
</if>
</set>
where id = #{id,jdbcType=VARCHAR}
</update>
<update id="updateByPrimaryKey" parameterType="com.sy.model.RESMESSAGE">
update resmessage
set JourneyID = #{journeyid,jdbcType=VARCHAR},
Manifest = #{manifest,jdbcType=VARCHAR},
ResponseCode = #{responsecode,jdbcType=VARCHAR},
ResponseText = #{responsetext,jdbcType=VARCHAR}
where id = #{id,jdbcType=VARCHAR}
</update>
</mapper>
\ No newline at end of file
... ...