mirror of
https://codeup.aliyun.com/67c68d4e484ca2f0a13ac3c1/ydc/jsowell-charger-web.git
synced 2026-06-29 11:38:04 +08:00
update 获取地锁数据
This commit is contained in:
@@ -25,6 +25,9 @@ public class CacheConstants {
|
|||||||
|
|
||||||
public static final String GET_PILE_MODEL_INFO_BY_MODEL_ID = "get_pile_model_info_by_model_id:";
|
public static final String GET_PILE_MODEL_INFO_BY_MODEL_ID = "get_pile_model_info_by_model_id:";
|
||||||
|
|
||||||
|
// 地锁数据
|
||||||
|
public static final String GROUND_LOCK_DATA = "ground_lock_data:";
|
||||||
|
|
||||||
// 根据站点id查询充电桩列表
|
// 根据站点id查询充电桩列表
|
||||||
public static final String GET_PILE_LIST_BY_STATION_ID = "get_pile_list_by_station_id:";
|
public static final String GET_PILE_LIST_BY_STATION_ID = "get_pile_list_by_station_id:";
|
||||||
|
|
||||||
|
|||||||
@@ -0,0 +1,45 @@
|
|||||||
|
package com.jsowell.common.core.domain.ykc;
|
||||||
|
|
||||||
|
import lombok.AllArgsConstructor;
|
||||||
|
import lombok.Builder;
|
||||||
|
import lombok.Data;
|
||||||
|
import lombok.NoArgsConstructor;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 地锁数据
|
||||||
|
*/
|
||||||
|
@Data
|
||||||
|
@NoArgsConstructor
|
||||||
|
@AllArgsConstructor
|
||||||
|
@Builder
|
||||||
|
public class GroundLockData {
|
||||||
|
/**
|
||||||
|
* 充电桩编号
|
||||||
|
*/
|
||||||
|
private String pileSn;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 枪口号
|
||||||
|
*/
|
||||||
|
private String connectorCode;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 车位锁状态
|
||||||
|
*/
|
||||||
|
private String parkingLockStatus;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 车位状态
|
||||||
|
*/
|
||||||
|
private String parkingStatus;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 地锁电量状态
|
||||||
|
*/
|
||||||
|
private String groundLockElectric;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 报警状态
|
||||||
|
*/
|
||||||
|
private String alarmStatus;
|
||||||
|
}
|
||||||
@@ -67,7 +67,7 @@ public abstract class AbstractHandler implements InitializingBean {
|
|||||||
*/
|
*/
|
||||||
protected void saveLastTime(String pileSn) {
|
protected void saveLastTime(String pileSn) {
|
||||||
String redisKey = CacheConstants.PILE_LAST_CONNECTION + pileSn;
|
String redisKey = CacheConstants.PILE_LAST_CONNECTION + pileSn;
|
||||||
redisCache.setCacheObject(redisKey, DateUtils.getTime(), 60 * 60 * 24);
|
redisCache.setCacheObject(redisKey, DateUtils.getTime(), CacheConstants.cache_expire_time_1d);
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
@@ -1,13 +1,17 @@
|
|||||||
package com.jsowell.netty.handler;
|
package com.jsowell.netty.handler;
|
||||||
|
|
||||||
import com.alibaba.fastjson2.JSONObject;
|
import com.alibaba.fastjson2.JSONObject;
|
||||||
|
import com.jsowell.common.constant.CacheConstants;
|
||||||
|
import com.jsowell.common.core.domain.ykc.GroundLockData;
|
||||||
import com.jsowell.common.core.domain.ykc.YKCDataProtocol;
|
import com.jsowell.common.core.domain.ykc.YKCDataProtocol;
|
||||||
import com.jsowell.common.core.domain.ykc.YKCFrameTypeCode;
|
import com.jsowell.common.core.domain.ykc.YKCFrameTypeCode;
|
||||||
|
import com.jsowell.common.core.redis.RedisCache;
|
||||||
import com.jsowell.common.util.BytesUtil;
|
import com.jsowell.common.util.BytesUtil;
|
||||||
import com.jsowell.common.util.YKCUtils;
|
import com.jsowell.common.util.YKCUtils;
|
||||||
import com.jsowell.netty.factory.YKCOperateFactory;
|
import com.jsowell.netty.factory.YKCOperateFactory;
|
||||||
import io.netty.channel.Channel;
|
import io.netty.channel.Channel;
|
||||||
import lombok.extern.slf4j.Slf4j;
|
import lombok.extern.slf4j.Slf4j;
|
||||||
|
import org.springframework.beans.factory.annotation.Autowired;
|
||||||
import org.springframework.stereotype.Component;
|
import org.springframework.stereotype.Component;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@@ -21,6 +25,9 @@ import org.springframework.stereotype.Component;
|
|||||||
@Slf4j
|
@Slf4j
|
||||||
@Component
|
@Component
|
||||||
public class GroundLockDataUploadHandler extends AbstractHandler{
|
public class GroundLockDataUploadHandler extends AbstractHandler{
|
||||||
|
@Autowired
|
||||||
|
private RedisCache redisCache;
|
||||||
|
|
||||||
private final String type = YKCUtils.frameType2Str(YKCFrameTypeCode.GROUND_LOCK_DATA_UPLOAD_CODE.getBytes());
|
private final String type = YKCUtils.frameType2Str(YKCFrameTypeCode.GROUND_LOCK_DATA_UPLOAD_CODE.getBytes());
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
@@ -33,10 +40,15 @@ public class GroundLockDataUploadHandler extends AbstractHandler{
|
|||||||
log.info("[===地锁数据上送===] param:{}, channel:{}", JSONObject.toJSONString(ykcDataProtocol), channel.toString());
|
log.info("[===地锁数据上送===] param:{}, channel:{}", JSONObject.toJSONString(ykcDataProtocol), channel.toString());
|
||||||
// 消息体
|
// 消息体
|
||||||
byte[] msgBody = ykcDataProtocol.getMsgBody();
|
byte[] msgBody = ykcDataProtocol.getMsgBody();
|
||||||
|
|
||||||
// 桩编码
|
// 桩编码
|
||||||
byte[] pileSnByteArr = BytesUtil.copyBytes(msgBody, 0, 7);
|
byte[] pileSnByteArr = BytesUtil.copyBytes(msgBody, 0, 7);
|
||||||
|
String pileSn = BytesUtil.bcd2Str(pileSnByteArr);
|
||||||
|
|
||||||
// 枪号
|
// 枪号
|
||||||
byte[] connectorByteArr = BytesUtil.copyBytes(msgBody, 7, 1);
|
byte[] connectorCodeByteArr = BytesUtil.copyBytes(msgBody, 7, 1);
|
||||||
|
String connectorCode = BytesUtil.bcd2Str(connectorCodeByteArr);
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* 车位锁状态
|
* 车位锁状态
|
||||||
* 0x00:未到位状态
|
* 0x00:未到位状态
|
||||||
@@ -44,14 +56,37 @@ public class GroundLockDataUploadHandler extends AbstractHandler{
|
|||||||
* 0xFF:降锁到位状态
|
* 0xFF:降锁到位状态
|
||||||
*/
|
*/
|
||||||
byte[] parkingLockStatusByteArr = BytesUtil.copyBytes(msgBody, 8, 1);
|
byte[] parkingLockStatusByteArr = BytesUtil.copyBytes(msgBody, 8, 1);
|
||||||
|
String parkingLockStatus = BytesUtil.bcd2Str(parkingLockStatusByteArr);
|
||||||
|
|
||||||
// 车位状态 0x00:无车辆 0xFF:停放车辆
|
// 车位状态 0x00:无车辆 0xFF:停放车辆
|
||||||
byte[] parkingStatusByteArr = BytesUtil.copyBytes(msgBody, 9, 1);
|
byte[] parkingStatusByteArr = BytesUtil.copyBytes(msgBody, 9, 1);
|
||||||
|
String parkingStatus = BytesUtil.bcd2Str(parkingStatusByteArr);
|
||||||
|
|
||||||
// 地锁电量状态 百分比值0~100
|
// 地锁电量状态 百分比值0~100
|
||||||
byte[] groundLockElectricByteArr = BytesUtil.copyBytes(msgBody, 10, 1);
|
byte[] groundLockElectricByteArr = BytesUtil.copyBytes(msgBody, 10, 1);
|
||||||
|
String groundLockElectric = BytesUtil.bcd2Str(groundLockElectricByteArr);
|
||||||
|
|
||||||
// 报警状态 0x00:正常无报警 0xFF:待机状态摇臂破坏 0x55:摇臂升降异常(未到位)
|
// 报警状态 0x00:正常无报警 0xFF:待机状态摇臂破坏 0x55:摇臂升降异常(未到位)
|
||||||
byte[] alarmStatusByteArr = BytesUtil.copyBytes(msgBody, 11, 1);
|
byte[] alarmStatusByteArr = BytesUtil.copyBytes(msgBody, 11, 1);
|
||||||
|
String alarmStatus = BytesUtil.bcd2Str(alarmStatusByteArr);
|
||||||
|
|
||||||
// 预留位 全部置0
|
// 预留位 全部置0
|
||||||
byte[] waitingUseByteArr = BytesUtil.copyBytes(msgBody, 12, 4);
|
byte[] waitingUseByteArr = BytesUtil.copyBytes(msgBody, 12, 4);
|
||||||
|
String waitingUse = BytesUtil.bcd2Str(waitingUseByteArr);
|
||||||
|
|
||||||
|
// 封装到对象中
|
||||||
|
GroundLockData data = GroundLockData.builder()
|
||||||
|
.pileSn(pileSn)
|
||||||
|
.connectorCode(connectorCode)
|
||||||
|
.parkingLockStatus(parkingLockStatus)
|
||||||
|
.parkingStatus(parkingStatus)
|
||||||
|
.groundLockElectric(groundLockElectric)
|
||||||
|
.alarmStatus(alarmStatus)
|
||||||
|
.build();
|
||||||
|
|
||||||
|
// 地锁信息放缓存中 缓存10分钟
|
||||||
|
String redisKey = CacheConstants.GROUND_LOCK_DATA + pileSn + connectorCode;
|
||||||
|
redisCache.setCacheObject(redisKey, data, CacheConstants.cache_expire_time_10m);
|
||||||
|
|
||||||
return null;
|
return null;
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -8,6 +8,7 @@ import com.google.common.collect.Maps;
|
|||||||
import com.google.common.collect.Sets;
|
import com.google.common.collect.Sets;
|
||||||
import com.jsowell.common.constant.CacheConstants;
|
import com.jsowell.common.constant.CacheConstants;
|
||||||
import com.jsowell.common.constant.Constants;
|
import com.jsowell.common.constant.Constants;
|
||||||
|
import com.jsowell.common.core.domain.ykc.GroundLockData;
|
||||||
import com.jsowell.common.core.domain.ykc.RealTimeMonitorData;
|
import com.jsowell.common.core.domain.ykc.RealTimeMonitorData;
|
||||||
import com.jsowell.common.core.page.PageResponse;
|
import com.jsowell.common.core.page.PageResponse;
|
||||||
import com.jsowell.common.core.redis.RedisCache;
|
import com.jsowell.common.core.redis.RedisCache;
|
||||||
@@ -481,9 +482,36 @@ public class PileConnectorInfoServiceImpl implements IPileConnectorInfoService {
|
|||||||
// 并修改数据库状态为离线
|
// 并修改数据库状态为离线
|
||||||
updateConnectorStatusByPileSn(pileConnectorInfoVO.getPileSn(), PileConnectorDataBaseStatusEnum.OFF_NETWORK.getValue());
|
updateConnectorStatusByPileSn(pileConnectorInfoVO.getPileSn(), PileConnectorDataBaseStatusEnum.OFF_NETWORK.getValue());
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// 获取地锁数据
|
||||||
|
pileConnectorInfoVO.setGroundLockData(queryGroundLockData(pileConnectorInfoVO.getPileConnectorCode()));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 通过充电桩枪口编号查询对应地锁数据
|
||||||
|
* @param pileSn 充电桩编号
|
||||||
|
* @param connectorCode 枪口号
|
||||||
|
*/
|
||||||
|
private GroundLockData queryGroundLockData(String pileSn, String connectorCode) {
|
||||||
|
if (StringUtils.isBlank(pileSn) || StringUtils.isBlank(connectorCode)) {
|
||||||
|
return null;
|
||||||
|
}
|
||||||
|
return queryGroundLockData(pileSn + connectorCode);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 通过充电桩枪口编号查询对应地锁数据
|
||||||
|
* @param pileConnectorCode 充电桩枪口编号
|
||||||
|
*/
|
||||||
|
private GroundLockData queryGroundLockData(String pileConnectorCode) {
|
||||||
|
if (StringUtils.isBlank(pileConnectorCode)) {
|
||||||
|
return null;
|
||||||
|
}
|
||||||
|
String redisKey = CacheConstants.GROUND_LOCK_DATA + pileConnectorCode;
|
||||||
|
return redisCache.getCacheObject(redisKey);
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* 通过桩编号修改枪口状态
|
* 通过桩编号修改枪口状态
|
||||||
* 仅用于登录逻辑使用
|
* 仅用于登录逻辑使用
|
||||||
|
|||||||
@@ -1,5 +1,6 @@
|
|||||||
package com.jsowell.pile.vo.web;
|
package com.jsowell.pile.vo.web;
|
||||||
|
|
||||||
|
import com.jsowell.common.core.domain.ykc.GroundLockData;
|
||||||
import lombok.AllArgsConstructor;
|
import lombok.AllArgsConstructor;
|
||||||
import lombok.Builder;
|
import lombok.Builder;
|
||||||
import lombok.Data;
|
import lombok.Data;
|
||||||
@@ -163,4 +164,9 @@ public class PileConnectorInfoVO {
|
|||||||
*/
|
*/
|
||||||
private String ratedPower;
|
private String ratedPower;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 地锁数据
|
||||||
|
*/
|
||||||
|
private GroundLockData groundLockData;
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|||||||
Reference in New Issue
Block a user