|
@@ -96,326 +96,256 @@ public class DataFormat {
|
|
|
return tempIndex == str.length() ? str : str.substring(0, tempIndex);
|
|
|
}
|
|
|
|
|
|
- public static void main(String[] args) {
|
|
|
-// String xx = "{BSM0G\\r\\n.R/+ACT/LD/B/S/1\\r\\nENDBPM\\r\\n\",\"dataObjectId\":\"167894111307300001000100\"}{\"dataContent\":\"QP CABDPCA\\r\\n.HKGBMCA 161231\\r\\nBPM\\r\\n.V/1LHKG\\r\\n.J/R/JAT/H92165/16MAR/123150L\\r\\n.F/CA0112/16MAR/PEK/Y\\r\\n.U/AKE29241CA//M/Y/PEK\\r\\n.N/3999456596001\\r\\n.Q/019\\r\\n.S/Y/55C/C/118//Y\\r\\n.P/1ZHONG/WEIGIANG\\r\\n.L/NBE0JY\\r\\nENDBPM\\r\\n\",\"dataObjectId\":\"167894111357600001000100\"}{\"dataContent\":\"CABDPCA\\r\\n.FRAHQ0A 160431\\r\\nBPM\\r\\n.V/1LPEK\\r\\n.J/R/13301/4693/16MAR/1231L/T2FJP43\\r\\n.F/CA1257/16MAR/KRL/Y\\r\\n.U/DOU41257CA//X/Y/KRL\\r\\n.N/3999431112001\\r\\n.Q/040\\r\\n.S/Y/12C/C/117//Y\\r\\n.P/RONGHONGQING\\r\\n.Y/CA006362841835\\r\\n.L/PFRGZG\\r\\n.R/+ACT/LD/B/S/1\\r\\nENDBPM\\r\\n\",\"dataObjectId\":\"167894111399100001000100\"}{\"dataContent\":\"QD CABDPCA\\r\\n.PEKBS1E 161231\\r\\nBSM\\r\\nCHG\\r\\n.V/1LPEK\\r\\n.F/CA1541/16MAR/NGB/Y\\r\\n.N/3999362826001\\r\\n.D/SELF//16MAR/1231L//BJS159627\\r\\n.S/Y/18L/C/046//Y//A\\r\\n.W/K/1/9\\r\\n.P/1ZHANGHONGHAI\\r\\n.Y/CA005317156803\\r\\n.L/PX201T\\r\\n.T/159627\\r\\nENDBSM}";
|
|
|
-
|
|
|
-// HashMap<String, String> objectObjectHashMap = new HashMap<>();
|
|
|
-// objectObjectHashMap.put("dataType", "dataType");
|
|
|
-// objectObjectHashMap.put("dataState", "dataState");
|
|
|
-// objectObjectHashMap.put(".B1", "abnormalState");
|
|
|
-// objectObjectHashMap.put(".B2", "luggageNum");
|
|
|
-// objectObjectHashMap.put(".N/1", "luggageNum");
|
|
|
-// objectObjectHashMap.put(".C/", "groupName");
|
|
|
-// objectObjectHashMap.put(".D/1", "checkInLocation");
|
|
|
-// objectObjectHashMap.put(".D/2", "checkInLocationDescription");
|
|
|
-// objectObjectHashMap.put(".D/3.D/4", "checkInDate");
|
|
|
-// objectObjectHashMap.put(".D/5", "transportMedium");
|
|
|
-// objectObjectHashMap.put(".D/6", "transportID");
|
|
|
-// objectObjectHashMap.put(".E/", "specialType");
|
|
|
-// objectObjectHashMap.put(".F/1", "flightNo");
|
|
|
-// objectObjectHashMap.put(".F/2", "flightDate");
|
|
|
-// objectObjectHashMap.put(".F/3", "target_airport");
|
|
|
-// objectObjectHashMap.put(".F/4", "passenger_cabin");
|
|
|
-// objectObjectHashMap.put(".G/1", "groundtransportationDateStar");
|
|
|
-// objectObjectHashMap.put(".G/2", "groundtransportationDateEnd");
|
|
|
-// objectObjectHashMap.put(".G/3", "groundtransportationAddress");
|
|
|
-// objectObjectHashMap.put(".H/1", "doTerminal");
|
|
|
-// objectObjectHashMap.put(".H/2", "operationArea");
|
|
|
-// objectObjectHashMap.put(".H/3", "operatingPosition");
|
|
|
-// objectObjectHashMap.put(".I/1", "inflightNo");
|
|
|
-// objectObjectHashMap.put(".I/2", "inflightDate");
|
|
|
-// objectObjectHashMap.put(".I/3", "inairport");
|
|
|
-// objectObjectHashMap.put(".I/4", "inpassenger_cabin");
|
|
|
-// objectObjectHashMap.put(".J/1", "secondary_code");
|
|
|
-// objectObjectHashMap.put(".J/2", "agentNumber");
|
|
|
-// objectObjectHashMap.put(".J/3", "device_ID");
|
|
|
-// objectObjectHashMap.put(".J/4.J/5", "processing_time");
|
|
|
-// objectObjectHashMap.put(".J/6", "location_code");
|
|
|
-// objectObjectHashMap.put(".J/7", "to_location_code");
|
|
|
-// objectObjectHashMap.put(".J/8", "location_describe");
|
|
|
-// objectObjectHashMap.put(".J/9", "to_location_describe");
|
|
|
-// objectObjectHashMap.put(".L/", "PNRNO");
|
|
|
-// objectObjectHashMap.put(".O/1", "transferFlightNO");
|
|
|
-// objectObjectHashMap.put(".O/2", "transferFlightDate");
|
|
|
-// objectObjectHashMap.put(".O/3", "transferAirport");
|
|
|
-// objectObjectHashMap.put(".P/", "passengerName");
|
|
|
-// objectObjectHashMap.put(".Q/", "loadNumber");
|
|
|
-// objectObjectHashMap.put(".R/", "luggage_describe");
|
|
|
-// objectObjectHashMap.put(".S/4", "checkin_number");
|
|
|
-// objectObjectHashMap.put(".S/5", "security_number");
|
|
|
-// objectObjectHashMap.put(".S/6", "passengerinfoState");
|
|
|
-// objectObjectHashMap.put(".S/7", "cantransportation");
|
|
|
-// objectObjectHashMap.put(".S/8", "activeState");
|
|
|
-// objectObjectHashMap.put(".S/1", "canLoad");
|
|
|
-// objectObjectHashMap.put(".S/2", "seatNum");
|
|
|
-// objectObjectHashMap.put(".S/3", "passengerState");
|
|
|
-// objectObjectHashMap.put(".T/", "printerID");
|
|
|
-// objectObjectHashMap.put(".U/1", "container_ID");
|
|
|
-// objectObjectHashMap.put(".U/2", "loadAddress");
|
|
|
-// objectObjectHashMap.put(".U/3", "luggageType");
|
|
|
-// objectObjectHashMap.put(".V/2", "sourceAirport");
|
|
|
-// objectObjectHashMap.put(".V/1", "sourceSign");
|
|
|
-// objectObjectHashMap.put(".V/3", "sourceOther");
|
|
|
-// objectObjectHashMap.put("creation_time", "creation_time");
|
|
|
-// objectObjectHashMap.put("dataObjectId", "dataObjectId");
|
|
|
-// objectObjectHashMap.put("sourceData", "sourceData");
|
|
|
-// objectObjectHashMap.put(".W/2", "luggageCount");
|
|
|
-// objectObjectHashMap.put(".W/3", "luggageWeight");
|
|
|
-// objectObjectHashMap.put(".W/1", "weightUnit");
|
|
|
-// objectObjectHashMap.put(".W/5", "luggageSize");
|
|
|
-// objectObjectHashMap.put(".W/9", "externalFeatures");
|
|
|
-// objectObjectHashMap.put(".X/1", "securityInspectionDescription");
|
|
|
-// objectObjectHashMap.put(".X/2", "securityInspectionResults");
|
|
|
-// objectObjectHashMap.put(".X/3", "reasonsForSecurity");
|
|
|
-// objectObjectHashMap.put(".X/4", "securityInspectionMethod");
|
|
|
-// objectObjectHashMap.put(".Y/1", "frequentflyerNO");
|
|
|
-// objectObjectHashMap.put(".Y/2", "frequentflyerGrade");
|
|
|
-// System.out.println(typeBToMap(xx,"11111111111111",objectObjectHashMap));
|
|
|
-//
|
|
|
-// String typeStr = "{1}{2}";
|
|
|
-//
|
|
|
-// System.out.println(typeStrList);
|
|
|
- }
|
|
|
-
|
|
|
-
|
|
|
- public static Map<String, Object> typeBToMap(String typeStr, String dataObjectId, Map<String, String> transMaps) {
|
|
|
+ public static Map<String, Object> typeBToMap(Object typeStr, String dataObjectId, Map<String, String> transMaps) {
|
|
|
try {
|
|
|
- if (MapTools.isBlank(typeStr)) {
|
|
|
- return MapTools.processSuccess(null);
|
|
|
+ if (Objects.isNull(typeStr)) return MapTools.processSuccess(null);
|
|
|
+ if (Objects.isNull(transMaps)) transMaps = new HashMap<>();
|
|
|
+ List<Object> tempList = new ArrayList<>();
|
|
|
+ if (typeStr instanceof List<?> tempInList) {
|
|
|
+ tempList.addAll(tempInList);
|
|
|
+ } else {
|
|
|
+ tempList.add(typeStr);
|
|
|
}
|
|
|
- if (Objects.isNull(transMaps)) {
|
|
|
- transMaps = new HashMap<>();
|
|
|
+ List<Map<String, Object>> rsList = new ArrayList<>();
|
|
|
+ for (Object o : tempList) {
|
|
|
+ String inData = Objects.toString(o);
|
|
|
+ if (MapTools.isBlank(inData)) continue;
|
|
|
+ int dataObjectIdIndex = inData.indexOf("dataObjectId");
|
|
|
+ String tpDataObjectId = inData.length() > 39 ? inData.substring(dataObjectIdIndex + 15, dataObjectIdIndex + 39) : null;
|
|
|
+ rsList.addAll(typebHandler(inData, transMaps, MapTools.isBlank(tpDataObjectId) ? dataObjectId : tpDataObjectId));
|
|
|
}
|
|
|
- List<String> typeStrList = MapTools.patternContent(typeStr, "\\{(.+?)\\}");
|
|
|
- //设定报文提取规则MAP,此MAP应该放到类变量中,属于常量,没必要每次调用都去创建:未来从配置文件或者数据库读取TypeB的所有数据格式,只是目前只支持BSM和BPM,未来可以加
|
|
|
- List<Map<String, Object>> returnDataList = new ArrayList<>();//初始化一个最终返回的数组
|
|
|
- for (String dataType : messageRules.keySet()) {//循环报文提取规则MAP:为了兼容一条字符串中既有BSM又有BPM的情况
|
|
|
- List<String> messagList = new ArrayList<>();
|
|
|
- for (String tempTypeStr : typeStrList) {
|
|
|
- if (tempTypeStr.indexOf("dataObjectId") > 0) {
|
|
|
- String tempDataObjectId = tempTypeStr.substring(tempTypeStr.indexOf("dataObjectId"));
|
|
|
- dataObjectId = tempDataObjectId.replaceAll("[^0-9]+", "");
|
|
|
- }
|
|
|
- List<String> tempMessageList = MapTools.patternContent(tempTypeStr, messageRules.get(dataType)); //使用对应的提取正则表达式进行报文提取
|
|
|
- if (tempMessageList.size() > 0) {
|
|
|
- messagList.addAll(tempMessageList);
|
|
|
- } else {
|
|
|
- if (tempTypeStr.contains(dataType)) {
|
|
|
- HashMap<String, Object> errorMap = new HashMap<>();
|
|
|
- errorMap.put("dataObjectId", dataObjectId);
|
|
|
- errorMap.put("errMessage", "报文数据格式错误");
|
|
|
- errorMap.put("sourceData", tempTypeStr);
|
|
|
- if (!returnDataList.contains(errorMap)) {
|
|
|
- returnDataList.add(errorMap);
|
|
|
- }
|
|
|
+ return processSuccess(rsList);
|
|
|
+ } catch (Exception e) {
|
|
|
+ return processFail(LogUtils.getException(e));
|
|
|
+ }
|
|
|
+ }
|
|
|
+
|
|
|
+
|
|
|
+ public static List<Map<String, Object>> typebHandler(String typeStr, Map<String, String> transMaps, String dataObjectId) {
|
|
|
+ List<String> typeStrList = MapTools.patternContent(typeStr, "\\{(.+?)\\}");
|
|
|
+ //设定报文提取规则MAP,此MAP应该放到类变量中,属于常量,没必要每次调用都去创建:未来从配置文件或者数据库读取TypeB的所有数据格式,只是目前只支持BSM和BPM,未来可以加
|
|
|
+ List<Map<String, Object>> returnDataList = new ArrayList<>();//初始化一个最终返回的数组
|
|
|
+ for (String dataType : messageRules.keySet()) {//循环报文提取规则MAP:为了兼容一条字符串中既有BSM又有BPM的情况
|
|
|
+ List<String> messagList = new ArrayList<>();
|
|
|
+ for (String tempTypeStr : typeStrList) {
|
|
|
+ if (tempTypeStr.indexOf("dataObjectId") > 0) {
|
|
|
+ String tempDataObjectId = tempTypeStr.substring(tempTypeStr.indexOf("dataObjectId"));
|
|
|
+ dataObjectId = tempDataObjectId.replaceAll("[^0-9]+", "");
|
|
|
+ }
|
|
|
+ List<String> tempMessageList = MapTools.patternContent(tempTypeStr, messageRules.get(dataType)); //使用对应的提取正则表达式进行报文提取
|
|
|
+ if (tempMessageList.size() > 0) {
|
|
|
+ messagList.addAll(tempMessageList);
|
|
|
+ } else {
|
|
|
+ if (tempTypeStr.contains(dataType)) {
|
|
|
+ HashMap<String, Object> errorMap = new HashMap<>();
|
|
|
+ errorMap.put("dataObjectId", dataObjectId);
|
|
|
+ errorMap.put("errMessage", "报文数据格式错误");
|
|
|
+ errorMap.put("sourceData", tempTypeStr);
|
|
|
+ if (!returnDataList.contains(errorMap)) {
|
|
|
+ returnDataList.add(errorMap);
|
|
|
}
|
|
|
}
|
|
|
}
|
|
|
- for (String signData : messagList) {//循环提取到的报文数组中每一条报文
|
|
|
- Map<String, Object> signDataMap = new HashMap<>();//创建一个当前报文的MAP
|
|
|
- signDataMap.put("dataType", dataType);//默认报文类型
|
|
|
- signDataMap.put("dataObjectId", dataObjectId); //默认生命周期ID
|
|
|
- signDataMap.put("sourceData", signData); //默认原始报文--因为要记录完整的原始报文,所以不去头不去尾
|
|
|
- String[] rowDataList = signData.split("(?=\\.[A-Z]{1}\\/)");//使用.字母/进行分组,获得行数据
|
|
|
- //获取第一行的数据:第一行,BPM为空,BSM直接使用indexOf判断即可
|
|
|
- signDataMap.put("dataState", dataType.equals("BSM") ? (rowDataList[0].contains("DEL") ? "DEL" : (rowDataList[0].contains("CHG") ? "CHG" : "ADD")) : null);
|
|
|
- List<Map<String, Object>> containerList = new ArrayList<>();//容器数组
|
|
|
- List<Map<String, Object>> luggageList = new ArrayList<>();//行李数组
|
|
|
- for (int rowNum = 1; rowNum < rowDataList.length; rowNum++) { //循环行数据
|
|
|
- String rowDataStr = rowDataList[rowNum];//获取单行数据
|
|
|
- String rowType = rowDataStr.substring(0, 3);//头三位是行标识
|
|
|
- if (".B/.N/".contains(rowType)) {//如果是.B\.N开头则//luggageList = getluggageNumList(rowDataStr);//--单独一个方法处理
|
|
|
- List<String> luggageNumList = new ArrayList<>();//默认行李牌号数组为空数组
|
|
|
- String luggageState = null;//默认行李状态为NULL
|
|
|
- String[] colList = rowDataStr.split("\\/");//使用\进行分组,获得列数据
|
|
|
- for (int colNum = 1; colNum < colList.length; colNum++) {//循环
|
|
|
- String colValue = colList[colNum].trim();//去空格 OFF,3666149457002
|
|
|
- colValue = replaceWrap(colValue);
|
|
|
- if (MapTools.isNumber(colValue) && colValue.length() == 13) {//如果是13位数字则
|
|
|
- String luggageNum = colValue.substring(0, 10);////获取前10位--开始行李牌号
|
|
|
- for (int loopNum = 0; loopNum < Integer.parseInt(colValue.substring(10, 13)); loopNum++) {//循环连续行李数
|
|
|
- luggageNum = String.format("%010d", (Long.parseLong(luggageNum) + loopNum)); //计算行李牌号,注意不足10位时前面补0:0999123456变数字后是9位
|
|
|
- luggageNumList.add(luggageNum);//添加到行李牌号数组 3666149457,3666149458
|
|
|
- }
|
|
|
- } else {//
|
|
|
- luggageState = MapTools.isNotBlank(colValue) ? colValue.substring(0, 3) : null;//更新行李状态
|
|
|
+ }
|
|
|
+ for (String signData : messagList) {//循环提取到的报文数组中每一条报文
|
|
|
+ Map<String, Object> signDataMap = new HashMap<>();//创建一个当前报文的MAP
|
|
|
+ signDataMap.put("dataType", dataType);//默认报文类型
|
|
|
+ signDataMap.put("dataObjectId", dataObjectId); //默认生命周期ID
|
|
|
+ signDataMap.put("sourceData", signData); //默认原始报文--因为要记录完整的原始报文,所以不去头不去尾
|
|
|
+ String[] rowDataList = signData.split("(?=\\.[A-Z]{1}\\/)", -1);//使用.字母/进行分组,获得行数据
|
|
|
+ //获取第一行的数据:第一行,BPM为空,BSM直接使用indexOf判断即可
|
|
|
+ signDataMap.put("dataState", dataType.equals("BSM") ? (rowDataList[0].contains("DEL") ? "DEL" : (rowDataList[0].contains("CHG") ? "CHG" : "ADD")) : null);
|
|
|
+ List<Map<String, Object>> containerList = new ArrayList<>();//容器数组
|
|
|
+ List<Map<String, Object>> luggageList = new ArrayList<>();//行李数组
|
|
|
+ for (int rowNum = 1; rowNum < rowDataList.length; rowNum++) { //循环行数据
|
|
|
+ String rowDataStr = rowDataList[rowNum];//获取单行数据
|
|
|
+ String rowType = rowDataStr.substring(0, 3);//头三位是行标识
|
|
|
+ if (".B/.N/".contains(rowType)) {//如果是.B\.N开头则//luggageList = getluggageNumList(rowDataStr);//--单独一个方法处理
|
|
|
+ List<String> luggageNumList = new ArrayList<>();//默认行李牌号数组为空数组
|
|
|
+ String luggageState = null;//默认行李状态为NULL
|
|
|
+ String[] colList = rowDataStr.split("\\/", -1);//使用\进行分组,获得列数据
|
|
|
+ for (int colNum = 1; colNum < colList.length; colNum++) {//循环
|
|
|
+ String colValue = colList[colNum].trim();//去空格 OFF,3666149457002
|
|
|
+ colValue = replaceWrap(colValue);
|
|
|
+ if (MapTools.isNumber(colValue) && colValue.length() == 13) {//如果是13位数字则
|
|
|
+ String luggageNum = colValue.substring(0, 10);////获取前10位--开始行李牌号
|
|
|
+ for (int loopNum = 0; loopNum < Integer.parseInt(colValue.substring(10, 13)); loopNum++) {//循环连续行李数
|
|
|
+ luggageNum = String.format("%010d", (Long.parseLong(luggageNum) + loopNum)); //计算行李牌号,注意不足10位时前面补0:0999123456变数字后是9位
|
|
|
+ luggageNumList.add(luggageNum);//添加到行李牌号数组 3666149457,3666149458
|
|
|
}
|
|
|
- }
|
|
|
- for (String luggageNum : luggageNumList) {//循环行李牌号数组
|
|
|
- Map<String, Object> luggageMap = new HashMap<>();
|
|
|
- luggageMap.put("luggageNum", luggageNum);
|
|
|
- luggageMap.put("abnormalState", luggageState);
|
|
|
- luggageList.add(luggageMap);//追加到行李数组中{行李牌号,行李状态}
|
|
|
+ } else {//
|
|
|
+ luggageState = MapTools.isNotBlank(colValue) ? colValue.substring(0, 3) : null;//更新行李状态
|
|
|
}
|
|
|
}
|
|
|
- //如果是.C\.E\.L\.M\.P\.Q\.R\.Q\.T开头则//去头写入当前行MAP{"对应数据库字段名",值(,号分割的字符串)
|
|
|
- if (".C/.E/.L/.M/.P/.Q/.R/.T/".contains(rowType)) {
|
|
|
- rowDataStr = rowDataStr.replace(rowType, "").trim();//去头去空格
|
|
|
+ for (String luggageNum : luggageNumList) {//循环行李牌号数组
|
|
|
+ Map<String, Object> luggageMap = new HashMap<>();
|
|
|
+ luggageMap.put("luggageNum", luggageNum);
|
|
|
+ luggageMap.put("abnormalState", luggageState);
|
|
|
+ luggageList.add(luggageMap);//追加到行李数组中{行李牌号,行李状态}
|
|
|
+ }
|
|
|
+ }
|
|
|
+ //如果是.C\.E\.L\.M\.P\.Q\.R\.Q\.T开头则//去头写入当前行MAP{"对应数据库字段名",值(,号分割的字符串)
|
|
|
+ if (".C/.E/.L/.M/.P/.Q/.R/.T/".contains(rowType)) {
|
|
|
+ rowDataStr = rowDataStr.replace(rowType, "").trim();//去头去空格
|
|
|
// rowDataStr = rowDataStr.indexOf("\\") > 0 ? rowDataStr.substring(0, rowDataStr.indexOf("\\") - 1) : rowDataStr;//去换行符
|
|
|
- rowDataStr = replaceWrap(rowDataStr);
|
|
|
- if (".P/".equals(rowType)) {//姓名需要去掉首位数字和分割符
|
|
|
- rowDataStr = rowDataStr.replaceAll("[(0-9)]", "").replaceAll("\\/", "");
|
|
|
- }
|
|
|
- if (Objects.nonNull(transMaps.get(rowType))) {
|
|
|
- signDataMap.put(transMaps.get(rowType), (signDataMap.containsKey(rowType) ? signDataMap.get(rowType) + "," : "") + rowDataStr);
|
|
|
- }
|
|
|
+ rowDataStr = replaceWrap(rowDataStr);
|
|
|
+ if (".P/".equals(rowType)) {//姓名需要去掉首位数字和分割符
|
|
|
+ rowDataStr = rowDataStr.replaceAll("[(0-9)]", "").replaceAll("\\/", "");
|
|
|
}
|
|
|
- //如果是.D\.F\.G\.H\.I\.J\.O\.S\.W\.X\.Y开头则只记录第一个,存在则不覆盖
|
|
|
- if (".D/.F/.G/.H/.I/.J/.O/.S/.W/.X/.Y/".contains(rowType) && !signDataMap.containsKey(rowType + "1")) {
|
|
|
- String[] colList = rowDataStr.split("\\/");//使用\进行分组,获得列数据
|
|
|
- for (int colNum = 1; colNum < colList.length; colNum++) {//循环
|
|
|
- String colValue = colList[colNum].trim();//去空格
|
|
|
- colValue = replaceWrap(colValue);
|
|
|
- //如果是日期则使用日期转换方法进行转换(08APR)(注意跨年处理)".F/"".I/"".O/"有日期,".D/"".J/"有日期和时间
|
|
|
- if (".F/.I/.O/.D/.J/".contains(rowType)) {
|
|
|
- String patternValue = MapTools.patternKey(colValue, "[0-3]{1}[0-9]{1}(JAN|FEB|MAR|APR|MAY|JUN|JUL|AUG|SEP|OCT|NOV|DEC)");
|
|
|
- if (!MapTools.isBlank(patternValue)) {
|
|
|
- colValue = TypeBDateChange(patternValue, null);
|
|
|
- signDataMap.put(rowType.equals(".D/") ? ".D/3" : (rowType.equals(".J/") ? ".J/4" : (rowType + "2")), colValue);//写入当前行MAP{"对应数据库字段名",值(不覆盖)}
|
|
|
- }
|
|
|
- if (".F/.I/.O/".contains(rowType) && MapTools.isNotBlank(colValue)) {
|
|
|
- if (colValue.length() == 3 && !MapTools.isBlank(MapTools.patternKey(colValue, "[A-z]{3}"))) {
|
|
|
- if (!signDataMap.containsKey(transMaps.get(rowType + "3"))) {
|
|
|
- signDataMap.put(transMaps.get(rowType + "3"), colValue);//写入当前行MAP{"对应数据库字段名",值(不覆盖)}
|
|
|
- }
|
|
|
- }
|
|
|
- if (colNum == 1) {
|
|
|
- String temp = colValue.substring(2);
|
|
|
- signDataMap.put(transMaps.get(rowType + "1"), colValue.substring(0, 2) + ((MapTools.isNumber(temp.substring(temp.length() - 1)) ? String.format("%4s", temp) : String.format("%5s", temp)).replace(" ", "0")));//写入当前行MAP{"对应数据库字段名",值(不覆盖)}
|
|
|
+ if (Objects.nonNull(transMaps.get(rowType))) {
|
|
|
+ signDataMap.put(transMaps.get(rowType), (signDataMap.containsKey(rowType) ? signDataMap.get(rowType) + "," : "") + rowDataStr);
|
|
|
+ }
|
|
|
+ }
|
|
|
+ //如果是.D\.F\.G\.H\.I\.J\.O\.S\.W\.X\.Y开头则只记录第一个,存在则不覆盖
|
|
|
+ if (".D/.F/.G/.H/.I/.J/.O/.S/.W/.X/.Y/".contains(rowType) && !signDataMap.containsKey(rowType + "1")) {
|
|
|
+ String[] colList = rowDataStr.split("\\/", -1);//使用\进行分组,获得列数据
|
|
|
+ for (int colNum = 1; colNum < colList.length; colNum++) {//循环
|
|
|
+ String colValue = colList[colNum].trim();//去空格
|
|
|
+ colValue = replaceWrap(colValue);
|
|
|
+ //如果是日期则使用日期转换方法进行转换(08APR)(注意跨年处理)".F/"".I/"".O/"有日期,".D/"".J/"有日期和时间
|
|
|
+ if (".F/.I/.O/.D/.J/".contains(rowType)) {
|
|
|
+ String patternValue = MapTools.patternKey(colValue, "[0-3]{1}[0-9]{1}(JAN|FEB|MAR|APR|MAY|JUN|JUL|AUG|SEP|OCT|NOV|DEC)");
|
|
|
+ if (!MapTools.isBlank(patternValue)) {
|
|
|
+ colValue = TypeBDateChange(patternValue, null);
|
|
|
+ signDataMap.put(rowType.equals(".D/") ? ".D/3" : (rowType.equals(".J/") ? ".J/4" : (rowType + "2")), colValue);//写入当前行MAP{"对应数据库字段名",值(不覆盖)}
|
|
|
+ }
|
|
|
+ if (".F/.I/.O/".contains(rowType) && MapTools.isNotBlank(colValue)) {
|
|
|
+ if (colValue.length() == 3 && !MapTools.isBlank(MapTools.patternKey(colValue, "[A-z]{3}"))) {
|
|
|
+ if (!signDataMap.containsKey(transMaps.get(rowType + "3"))) {
|
|
|
+ signDataMap.put(transMaps.get(rowType + "3"), colValue);//写入当前行MAP{"对应数据库字段名",值(不覆盖)}
|
|
|
}
|
|
|
}
|
|
|
- if ((rowType + "" + colNum).equals(".J/5") || (rowType + "" + colNum).equals(".D/4")) {
|
|
|
- colValue = TypeBDateChange(null, colValue);
|
|
|
+ if (colNum == 1) {
|
|
|
+ String temp = colValue.substring(2);
|
|
|
+ signDataMap.put(transMaps.get(rowType + "1"), colValue.substring(0, 2) + ((MapTools.isNumber(temp.substring(temp.length() - 1)) ? String.format("%4s", temp) : String.format("%5s", temp)).replace(" ", "0")));//写入当前行MAP{"对应数据库字段名",值(不覆盖)}
|
|
|
}
|
|
|
}
|
|
|
- if (".S/".contains(rowType) && MapTools.isNotBlank(colValue)) {
|
|
|
- if ("I,V,A".contains(colValue) && colValue.length() == 1 && !signDataMap.containsKey(transMaps.get(".S/8"))) {
|
|
|
- signDataMap.put(transMaps.get(".S/8"), colValue);//写入当前行MAP{"对应数据库字段名",值(不覆盖)}
|
|
|
- }
|
|
|
+ if ((rowType + "" + colNum).equals(".J/5") || (rowType + "" + colNum).equals(".D/4")) {
|
|
|
+ colValue = TypeBDateChange(null, colValue);
|
|
|
}
|
|
|
- if (".X/".contains(rowType) && MapTools.isNotBlank(colValue)) {
|
|
|
- if (colValue.length() == 3) {
|
|
|
- if ("CLR,RFJ,UCL".contains(colValue)) {
|
|
|
- signDataMap.put(transMaps.get(".X/2"), colValue);//写入当前行MAP{"对应数据库字段名",值(不覆盖)}
|
|
|
- } else {
|
|
|
- signDataMap.put(transMaps.get(".X/1"), colValue);//写入当前行MAP{"对应数据库字段名",值(不覆盖)}
|
|
|
- }
|
|
|
- }
|
|
|
+ }
|
|
|
+ if (".S/".contains(rowType) && MapTools.isNotBlank(colValue)) {
|
|
|
+ if ("I,V,A".contains(colValue) && colValue.length() == 1 && !signDataMap.containsKey(transMaps.get(".S/8"))) {
|
|
|
+ signDataMap.put(transMaps.get(".S/8"), colValue);//写入当前行MAP{"对应数据库字段名",值(不覆盖)}
|
|
|
}
|
|
|
- //如果是时间则使用时间转换方法进行转换转换(082512;082512L;082512Z,0825;0825L;0825Z)(注意没有结尾字母则是)".D/"".J/"有日期和时间
|
|
|
- //如果是日期时间则使用日期时间转换方法进行转换转换".G/"有日期时间(25NOV1600)
|
|
|
- //如果同时存在日期和时间".D/"".J/"有日期和时间
|
|
|
- String key = rowType + "" + colNum;
|
|
|
- if (".D/3.D/4.J/4.J/5".contains(rowType + "" + colNum)) {
|
|
|
- if (!signDataMap.containsKey(key)) {
|
|
|
- signDataMap.put(rowType + "" + colNum, colValue);//写入当前行MAP{"对应数据库字段名",值(不覆盖)}
|
|
|
+ }
|
|
|
+ if (".X/".contains(rowType) && MapTools.isNotBlank(colValue)) {
|
|
|
+ if (colValue.length() == 3) {
|
|
|
+ if ("CLR,RFJ,UCL".contains(colValue)) {
|
|
|
+ signDataMap.put(transMaps.get(".X/2"), colValue);//写入当前行MAP{"对应数据库字段名",值(不覆盖)}
|
|
|
+ } else {
|
|
|
+ signDataMap.put(transMaps.get(".X/1"), colValue);//写入当前行MAP{"对应数据库字段名",值(不覆盖)}
|
|
|
}
|
|
|
- } else {
|
|
|
- if (Objects.nonNull(transMaps.get(rowType + "" + colNum))) {
|
|
|
- if (!signDataMap.containsKey(transMaps.get(key))) {
|
|
|
- signDataMap.put(transMaps.get(rowType + "" + colNum), colValue);//写入当前行MAP{"对应数据库字段名",值(不覆盖)}
|
|
|
- }
|
|
|
+ }
|
|
|
+ }
|
|
|
+ //如果是时间则使用时间转换方法进行转换转换(082512;082512L;082512Z,0825;0825L;0825Z)(注意没有结尾字母则是)".D/"".J/"有日期和时间
|
|
|
+ //如果是日期时间则使用日期时间转换方法进行转换转换".G/"有日期时间(25NOV1600)
|
|
|
+ //如果同时存在日期和时间".D/"".J/"有日期和时间
|
|
|
+ String key = rowType + "" + colNum;
|
|
|
+ if (".D/3.D/4.J/4.J/5".contains(rowType + "" + colNum)) {
|
|
|
+ if (!signDataMap.containsKey(key)) {
|
|
|
+ signDataMap.put(rowType + "" + colNum, colValue);//写入当前行MAP{"对应数据库字段名",值(不覆盖)}
|
|
|
+ }
|
|
|
+ } else {
|
|
|
+ if (Objects.nonNull(transMaps.get(rowType + "" + colNum))) {
|
|
|
+ if (!signDataMap.containsKey(transMaps.get(key))) {
|
|
|
+ signDataMap.put(transMaps.get(rowType + "" + colNum), colValue);//写入当前行MAP{"对应数据库字段名",值(不覆盖)}
|
|
|
}
|
|
|
}
|
|
|
-
|
|
|
}
|
|
|
- // 处理D3D4 //J4J5
|
|
|
+
|
|
|
+ }
|
|
|
+ // 处理D3D4 //J4J5
|
|
|
// "D3D4": "checkInDate",
|
|
|
- if (Objects.nonNull(signDataMap.get(".D/3")) && Objects.nonNull(signDataMap.get(".D/4"))) {
|
|
|
- String d4 = signDataMap.get(".D/4").toString();
|
|
|
- signDataMap.put("checkInTimeType", d4.substring(d4.length() - 1));
|
|
|
- signDataMap.put(transMaps.get(".D/3.D/4"), (signDataMap.get(".D/3") + " " + d4.substring(0, d4.length() - 1)).trim());
|
|
|
- signDataMap.remove(".D/3");
|
|
|
- signDataMap.remove(".D/4");
|
|
|
- }
|
|
|
- if (Objects.nonNull(signDataMap.get(".J/4")) && Objects.nonNull(signDataMap.get(".J/5"))) {
|
|
|
- String J5 = signDataMap.get(".J/5").toString();
|
|
|
- signDataMap.put("processTimeType", J5.substring(J5.length() - 1));
|
|
|
- signDataMap.put(transMaps.get(".J/4.J/5"), (signDataMap.get(".J/4") + " " + J5.substring(0, J5.length() - 1)).trim());
|
|
|
- signDataMap.remove(".J/4");
|
|
|
- signDataMap.remove(".J/5");
|
|
|
- }
|
|
|
+ if (Objects.nonNull(signDataMap.get(".D/3")) && Objects.nonNull(signDataMap.get(".D/4"))) {
|
|
|
+ String d4 = signDataMap.get(".D/4").toString();
|
|
|
+ signDataMap.put("checkInTimeType", d4.substring(d4.length() - 1));
|
|
|
+ signDataMap.put(transMaps.get(".D/3.D/4"), (signDataMap.get(".D/3") + " " + d4.substring(0, d4.length() - 1)).trim());
|
|
|
+ signDataMap.remove(".D/3");
|
|
|
+ signDataMap.remove(".D/4");
|
|
|
}
|
|
|
- if (".V/".equals(rowType) && !signDataMap.containsKey(rowType + "1")) {//存在则不覆盖
|
|
|
- signDataMap.put(transMaps.get(".V/1"), rowDataStr.substring(4, 5));//写入当前行MAP{"来源标识",值}
|
|
|
- signDataMap.put(transMaps.get(".V/2"), rowDataStr.substring(5, 8));//写入当前行MAP{"来源机场",值}
|
|
|
+ if (Objects.nonNull(signDataMap.get(".J/4")) && Objects.nonNull(signDataMap.get(".J/5"))) {
|
|
|
+ String J5 = signDataMap.get(".J/5").toString();
|
|
|
+ signDataMap.put("processTimeType", J5.substring(J5.length() - 1));
|
|
|
+ signDataMap.put(transMaps.get(".J/4.J/5"), (signDataMap.get(".J/4") + " " + J5.substring(0, J5.length() - 1)).trim());
|
|
|
+ signDataMap.remove(".J/4");
|
|
|
+ signDataMap.remove(".J/5");
|
|
|
}
|
|
|
- if (".U/".equals(rowType)) {//如果是.U开头则----出现两个.U的需要单独处理
|
|
|
- Map<String, Object> containerMap = new HashMap<>();//创建一个当前报文的MAP
|
|
|
- String[] colList = rowDataStr.split("\\/");//使用\进行分组,获得列数据
|
|
|
- for (int colNum = 1; colNum < colList.length; colNum++) {//循环
|
|
|
- String colValue = colList[colNum];//去空格
|
|
|
-// colValue = colValue.indexOf("\\r\\n") > 0 ? colValue.substring(0, colValue.indexOf("\\r\\n") - 1) : colValue;//去换行符
|
|
|
- colValue = replaceWrap(colValue);
|
|
|
- if (Objects.nonNull(transMaps.get(rowType + "" + colNum))) {
|
|
|
- containerMap.put(transMaps.get(rowType + "" + colNum), colValue);//写入容器MAP
|
|
|
- }
|
|
|
-
|
|
|
+ }
|
|
|
+ if (".V/".equals(rowType) && !signDataMap.containsKey(rowType + "1")) {//存在则不覆盖
|
|
|
+ signDataMap.put(transMaps.get(".V/1"), rowDataStr.substring(4, 5));//写入当前行MAP{"来源标识",值}
|
|
|
+ signDataMap.put(transMaps.get(".V/2"), rowDataStr.substring(5, 8));//写入当前行MAP{"来源机场",值}
|
|
|
+ }
|
|
|
+ if (".U/".equals(rowType)) {//如果是.U开头则----出现两个.U的需要单独处理
|
|
|
+ Map<String, Object> containerMap = new HashMap<>();//创建一个当前报文的MAP
|
|
|
+ String[] colList = rowDataStr.split("\\/", -1);//使用\进行分组,获得列数据
|
|
|
+ for (int colNum = 1; colNum < colList.length; colNum++) {//循环
|
|
|
+ String colValue = colList[colNum];//去空格
|
|
|
+ colValue = replaceWrap(colValue);
|
|
|
+ if (Objects.nonNull(transMaps.get(rowType + "" + colNum))) {
|
|
|
+ containerMap.put(transMaps.get(rowType + "" + colNum), colValue);//写入容器MAP
|
|
|
}
|
|
|
- containerList.add(containerMap);//添加到容器数组中
|
|
|
+
|
|
|
}
|
|
|
+ containerList.add(containerMap);//添加到容器数组中
|
|
|
}
|
|
|
+ }
|
|
|
|
|
|
- //处理容器以及行李数组
|
|
|
- if (containerList.size() == 0) {//为0时添加空MAP,方便下面的循环
|
|
|
- containerList.add(new HashMap<>());
|
|
|
- }
|
|
|
- if (containerList.size() > 2) {//最多两个容器,否则是异常数据,整个报文都作废
|
|
|
- signDataMap.put("errMessage", "容器数量超规 " + containerList.size());//只需要标记错误,因为已经有原始报文存在
|
|
|
- Map<String, Object> containerMap = containerList.get(0);
|
|
|
- containerList = new ArrayList<>() {{
|
|
|
- add(containerMap);
|
|
|
- }};
|
|
|
+ //处理容器以及行李数组
|
|
|
+ if (containerList.size() == 0) {//为0时添加空MAP,方便下面的循环
|
|
|
+ containerList.add(new HashMap<>());
|
|
|
+ }
|
|
|
+ if (containerList.size() > 2) {//最多两个容器,否则是异常数据,整个报文都作废
|
|
|
+ signDataMap.put("errMessage", "容器数量超规 " + containerList.size());//只需要标记错误,因为已经有原始报文存在
|
|
|
+ Map<String, Object> containerMap = containerList.get(0);
|
|
|
+ containerList = new ArrayList<>() {{
|
|
|
+ add(containerMap);
|
|
|
+ }};
|
|
|
// returnDataList.add(signDataMap);//添加到返回数组中
|
|
|
+ }
|
|
|
+ for (int containerNum = 0; containerNum < containerList.size(); containerNum++) {//循环容器数组
|
|
|
+ HashMap<String, Object> tempDataMapClone = MapTools.clone(signDataMap);
|
|
|
+ HashMap<String, Object> tempDataMap = Objects.isNull(tempDataMapClone) ? new HashMap<>() : tempDataMapClone; //深拷贝添加到单条报文的MAP中
|
|
|
+ Map<String, Object> containerMap = containerList.get(containerNum);//获取当前容器数据
|
|
|
+ if (containerNum == 0 && containerList.size() > 1) {//如果当前是第一条且容器数组大于代表第一个容器是卸下,第二个容器是
|
|
|
+ containerMap.put("containerState", "OFF");//添加容器状态为OFF,代表卸下
|
|
|
}
|
|
|
- for (int containerNum = 0; containerNum < containerList.size(); containerNum++) {//循环容器数组
|
|
|
- HashMap<String, Object> tempDataMapClone = MapTools.clone(signDataMap);
|
|
|
- HashMap<String, Object> tempDataMap = Objects.isNull(tempDataMapClone) ? new HashMap<>() : tempDataMapClone; //深拷贝添加到单条报文的MAP中
|
|
|
- Map<String, Object> containerMap = containerList.get(containerNum);//获取当前容器数据
|
|
|
- if (containerNum == 0 && containerList.size() > 1) {//如果当前是第一条且容器数组大于代表第一个容器是卸下,第二个容器是
|
|
|
- containerMap.put("containerState", "OFF");//添加容器状态为OFF,代表卸下
|
|
|
- }
|
|
|
- if (!containerMap.isEmpty()) {//如果当前容器数据不是空
|
|
|
- tempDataMap.putAll(containerMap);//深拷贝添加到单条报文的MAP中
|
|
|
- }
|
|
|
- tempDataMap.values().removeAll(Collections.singleton(null));
|
|
|
- tempDataMap.values().removeAll(Collections.singleton(""));
|
|
|
- if (luggageList.size() == 0) {
|
|
|
- returnDataList.add(specialHandler(tempDataMap, dataObjectId)); //只有容器没有行李:整箱操作
|
|
|
- } else {
|
|
|
- for (Map<String, Object> tempLuggageMap : luggageList) {//循环行李数组
|
|
|
- if (containerNum == 0 && containerList.size() > 1 && tempLuggageMap.get("abnormalState") == null) {//只添加.B行李
|
|
|
- continue;
|
|
|
- }
|
|
|
- if (containerNum != 0 && containerList.size() > 1 && tempLuggageMap.get("abnormalState") != null) {//只添加.N行李
|
|
|
- continue;
|
|
|
- }
|
|
|
- HashMap<String, Object> objectObjectHashMap = new HashMap<>();
|
|
|
- objectObjectHashMap.putAll(tempDataMap);
|
|
|
- objectObjectHashMap.putAll(tempLuggageMap);
|
|
|
+ if (!containerMap.isEmpty()) {//如果当前容器数据不是空
|
|
|
+ tempDataMap.putAll(containerMap);//深拷贝添加到单条报文的MAP中
|
|
|
+ }
|
|
|
+ tempDataMap.values().removeAll(Collections.singleton(null));
|
|
|
+ tempDataMap.values().removeAll(Collections.singleton(""));
|
|
|
+ if (luggageList.size() == 0) {
|
|
|
+ returnDataList.add(specialHandler(tempDataMap, dataObjectId)); //只有容器没有行李:整箱操作
|
|
|
+ } else {
|
|
|
+ for (Map<String, Object> tempLuggageMap : luggageList) {//循环行李数组
|
|
|
+ if (containerNum == 0 && containerList.size() > 1 && tempLuggageMap.get("abnormalState") == null) {//只添加.B行李
|
|
|
+ continue;
|
|
|
+ }
|
|
|
+ if (containerNum != 0 && containerList.size() > 1 && tempLuggageMap.get("abnormalState") != null) {//只添加.N行李
|
|
|
+ continue;
|
|
|
+ }
|
|
|
+ HashMap<String, Object> objectObjectHashMap = new HashMap<>();
|
|
|
+ objectObjectHashMap.putAll(tempDataMap);
|
|
|
+ objectObjectHashMap.putAll(tempLuggageMap);
|
|
|
|
|
|
- if (Objects.isNull(objectObjectHashMap.get("abnormalState"))) {
|
|
|
- objectObjectHashMap.remove("abnormalState");
|
|
|
- }
|
|
|
-// tempDataMap.putAll(tempLuggageMap);//添加行李信息
|
|
|
- returnDataList.add(specialHandler(objectObjectHashMap, dataObjectId));//添加到返回数组中
|
|
|
+ if (Objects.isNull(objectObjectHashMap.get("abnormalState"))) {
|
|
|
+ objectObjectHashMap.remove("abnormalState");
|
|
|
}
|
|
|
+ returnDataList.add(specialHandler(objectObjectHashMap, dataObjectId));//添加到返回数组中
|
|
|
}
|
|
|
}
|
|
|
}
|
|
|
}
|
|
|
-
|
|
|
- if (returnDataList.size() == 0) {
|
|
|
- HashMap<String, Object> errorMap = new HashMap<>();
|
|
|
- errorMap.put("dataObjectId", dataObjectId);
|
|
|
- errorMap.put("errMessage", "报文数据格式错误");
|
|
|
- errorMap.put("sourceData", typeStr);
|
|
|
- returnDataList.add(errorMap);
|
|
|
- }
|
|
|
- return processSuccess(returnDataList);
|
|
|
- } catch (Exception e) {
|
|
|
- return processFail(LogUtils.getException(e));
|
|
|
}
|
|
|
+ if (returnDataList.size() == 0) {
|
|
|
+ HashMap<String, Object> errorMap = new HashMap<>();
|
|
|
+ errorMap.put("dataObjectId", dataObjectId);
|
|
|
+ errorMap.put("errMessage", "报文数据格式错误");
|
|
|
+ errorMap.put("sourceData", typeStr);
|
|
|
+ returnDataList.add(errorMap);
|
|
|
+ }
|
|
|
+ return returnDataList;
|
|
|
}
|
|
|
|
|
|
/**
|
|
@@ -557,7 +487,6 @@ public class DataFormat {
|
|
|
}
|
|
|
|
|
|
|
|
|
-
|
|
|
/**
|
|
|
* map key值转换
|
|
|
*
|
|
@@ -596,11 +525,11 @@ public class DataFormat {
|
|
|
Document doc = DocumentHelper.parseText(xmlStr);
|
|
|
Element root = doc.getRootElement();
|
|
|
Map<String, Object> returnMap = xmlToMap(root);
|
|
|
- returnMap.put("souceData",xml);
|
|
|
+ returnMap.put("souceData", xml);
|
|
|
return processSuccess(returnMap);
|
|
|
} catch (Exception e) {
|
|
|
Map<String, Object> errMap = processFail("入参不是规则的xml :" + xml);
|
|
|
- errMap.put("souceData",xml);
|
|
|
+ errMap.put("souceData", xml);
|
|
|
return errMap;
|
|
|
}
|
|
|
}
|