update 联联平台查询充电状态接口

This commit is contained in:
Lemon
2023-05-31 15:24:18 +08:00
parent 52884983f5
commit f310d4f022
5 changed files with 110 additions and 24 deletions

View File

@@ -364,22 +364,61 @@ public class LianLianController extends BaseController {
* @param startChargeSeq * @param startChargeSeq
* @return * @return
*/ */
@GetMapping("/query_equip_charge_status/{startChargeSeq}") // @GetMapping("/query_equip_charge_status/{startChargeSeq}")
public RestApiResponse<?> query_equip_charge_status(@PathVariable("startChargeSeq") String startChargeSeq) { // public RestApiResponse<?> query_equip_charge_status(@PathVariable("startChargeSeq") String startChargeSeq) {
logger.info("联联平台查询充电状态 params :{}", startChargeSeq); // logger.info("联联平台查询充电状态 params :{}", startChargeSeq);
RestApiResponse<?> response; // RestApiResponse<?> response;
// try {
// QueryChargingStatusVO vo = lianLianService.query_equip_charge_status(startChargeSeq);
// response = new RestApiResponse<>(vo);
// }catch (BusinessException e) {
// logger.error("联联平台查询充电状态 error",e);
// response = new RestApiResponse<>(e.getCode(), e.getMessage());
// } catch (Exception e) {
// logger.error("联联平台查询充电状态 error", e);
// response = new RestApiResponse<>(e);
// }
// logger.info("联联平台查询充电状态 result :{}", response);
// return response;
// }
/**
* 查询充电状态
* http://localhost:8080/LianLian/query_equip_charge_status/{startChargeSeq}
* @param dto
* @return
*/
@PostMapping("/v1/query_equip_charge_status")
public CommonResult<?> query_equip_charge_status(HttpServletRequest request, @RequestBody CommonParamsDTO dto) {
logger.info("联联平台查询充电状态 params :{}", JSONObject.toJSONString(dto));
try { try {
QueryChargingStatusVO vo = lianLianService.query_equip_charge_status(startChargeSeq); // 校验令牌
response = new RestApiResponse<>(vo); String token = request.getHeader("Authorization");
}catch (BusinessException e) { if (!JWTUtils.checkThirdPartyToken(token)) {
logger.error("联联平台查询充电状态 error",e); // 校验失败
response = new RestApiResponse<>(e.getCode(), e.getMessage()); return CommonResult.failed("令牌校验错误");
}
// 校验签名
Map<String, String> resultMap = lianLianService.checkoutSign(dto);
if (resultMap == null) {
// 签名错误
return CommonResult.failed("签名校验错误");
}
String operatorSecret = resultMap.get("OperatorSecret");
String dataString = resultMap.get("Data");
// 解密data
byte[] plainText = Cryptos.aesDecrypt(Encodes.decodeBase64(dataString), operatorSecret.getBytes(), operatorSecret.getBytes());
String dataStr = new String(plainText, "UTF-8");
// 转换成相应对象
QueryEquipChargeStatusDTO queryEquipChargeStatusDTO = JSONObject.parseObject(dataStr, QueryEquipChargeStatusDTO.class);
queryEquipChargeStatusDTO.setOperatorID(dto.getOperatorID());
Map<String, String> map = lianLianService.query_equip_charge_status(queryEquipChargeStatusDTO);
return CommonResult.success(0, "查询充电状态成功!", map.get("Data"), map.get("Sig"));
} catch (Exception e) { } catch (Exception e) {
logger.error("联联平台查询充电状态 error", e); logger.error("联联平台查询充电状态 error", e);
response = new RestApiResponse<>(e);
} }
logger.info("联联平台查询充电状态 result :{}", response); return CommonResult.failed("查询充电状态发生异常");
return response;
} }
/** /**

View File

@@ -137,6 +137,9 @@ public class YKCUtils {
String s1 = convertDecimalPoint(bytess, 5); String s1 = convertDecimalPoint(bytess, 5);
System.out.println(s1); System.out.println(s1);
String amount = "1000";
byte[] priceByte = getPriceByte(amount, 2);
System.out.println(BytesUtil.bin2HexStr(priceByte));
} }
/** /**

View File

@@ -0,0 +1,19 @@
package com.jsowell.pile.dto;
import com.fasterxml.jackson.annotation.JsonProperty;
import lombok.Data;
/**
* 联联平台查询充电状态
*
* @author JS-ZZA
* @date 2023/5/31 15:00
*/
@Data
public class QueryEquipChargeStatusDTO {
@JsonProperty(value = "StartChargeSeq")
private String StartChargeSeq;
@JsonProperty(value = "OperatorID")
private String OperatorID;
}

View File

@@ -64,9 +64,9 @@ public interface LianLianService {
/** /**
* 查询充电状态 * 查询充电状态
* @param startChargeSeq * @param dto
*/ */
QueryChargingStatusVO query_equip_charge_status(String startChargeSeq); Map<String, String> query_equip_charge_status(QueryEquipChargeStatusDTO dto);
/** /**
* 请求停止充电 * 请求停止充电
@@ -110,7 +110,7 @@ public interface LianLianService {
* @param orderCode * @param orderCode
* @return * @return
*/ */
String pushChargeStatus(String orderCode); String pushChargeStatus(String orderCode) throws UnsupportedEncodingException;
/** /**
* 推送停止充电结果(仅在 交易记录的帧类型中调用) * 推送停止充电结果(仅在 交易记录的帧类型中调用)

View File

@@ -612,15 +612,19 @@ public class LianLianServiceImpl implements LianLianService {
/** /**
* 查询充电状态 * 查询充电状态
* *
* @param startChargeSeq * @param dto
* @return * @return
*/ */
public QueryChargingStatusVO query_equip_charge_status(String startChargeSeq) { public Map<String, String> query_equip_charge_status(QueryEquipChargeStatusDTO dto) {
// 通过订单号查询订单信息 // 通过订单号查询订单信息
OrderBasicInfo orderInfo = orderBasicInfoService.getOrderInfoByOrderCode(startChargeSeq); OrderBasicInfo orderInfo = orderBasicInfoService.getOrderInfoByOrderCode(dto.getStartChargeSeq());
// 通过订单号查询实时数据 // 通过订单号查询实时数据
if (orderInfo == null) { if (orderInfo == null) {
throw new BusinessException("", ""); return null;
}
DockingPlatformConfig configInfo = dockingPlatformConfigService.getInfoByOperatorId(dto.getOperatorID());
if (configInfo == null) {
return null;
} }
OrderDetail orderDetail = orderBasicInfoService.getOrderDetailByOrderCode(orderInfo.getOrderCode()); OrderDetail orderDetail = orderBasicInfoService.getOrderDetailByOrderCode(orderInfo.getOrderCode());
List<RealTimeMonitorData> realTimeData = orderBasicInfoService.getChargingRealTimeData(orderInfo.getTransactionCode()); List<RealTimeMonitorData> realTimeData = orderBasicInfoService.getChargingRealTimeData(orderInfo.getTransactionCode());
@@ -639,7 +643,7 @@ public class LianLianServiceImpl implements LianLianService {
} }
// 拼装联联平台数据 // 拼装联联平台数据
QueryChargingStatusVO vo = QueryChargingStatusVO.builder() QueryChargingStatusVO vo = QueryChargingStatusVO.builder()
.StartChargeSeq(startChargeSeq) // 订单号 .StartChargeSeq(dto.getStartChargeSeq()) // 订单号
.StartChargeSeqStat(Integer.parseInt(orderStatus)) // 订单状态 .StartChargeSeqStat(Integer.parseInt(orderStatus)) // 订单状态
.ConnectorID(orderInfo.getPileConnectorCode()) // 枪口编码 .ConnectorID(orderInfo.getPileConnectorCode()) // 枪口编码
.ConnectorStatus(Integer.parseInt(data.getConnectorStatus())) // 枪口状态 .ConnectorStatus(Integer.parseInt(data.getConnectorStatus())) // 枪口状态
@@ -656,7 +660,19 @@ public class LianLianServiceImpl implements LianLianService {
.build(); .build();
return vo; // 加密
Map<String, String> resultMap = Maps.newLinkedHashMap();
// 加密数据
byte[] encryptText = Cryptos.aesEncrypt(JSONObject.toJSONString(vo).getBytes(),
configInfo.getOperatorSecret().getBytes(), configInfo.getDataSecretIv().getBytes());
String encryptData = Encodes.encodeBase64(encryptText);
resultMap.put("Data", encryptData);
// 生成sig
String resultSign = GBSignUtils.sign(resultMap, configInfo.getOperatorSecret());
resultMap.put("Sig", resultSign);
return resultMap;
} }
@@ -980,7 +996,7 @@ public class LianLianServiceImpl implements LianLianService {
* @return * @return
*/ */
@Override @Override
public String pushChargeStatus(String orderCode) { public String pushChargeStatus(String orderCode) throws UnsupportedEncodingException {
// 根据订单号查询订单信息 // 根据订单号查询订单信息
OrderBasicInfo orderInfo = orderBasicInfoService.getOrderInfoByOrderCode(orderCode); OrderBasicInfo orderInfo = orderBasicInfoService.getOrderInfoByOrderCode(orderCode);
// 通过站点id查询相关配置信息 // 通过站点id查询相关配置信息
@@ -996,7 +1012,16 @@ public class LianLianServiceImpl implements LianLianService {
String urlAddress = settingInfo.getUrlAddress(); String urlAddress = settingInfo.getUrlAddress();
// 调用 查询充电状态方法 // 调用 查询充电状态方法
QueryChargingStatusVO vo = query_equip_charge_status(orderCode); QueryEquipChargeStatusDTO dto = new QueryEquipChargeStatusDTO();
dto.setStartChargeSeq(orderCode);
Map<String, String> map = query_equip_charge_status(dto);
String data = map.get("Data");
// 解密data
byte[] plainText = Cryptos.aesDecrypt(Encodes.decodeBase64(data),
operatorSecret.getBytes(), operatorSecret.getBytes());
String dataStr = new String(plainText, "UTF-8");
// 转成对应的对象
QueryEquipChargeStatusDTO queryEquipChargeStatusDTO = JSONObject.parseObject(dataStr, QueryEquipChargeStatusDTO.class);
// 获取令牌 // 获取令牌
String token = getToken(urlAddress, operatorId, operatorSecret); String token = getToken(urlAddress, operatorId, operatorSecret);
if (StringUtils.isBlank(token)) { if (StringUtils.isBlank(token)) {
@@ -1004,7 +1029,7 @@ public class LianLianServiceImpl implements LianLianService {
} }
String url = urlAddress + "notification_equip_charge_status"; String url = urlAddress + "notification_equip_charge_status";
// 调用联联平台接口 // 调用联联平台接口
String jsonString = JSONObject.toJSONString(vo); String jsonString = JSONObject.toJSONString(queryEquipChargeStatusDTO);
String result = HttpRequestUtil.sendPost(token, jsonString, url, dataSecret, dataSecretIv, operatorId, signSecret); String result = HttpRequestUtil.sendPost(token, jsonString, url, dataSecret, dataSecretIv, operatorId, signSecret);