diff --git a/xhpc-modules/xhpc-power-pile/pom.xml b/xhpc-modules/xhpc-power-pile/pom.xml
index e14767a0..7d28659c 100644
--- a/xhpc-modules/xhpc-power-pile/pom.xml
+++ b/xhpc-modules/xhpc-power-pile/pom.xml
@@ -88,6 +88,11 @@
compile
+
+ cn.hutool
+ hutool-all
+ 5.7.5
+
diff --git a/xhpc-modules/xhpc-power-pile/src/main/java/com/xhpc/pp/logic/PileTimeConfigReplyDataLogic.java b/xhpc-modules/xhpc-power-pile/src/main/java/com/xhpc/pp/logic/PileTimeConfigReplyDataLogic.java
index 6a881674..ca9ff2d6 100644
--- a/xhpc-modules/xhpc-power-pile/src/main/java/com/xhpc/pp/logic/PileTimeConfigReplyDataLogic.java
+++ b/xhpc-modules/xhpc-power-pile/src/main/java/com/xhpc/pp/logic/PileTimeConfigReplyDataLogic.java
@@ -1,7 +1,8 @@
package com.xhpc.pp.logic;
+import cn.hutool.core.date.DateUtil;
import com.fasterxml.jackson.databind.ObjectMapper;
-import com.xhpc.common.data.up.PileConfigReplyData;
+import com.xhpc.common.data.up.PileTimeConfigReplyData;
import com.xhpc.pp.tx.ServiceParameter;
import com.xhpc.pp.tx.ServiceResult;
import com.xhpc.pp.tx.logic.ServiceLogic;
@@ -12,6 +13,11 @@ import org.springframework.stereotype.Component;
import java.util.Map;
+import static cn.hutool.core.date.DatePattern.UTC_FORMAT;
+import static com.xhpc.pp.server.ChargingPileServer.REDIS;
+import static com.xhpc.pp.utils.security.CP56Time2a.toDate;
+import static com.xhpc.pp.utils.security.HexUtils.toBytes;
+
@Lazy
@Component("PileTimeConfigReplyDataLogic")
public class PileTimeConfigReplyDataLogic implements ServiceLogic {
@@ -23,8 +29,18 @@ public class PileTimeConfigReplyDataLogic implements ServiceLogic {
Map req = sp.getParameters();
ObjectMapper objectMapper = new ObjectMapper();
- PileConfigReplyData pileConfigReplyData = objectMapper.convertValue(req, PileConfigReplyData.class);
- //todo
+ PileTimeConfigReplyData pileTimeConfigReplyData = objectMapper.convertValue(req, PileTimeConfigReplyData.class);
+ String pileNo = (String) req.get("pileNo");
+ String pk = "pile:".concat(pileNo);
+ Map cachePile = REDIS.getCacheMap(pk);
+ String setTime = (String) cachePile.get("setTime");
+ String configTime = pileTimeConfigReplyData.getSetTime();
+ if (configTime.equals(setTime)) {
+ log.info("({}) set time success", pileNo);
+ } else {
+ // todo may call back mgmt backend
+ log.error("({}) set time failed: √[{}] ×[{}]", pileNo, DateUtil.format(toDate(toBytes(setTime)), UTC_FORMAT), DateUtil.format(toDate(toBytes(configTime)), UTC_FORMAT));
+ }
return new ServiceResult(false);
}
diff --git a/xhpc-modules/xhpc-power-pile/src/main/java/com/xhpc/pp/server/ChargingPileBinaryHandler.java b/xhpc-modules/xhpc-power-pile/src/main/java/com/xhpc/pp/server/ChargingPileBinaryHandler.java
index 46bb428f..14e5cea1 100644
--- a/xhpc-modules/xhpc-power-pile/src/main/java/com/xhpc/pp/server/ChargingPileBinaryHandler.java
+++ b/xhpc-modules/xhpc-power-pile/src/main/java/com/xhpc/pp/server/ChargingPileBinaryHandler.java
@@ -23,8 +23,9 @@ import java.util.*;
import static com.xhpc.common.data.redis.SeqUtil.seqHex;
import static com.xhpc.pp.server.ChargingPileServer.REDIS;
import static com.xhpc.pp.tx.ServiceResult.OK;
-import static com.xhpc.pp.utils.security.CP56Time2aEncoder.getCP56time2aHex;
+import static com.xhpc.pp.utils.security.CP56Time2a.toBytes;
import static com.xhpc.pp.utils.security.CRCCalculator.calcCrc;
+import static com.xhpc.pp.utils.security.HexUtils.toHex;
public class ChargingPileBinaryHandler implements ClientBinaryHandler {
@@ -53,7 +54,7 @@ public class ChargingPileBinaryHandler implements ClientBinaryHandler {
try {
List dataList = parseDataList(data);
for (byte[] d : dataList) {
- String dataStr = HexUtils.toHex(d);
+ String dataStr = toHex(d);
String pileNo = ChargingPileServer.getPileNo(handler);
log.info("received data <<<< |{}| from pile <- ({})", dataStr, pileNo);
if (d.length <= 2 || !dataStr.startsWith("68")) {
@@ -79,7 +80,7 @@ public class ChargingPileBinaryHandler implements ClientBinaryHandler {
private void process(ClientHandler handler, byte[] data) throws TxException, IOException, NacosException {
- String serviceName = HexUtils.toHex(data, 5, 6);
+ String serviceName = toHex(data, 5, 6);
String version = ChargingPileServer.getVersion(handler.getName());
Map req = analysis(data, serviceName, version);
int seq = HexUtils.toInteger(data, 2, 4);
@@ -91,14 +92,18 @@ public class ChargingPileBinaryHandler implements ClientBinaryHandler {
String pilekey = "pile:".concat(pileNo);
if (SERVICE_REGISTER.equals(serviceName) && OK.equals(resultCode)) {
regHandler(handler, pileNo, req);
- String timebin = getTimeBin(seqHex(pilekey.concat("seqhex")), pileNo);
+ Calendar calendar = Calendar.getInstance();
+ String timebin = getTimeBin(seqHex(pilekey.concat("seqhex")), pileNo, calendar);
+ Map cachePile = REDIS.getCacheMap(pilekey);
+ cachePile.put("setTime", toHex(toBytes(calendar.getTime())));
+ REDIS.setCacheMap(pilekey, cachePile);
log.info("server send time config msg >>>> ({}) |{}|", pileNo, timebin);
handler.sendClientBinary(HexUtils.toBytes(timebin));
} else if (SERVICE_RMCR.equals(serviceName) && OK.equals(resultCode)) {
setCachePileRM(pilekey);
}
if (result.getBinary() != null) {
- log.info("server send msg >>>> ({}) |{}|", pileNo, HexUtils.toHex(result.getBinary()));
+ log.info("server send msg >>>> ({}) |{}|", pileNo, toHex(result.getBinary()));
handler.sendClientBinary(result.getBinary());
if (SERVICE_RMR.equals(serviceName) && OK.equals(resultCode)) {
setCachePileRM(pilekey);
@@ -106,9 +111,9 @@ public class ChargingPileBinaryHandler implements ClientBinaryHandler {
}
}
- private String getTimeBin(String seqhex, String pileNo) {
+ private String getTimeBin(String seqhex, String pileNo, Calendar calendar) {
- String timebin = "6812".concat(seqhex).concat("0056").concat(pileNo).concat(getCP56time2aHex(Calendar.getInstance()));
+ String timebin = "6812".concat(seqhex).concat("0056").concat(pileNo).concat(toHex(toBytes(calendar.getTime())));
timebin = timebin.concat(CRCCalculator.calcCrc(timebin));
return timebin;
}
@@ -170,11 +175,11 @@ public class ChargingPileBinaryHandler implements ClientBinaryHandler {
result.put(field.getCode(), HexUtils.byte2Long(ArrayUtils.subarray(data, pos, pos + field.getLen())));
break;
default:
- result.put(field.getCode(), HexUtils.toHex(data, pos, pos + field.getLen()));
+ result.put(field.getCode(), toHex(data, pos, pos + field.getLen()));
}
pos += field.getLen();
}
- result.put("hex", HexUtils.toHex(data));
+ result.put("hex", toHex(data));
return result;
}
diff --git a/xhpc-modules/xhpc-power-pile/src/main/java/com/xhpc/pp/utils/security/CP56Time2a.java b/xhpc-modules/xhpc-power-pile/src/main/java/com/xhpc/pp/utils/security/CP56Time2a.java
new file mode 100644
index 00000000..5f180366
--- /dev/null
+++ b/xhpc-modules/xhpc-power-pile/src/main/java/com/xhpc/pp/utils/security/CP56Time2a.java
@@ -0,0 +1,63 @@
+package com.xhpc.pp.utils.security;
+
+import java.util.Calendar;
+import java.util.Date;
+
+/**
+ * CP56time2a
+ *
+ * @author drebander
+ * @since 2020-09-11 11:35 上午
+ **/
+public class CP56Time2a {
+
+ public static Date toDate(byte[] bytes) {
+
+ int milliseconds1 = bytes[0] < 0 ? 256 + bytes[0] : bytes[0];
+ int milliseconds2 = bytes[1] < 0 ? 256 + bytes[1] : bytes[1];
+ int milliseconds = milliseconds1 + milliseconds2 * 256;
+ // 位于 0011 1111
+ int minutes = bytes[2] & 0x3f;
+ // 位于 0001 1111
+ int hours = bytes[3] & 0x1f;
+ // 位于 0000 1111
+ int days = bytes[4] & 0x3f;
+ // 位于 0001 1111
+ int months = bytes[5] & 0x0f;
+ // 位于 0111 1111
+ int years = bytes[6] & 0x7f;
+ Calendar aTime = Calendar.getInstance();
+ aTime.set(Calendar.MILLISECOND, milliseconds);
+ aTime.set(Calendar.MINUTE, minutes);
+ aTime.set(Calendar.HOUR_OF_DAY, hours + 8);
+ aTime.set(Calendar.DAY_OF_MONTH, days);
+ aTime.set(Calendar.MONTH, months - 1);
+ aTime.set(Calendar.YEAR, years + 2000);
+ return aTime.getTime();
+ }
+
+ public static byte[] toBytes(Date aDate) {
+
+ byte[] result = new byte[7];
+ Calendar aTime = Calendar.getInstance();
+ aTime.setTime(aDate);
+ final int milliseconds = aTime.get(Calendar.MILLISECOND);
+ result[0] = (byte) (milliseconds % 256);
+ result[1] = (byte) (milliseconds / 256);
+ result[2] = (byte) aTime.get(Calendar.MINUTE);
+ result[3] = (byte) aTime.get(Calendar.HOUR_OF_DAY);
+ result[4] = (byte) aTime.get(Calendar.DAY_OF_MONTH);
+ result[5] = (byte) aTime.get(Calendar.MONTH);
+ result[6] = (byte) (aTime.get(Calendar.YEAR) % 100);
+ return result;
+ }
+
+// public static void main(String[] args) {
+// Date aDate = new Date();
+// System.out.println(aDate);
+// final byte[] bytes = toBytes(aDate);
+// final Date date = toDate(bytes);
+// System.out.println(date);
+// }
+
+}
diff --git a/xhpc-modules/xhpc-power-pile/src/main/java/com/xhpc/pp/utils/security/CP56Time2aEncoder.java b/xhpc-modules/xhpc-power-pile/src/main/java/com/xhpc/pp/utils/security/CP56Time2aEncoder.java
deleted file mode 100644
index e8bc7df5..00000000
--- a/xhpc-modules/xhpc-power-pile/src/main/java/com/xhpc/pp/utils/security/CP56Time2aEncoder.java
+++ /dev/null
@@ -1,62 +0,0 @@
-package com.xhpc.pp.utils.security;
-
-import java.util.Calendar;
-
-public class CP56Time2aEncoder {
-
- private byte octetset[];
- private Object dataset[];
-
- public CP56Time2aEncoder(Calendar calendar) {
-
- int k;
- int i = 7;
- octetset = new byte[i];
- int j = 13;
- dataset = new Object[j];
- for (k = 0; k < i; k++) {
- octetset[k] = (byte) 0x00;
- }
- for (k = 0; k < j; k++) {
- dataset[k] = null;
- }
- dataset[0] = calendar.get(Calendar.MILLISECOND) + 1000 * calendar.get(Calendar.SECOND);
- dataset[1] = (byte) calendar.get(Calendar.MINUTE);
- dataset[2] = Boolean.FALSE;
- dataset[3] = Boolean.FALSE;
- dataset[4] = (byte) calendar.get(Calendar.HOUR_OF_DAY);
- dataset[5] = Boolean.FALSE;
- dataset[6] = Boolean.TRUE; //summertime
- dataset[7] = (byte) calendar.get(Calendar.DAY_OF_MONTH);
- dataset[8] = (byte) calendar.get(Calendar.DAY_OF_WEEK);
- dataset[9] = (byte) (calendar.get(Calendar.MONTH) + 1);
- dataset[10] = (byte) 0x00;
-
- int year = calendar.get(Calendar.YEAR);
-
- year = Math.round((float) Math.IEEEremainder(year, 100));
-
- dataset[11] = (byte) (year);
- dataset[12] = Boolean.FALSE;
- code();
- }
-
- protected void code() {
-
- octetset[0] = (byte) ((Integer) dataset[0] & 0xFF); //Millisecond
- octetset[1] = (byte) (((Integer) dataset[0] & 0xFF00) >> 8); //Millisecond
- octetset[2] = ((Byte) dataset[1]); // Minutes
- octetset[3] = (byte) ((Byte) dataset[4] | ((((Boolean) dataset[6]) ? 1 : 0) << 7)); //summertime
- octetset[4] = (byte) (((Byte) dataset[7]) | ((Byte) dataset[8] << 5)); // weekday day of month
- octetset[5] = (byte) ((Byte) dataset[9] | ((Byte) dataset[10] << 4)); // month
- octetset[6] = (byte) dataset[11]; // year
- }
-
- public static String getCP56time2aHex(Calendar calendar) {
-
- CP56Time2aEncoder encoder = new CP56Time2aEncoder(calendar);
- encoder.code();
- return HexUtils.toHex(encoder.octetset);
- }
-
-}
diff --git a/xhpc-modules/xhpc-power-pile/src/main/java/com/xhpc/pp/utils/security/CacheDataUtils.java b/xhpc-modules/xhpc-power-pile/src/main/java/com/xhpc/pp/utils/security/CacheDataUtils.java
index 5bb6d624..b622e2ac 100644
--- a/xhpc-modules/xhpc-power-pile/src/main/java/com/xhpc/pp/utils/security/CacheDataUtils.java
+++ b/xhpc-modules/xhpc-power-pile/src/main/java/com/xhpc/pp/utils/security/CacheDataUtils.java
@@ -1,10 +1,14 @@
package com.xhpc.pp.utils.security;
+import cn.hutool.core.date.DateUtil;
+
import java.lang.reflect.Field;
import java.lang.reflect.InvocationTargetException;
+import static cn.hutool.core.date.DatePattern.UTC_FORMAT;
import static com.xhpc.common.core.utils.StringUtils.capitalize;
-import static com.xhpc.pp.utils.security.Cp56Time2aDecoder.getCP56time2a;
+import static com.xhpc.pp.utils.security.CP56Time2a.toDate;
+import static com.xhpc.pp.utils.security.HexUtils.toBytes;
public class CacheDataUtils {
@@ -18,7 +22,7 @@ public class CacheDataUtils {
if (tarfield.getType().getSimpleName().equals("Integer")) {
tarval = HexUtils.reverseHexInt(srcval);
} else if (tarFieldName.contains("ime")) {
- tarval = getCP56time2a(srcval);
+ tarval = DateUtil.format(toDate(toBytes(srcval)), UTC_FORMAT);
} else {
tarval = srcval;
}
diff --git a/xhpc-modules/xhpc-power-pile/src/main/java/com/xhpc/pp/utils/security/Cp56Time2aDecoder.java b/xhpc-modules/xhpc-power-pile/src/main/java/com/xhpc/pp/utils/security/Cp56Time2aDecoder.java
deleted file mode 100644
index 1d95fded..00000000
--- a/xhpc-modules/xhpc-power-pile/src/main/java/com/xhpc/pp/utils/security/Cp56Time2aDecoder.java
+++ /dev/null
@@ -1,20 +0,0 @@
-package com.xhpc.pp.utils.security;
-
-public class Cp56Time2aDecoder {
-
- public static void main(String[] args) {
-
- String date = getCP56time2a("F0D2210F060815");
- System.out.println(date);
- }
-
- public static String getCP56time2a(String str) {
-
- return "20" + Integer.parseInt(str.substring(12, 14), 16) + "-" + Integer.parseInt(str.substring(10, 12), 16)
- + "-" + Integer.parseInt(str.substring(8, 10), 16) + "T" + Integer.parseInt(str.substring(6, 8), 16)
- + ":" + Integer.parseInt(str.substring(4, 6), 16) + ":"
- + Integer.parseInt(str.substring(2, 4) + "" + str.substring(0, 2), 16) / 1000;
- }
-
-}
-