update 涌城泊车平台Controller

This commit is contained in:
Lemon
2025-02-25 10:57:22 +08:00
parent 832304a52d
commit 382622e187

View File

@@ -4,6 +4,7 @@ import com.alibaba.fastjson2.JSON;
import com.alibaba.fastjson2.JSONObject; import com.alibaba.fastjson2.JSONObject;
import com.jsowell.common.annotation.Anonymous; import com.jsowell.common.annotation.Anonymous;
import com.jsowell.common.core.controller.BaseController; import com.jsowell.common.core.controller.BaseController;
import com.jsowell.common.enums.thirdparty.ThirdPartyReturnCodeEnum;
import com.jsowell.common.enums.thirdparty.ThirdPlatformTypeEnum; import com.jsowell.common.enums.thirdparty.ThirdPlatformTypeEnum;
import com.jsowell.common.enums.ykc.ReturnCodeEnum; import com.jsowell.common.enums.ykc.ReturnCodeEnum;
import com.jsowell.common.exception.BusinessException; import com.jsowell.common.exception.BusinessException;
@@ -14,11 +15,13 @@ import com.jsowell.pile.dto.*;
import com.jsowell.thirdparty.lianlian.common.CommonResult; import com.jsowell.thirdparty.lianlian.common.CommonResult;
import com.jsowell.pile.thirdparty.CommonParamsDTO; import com.jsowell.pile.thirdparty.CommonParamsDTO;
import com.jsowell.thirdparty.lianlian.service.LianLianService; import com.jsowell.thirdparty.lianlian.service.LianLianService;
import com.jsowell.thirdparty.platform.service.ThirdPartyPlatformService;
import com.jsowell.thirdparty.platform.util.Cryptos; import com.jsowell.thirdparty.platform.util.Cryptos;
import com.jsowell.thirdparty.platform.util.Encodes; import com.jsowell.thirdparty.platform.util.Encodes;
import com.jsowell.thirdparty.yongchengboche.dto.YCBCGetTokenDTO; import com.jsowell.thirdparty.yongchengboche.dto.YCBCGetTokenDTO;
import com.jsowell.thirdparty.yongchengboche.service.YCBCService; import com.jsowell.thirdparty.yongchengboche.service.YCBCService;
import org.springframework.beans.factory.annotation.Autowired; import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.beans.factory.annotation.Qualifier;
import org.springframework.web.bind.annotation.*; import org.springframework.web.bind.annotation.*;
import javax.servlet.http.HttpServletRequest; import javax.servlet.http.HttpServletRequest;
@@ -35,7 +38,15 @@ import java.util.Map;
@Anonymous @Anonymous
@RestController @RestController
@RequestMapping("/ycbc") @RequestMapping("/ycbc")
public class YCBCController extends BaseController { public class YCBCController extends ThirdPartyBaseController {
private final String platformName = "甬城泊车平台";
private final String platformType = ThirdPlatformTypeEnum.YONG_CHENG_BO_CHE.getTypeCode();
@Autowired
@Qualifier("yongChengbochePlatfromServiceImpl")
private ThirdPartyPlatformService platformLogic;
@Autowired @Autowired
private YCBCService ycbcService; private YCBCService ycbcService;
@@ -49,13 +60,13 @@ public class YCBCController extends BaseController {
*/ */
@PostMapping("/v1/query_token") @PostMapping("/v1/query_token")
public CommonResult<?> queryToken(@RequestBody CommonParamsDTO dto) { public CommonResult<?> queryToken(@RequestBody CommonParamsDTO dto) {
logger.info("甬城泊车平台请求令牌 params:{}", JSON.toJSONString(dto)); // logger.info("{}-请求令牌 params:{}", platformName, JSON.toJSONString(dto));
try { try {
Map<String, String> map = ycbcService.generateToken(dto); Map<String, String> map = platformLogic.queryToken(dto);
logger.info("甬城泊车平台请求令牌 result:{}", JSON.toJSONString(map)); logger.info("{}-请求令牌, params:{}, result:{}", platformName, JSON.toJSONString(dto), JSON.toJSONString(map));
return CommonResult.success(0, "请求令牌成功!", map.get("Data"), map.get("Sig")); return CommonResult.success(Integer.parseInt(map.get("Ret")), map.get("Msg"), map.get("Data"), map.get("Sig"));
} catch (UnsupportedEncodingException e) { } catch (Exception e) {
logger.error("甬城泊车平台 请求令牌接口 异常"); logger.error("{}-获取token接口, 异常, params:{}", platformName, JSON.toJSONString(dto), e);
return CommonResult.failed("获取token发生异常"); return CommonResult.failed("获取token发生异常");
} }
} }
@@ -64,19 +75,19 @@ public class YCBCController extends BaseController {
* 获取token接口 * 获取token接口
* http://localhost:8080/ycbc/v1/query_token * http://localhost:8080/ycbc/v1/query_token
*/ */
@PostMapping("/v1/ycbcQuery_token") // @PostMapping("/v1/ycbcQuery_token")
public String ycbcQueryToken(@RequestBody YCBCGetTokenDTO dto) { // public String ycbcQueryToken(@RequestBody YCBCGetTokenDTO dto) {
logger.info("请求甬城泊车平台令牌 params:{}", JSON.toJSONString(dto)); // logger.info("请求甬城泊车平台令牌 params:{}", JSON.toJSONString(dto));
String token = ""; // String token = "";
try { // try {
token = ycbcService.YCBCGetToken(dto); // token = ycbcService.YCBCGetToken(dto);
logger.info("请求甬城泊车平台令牌 result:{}", token); // logger.info("请求甬城泊车平台令牌 result:{}", token);
} catch (Exception e) { // } catch (Exception e) {
logger.error("请求甬城泊车平台令牌接口 异常"); // logger.error("请求甬城泊车平台令牌接口 异常");
return ""; // return "";
} // }
return token; // return token;
} // }
/** /**
@@ -87,37 +98,29 @@ public class YCBCController extends BaseController {
*/ */
@PostMapping("/v1/query_stations_info") @PostMapping("/v1/query_stations_info")
public CommonResult<?> query_stations_info(HttpServletRequest request, @RequestBody CommonParamsDTO dto) { public CommonResult<?> query_stations_info(HttpServletRequest request, @RequestBody CommonParamsDTO dto) {
logger.info("甬城泊车平台查询充电站信息 params:{}", JSON.toJSONString(dto)); logger.info("{}-查询充电站信息 params:{}", platformName, JSON.toJSONString(dto));
try { try {
// 校验令牌 // 校验令牌
String token = request.getHeader("Authorization"); if (!verifyToken(request.getHeader("Authorization"))) {
if (!JWTUtils.checkThirdPartyToken(token)) {
// 校验失败 // 校验失败
return CommonResult.failed("令牌校验错误"); return CommonResult.failed(ThirdPartyReturnCodeEnum.TOKEN_ERROR);
} }
// 校验签名
Map<String, String> resultMap = lianLianService.checkoutSign(dto);
if (resultMap == null) {
// 签名错误
return CommonResult.failed("签名校验错误");
}
String operatorSecret = resultMap.get("OperatorSecret");
String dataString = resultMap.get("Data");
String dataSecret = resultMap.get("DataSecret");
String dataSecretIV = resultMap.get("DataSecretIV");
// 解密data // 校验签名
byte[] plainText = Cryptos.aesDecrypt(Encodes.decodeBase64(dataString), dataSecret.getBytes(), dataSecretIV.getBytes()); if (!verifySignature(dto)) {
String dataStr = new String(plainText, StandardCharsets.UTF_8); // 签名错误
// 转换成相应对象 return CommonResult.failed(ThirdPartyReturnCodeEnum.SIGN_ERROR);
QueryStationInfoDTO queryStationInfoDTO = JSONObject.parseObject(dataStr, QueryStationInfoDTO.class); }
queryStationInfoDTO.setOperatorId(dto.getOperatorID());
Map<String, String> map = ycbcService.queryStationsInfo(queryStationInfoDTO); // 解析入参
logger.info("甬城泊车平台查询充电站信息 result:{}", JSON.toJSONString(map)); QueryStationInfoDTO queryStationInfoDTO = parseParamsDTO(dto, QueryStationInfoDTO.class);
return CommonResult.success(0, "查询充电站信息成功!", map.get("Data"), map.get("Sig"));
// 执行逻辑
Map<String, String> map = platformLogic.queryStationsInfo(queryStationInfoDTO);
return CommonResult.success(Integer.parseInt(map.get("Ret")), map.get("Msg"), map.get("Data"), map.get("Sig"));
} catch (Exception e) { } catch (Exception e) {
logger.info("甬城泊车平台查询充电站信息 error:", e); logger.info("{}-查询充电站信息 error:", platformName, e);
e.printStackTrace();
} }
return CommonResult.failed("查询充电站信息发生异常"); return CommonResult.failed("查询充电站信息发生异常");
} }
@@ -131,36 +134,29 @@ public class YCBCController extends BaseController {
*/ */
@PostMapping("/v1/query_station_status") @PostMapping("/v1/query_station_status")
public CommonResult<?> query_station_status(HttpServletRequest request, @RequestBody CommonParamsDTO dto) { public CommonResult<?> query_station_status(HttpServletRequest request, @RequestBody CommonParamsDTO dto) {
logger.info("甬城泊车平台查询充电站状态信息 params:{}", JSON.toJSONString(dto)); logger.info("{}-查询充电站状态信息 params:{}", platformName, JSON.toJSONString(dto));
try { try {
// 校验令牌 // 校验令牌
String token = request.getHeader("Authorization"); if (!verifyToken(request.getHeader("Authorization"))) {
if (!JWTUtils.checkThirdPartyToken(token)) {
// 校验失败 // 校验失败
return CommonResult.failed("令牌校验错误"); return CommonResult.failed(ThirdPartyReturnCodeEnum.TOKEN_ERROR);
} }
// 校验签名 // 校验签名
Map<String, String> resultMap = lianLianService.checkoutSign(dto); if (!verifySignature(dto)) {
if (resultMap == null) {
// 签名错误 // 签名错误
return CommonResult.failed("签名校验错误"); return CommonResult.failed(ThirdPartyReturnCodeEnum.SIGN_ERROR);
} }
String operatorSecret = resultMap.get("OperatorSecret");
String dataString = resultMap.get("Data"); // 解析入参
String dataSecret = resultMap.get("DataSecret"); QueryStationInfoDTO queryStationInfoDTO = parseParamsDTO(dto, QueryStationInfoDTO.class);
String dataSecretIV = resultMap.get("DataSecretIV");
// 解密data // 执行逻辑
byte[] plainText = Cryptos.aesDecrypt(Encodes.decodeBase64(dataString), dataSecret.getBytes(), dataSecretIV.getBytes()); Map<String, String> map = platformLogic.queryStationStatus(queryStationInfoDTO);
String dataStr = new String(plainText, StandardCharsets.UTF_8);
// 转换成相应对象 return CommonResult.success(Integer.parseInt(map.get("Ret")), map.get("Msg"), map.get("Data"), map.get("Sig"));
QueryStationInfoDTO queryStationInfoDTO = JSONObject.parseObject(dataStr, QueryStationInfoDTO.class);
queryStationInfoDTO.setOperatorId(dto.getOperatorID());
Map<String, String> map = ycbcService.queryStationStatus(queryStationInfoDTO);
logger.info("甬城泊车平台查询充电站状态信息 result:{}", JSON.toJSONString(map));
return CommonResult.success(0, "查询充电站状态信息成功!", map.get("Data"), map.get("Sig"));
} catch (Exception e) { } catch (Exception e) {
logger.info("甬城泊车平台查询充电站状态信息 error:", e); logger.error("{}-查询充电站状态信息 error:", platformName, e);
e.printStackTrace();
} }
return CommonResult.failed("查询充电站状态信息发生异常"); return CommonResult.failed("查询充电站状态信息发生异常");
} }
@@ -172,31 +168,31 @@ public class YCBCController extends BaseController {
* @param dto * @param dto
* @return * @return
*/ */
@PostMapping("/pushStationStatus") // @PostMapping("/pushStationStatus")
public RestApiResponse<?> pushStationStatus(@RequestBody PushInfoParamDTO dto) { // public RestApiResponse<?> pushStationStatus(@RequestBody PushInfoParamDTO dto) {
logger.info("甬城泊车平台设备状态变化推送 params:{}", JSON.toJSONString(dto)); // logger.info("甬城泊车平台设备状态变化推送 params:{}", JSON.toJSONString(dto));
RestApiResponse<?> response = null; // RestApiResponse<?> response = null;
try { // try {
if (StringUtils.isBlank(String.valueOf(dto.getPileConnectorCode())) || // if (StringUtils.isBlank(String.valueOf(dto.getPileConnectorCode())) ||
StringUtils.isBlank(String.valueOf(dto.getStatus()))) { // StringUtils.isBlank(String.valueOf(dto.getStatus()))) {
throw new BusinessException(ReturnCodeEnum.CODE_PARAM_NOT_NULL_ERROR); // throw new BusinessException(ReturnCodeEnum.CODE_PARAM_NOT_NULL_ERROR);
} // }
PushRealTimeInfoDTO pushRealTimeInfoDTO = new PushRealTimeInfoDTO(); // PushRealTimeInfoDTO pushRealTimeInfoDTO = new PushRealTimeInfoDTO();
pushRealTimeInfoDTO.setStatus(dto.getStatus()); // pushRealTimeInfoDTO.setStatus(dto.getStatus());
pushRealTimeInfoDTO.setPileConnectorCode(dto.getPileConnectorCode()); // pushRealTimeInfoDTO.setPileConnectorCode(dto.getPileConnectorCode());
pushRealTimeInfoDTO.setThirdPartyType(ThirdPlatformTypeEnum.YONG_CHENG_BO_CHE.getTypeCode()); // pushRealTimeInfoDTO.setThirdPartyType(ThirdPlatformTypeEnum.YONG_CHENG_BO_CHE.getTypeCode());
String result = ycbcService.notificationStationStatus(pushRealTimeInfoDTO); // String result = ycbcService.notificationStationStatus(pushRealTimeInfoDTO);
response = new RestApiResponse<>(result); // response = new RestApiResponse<>(result);
}catch (BusinessException e) { // }catch (BusinessException e) {
logger.error("甬城泊车平台设备状态变化推送 error",e); // logger.error("甬城泊车平台设备状态变化推送 error",e);
response = new RestApiResponse<>(e.getCode(), e.getMessage()); // response = new RestApiResponse<>(e.getCode(), e.getMessage());
}catch (Exception e) { // }catch (Exception e) {
logger.error("甬城泊车平台设备状态变化推送 error", e); // logger.error("甬城泊车平台设备状态变化推送 error", e);
response = new RestApiResponse<>(e); // response = new RestApiResponse<>(e);
} // }
logger.info("甬城泊车平台设备状态变化推送 result:{}", response); // logger.info("甬城泊车平台设备状态变化推送 result:{}", response);
return response; // return response;
} // }
/** /**
* 甬城泊车推送启动充电结果 * 甬城泊车推送启动充电结果
@@ -204,23 +200,23 @@ public class YCBCController extends BaseController {
* @param orderCode * @param orderCode
* @return * @return
*/ */
@GetMapping("/pushStartChargeResult/{orderCode}") // @GetMapping("/pushStartChargeResult/{orderCode}")
public RestApiResponse<?> pushStartChargeResult(@PathVariable("orderCode") String orderCode) { // public RestApiResponse<?> pushStartChargeResult(@PathVariable("orderCode") String orderCode) {
logger.info("甬城泊车平台推送启动充电结果 params:{}", orderCode); // logger.info("甬城泊车平台推送启动充电结果 params:{}", orderCode);
RestApiResponse<?> response = null; // RestApiResponse<?> response = null;
try { // try {
String result = ycbcService.pushStartChargeResult(orderCode); // String result = ycbcService.pushStartChargeResult(orderCode);
response = new RestApiResponse<>(result); // response = new RestApiResponse<>(result);
}catch (BusinessException e) { // }catch (BusinessException e) {
logger.error("甬城泊车平台推送启动充电结果 error",e); // logger.error("甬城泊车平台推送启动充电结果 error",e);
response = new RestApiResponse<>(e.getCode(), e.getMessage()); // response = new RestApiResponse<>(e.getCode(), e.getMessage());
}catch (Exception e) { // }catch (Exception e) {
logger.error("甬城泊车平台推送启动充电结果 error", e); // logger.error("甬城泊车平台推送启动充电结果 error", e);
response = new RestApiResponse<>(e); // response = new RestApiResponse<>(e);
} // }
logger.info("甬城泊车平台推送启动充电结果 result:{}", response); // logger.info("甬城泊车平台推送启动充电结果 result:{}", response);
return response; // return response;
} // }
/** /**
* 请求设备认证 * 请求设备认证
@@ -230,36 +226,30 @@ public class YCBCController extends BaseController {
*/ */
@PostMapping("/v1/query_equip_auth") @PostMapping("/v1/query_equip_auth")
public CommonResult<?> query_equip_auth(HttpServletRequest request, @RequestBody CommonParamsDTO dto) { public CommonResult<?> query_equip_auth(HttpServletRequest request, @RequestBody CommonParamsDTO dto) {
logger.info("甬城泊车平台请求设备认证 param:{}", JSON.toJSONString(dto)); logger.info("{}-请求设备认证 params:{}", platformName, JSON.toJSONString(dto));
try { try {
// 校验令牌 // 校验令牌
String token = request.getHeader("Authorization"); if (!verifyToken(request.getHeader("Authorization"))) {
if (!JWTUtils.checkThirdPartyToken(token)) {
// 校验失败 // 校验失败
return CommonResult.failed("令牌校验错误"); return CommonResult.failed(ThirdPartyReturnCodeEnum.TOKEN_ERROR);
} }
dto.setPlatformType(platformType);
// 校验签名 // 校验签名
Map<String, String> resultMap = lianLianService.checkoutSign(dto); if (!verifySignature(dto)) {
if (resultMap == null) {
// 签名错误 // 签名错误
return CommonResult.failed("签名校验错误"); return CommonResult.failed(ThirdPartyReturnCodeEnum.SIGN_ERROR);
} }
String operatorSecret = resultMap.get("OperatorSecret");
String dataString = resultMap.get("Data"); // 解析入参
String dataSecret = resultMap.get("DataSecret"); QueryEquipmentDTO queryEquipmentDTO = parseParamsDTO(dto, QueryEquipmentDTO.class);
String dataSecretIV = resultMap.get("DataSecretIV");
// 解密data // 执行逻辑
byte[] plainText = Cryptos.aesDecrypt(Encodes.decodeBase64(dataString), dataSecret.getBytes(), dataSecretIV.getBytes()); Map<String, String> map = platformLogic.queryEquipAuth(queryEquipmentDTO);
String dataStr = new String(plainText, StandardCharsets.UTF_8);
// 转换成相应对象 return CommonResult.success(Integer.parseInt(map.get("Ret")), map.get("Msg"), map.get("Data"), map.get("Sig"));
QueryEquipmentDTO queryEquipmentDTO = JSONObject.parseObject(dataStr, QueryEquipmentDTO.class);
queryEquipmentDTO.setOperatorID(dto.getOperatorID());
Map<String, String> map = ycbcService.queryEquipAuth(queryEquipmentDTO);
logger.info("甬城泊车平台请求设备认证 result:{}", JSON.toJSONString(map));
return CommonResult.success(0, "请求设备认证成功!", map.get("Data"), map.get("Sig"));
} catch (Exception e) { } catch (Exception e) {
logger.info("甬城泊车平台请求设备认证 error:", e); logger.error("{}-请求设备认证 error:", platformName, e);
e.printStackTrace();
} }
return CommonResult.failed("请求设备认证发生异常"); return CommonResult.failed("请求设备认证发生异常");
} }
@@ -272,35 +262,30 @@ public class YCBCController extends BaseController {
*/ */
@PostMapping("/v1/query_start_charge") @PostMapping("/v1/query_start_charge")
public CommonResult<?> query_start_charge(HttpServletRequest request, @RequestBody CommonParamsDTO dto) { public CommonResult<?> query_start_charge(HttpServletRequest request, @RequestBody CommonParamsDTO dto) {
logger.info("甬城泊车平台请求启动充电 params :{}", JSON.toJSONString(dto)); logger.info("{}-请求启动充电 params:{}", platformName, JSON.toJSONString(dto));
try { try {
// 校验令牌 // 校验令牌
String token = request.getHeader("Authorization"); if (!verifyToken(request.getHeader("Authorization"))) {
if (!JWTUtils.checkThirdPartyToken(token)) {
// 校验失败 // 校验失败
return CommonResult.failed("令牌校验错误"); return CommonResult.failed(ThirdPartyReturnCodeEnum.TOKEN_ERROR);
} }
dto.setPlatformType(platformType);
// 校验签名 // 校验签名
Map<String, String> resultMap = lianLianService.checkoutSign(dto); if (!verifySignature(dto)) {
if (resultMap == null) {
// 签名错误 // 签名错误
return CommonResult.failed("签名校验错误"); return CommonResult.failed(ThirdPartyReturnCodeEnum.SIGN_ERROR);
} }
String operatorSecret = resultMap.get("OperatorSecret");
String dataString = resultMap.get("Data"); // 解析入参
String dataSecret = resultMap.get("DataSecret"); QueryStartChargeDTO queryStartChargeDTO = parseParamsDTO(dto, QueryStartChargeDTO.class);
String dataSecretIV = resultMap.get("DataSecretIV");
// 解密data // 执行逻辑
byte[] plainText = Cryptos.aesDecrypt(Encodes.decodeBase64(dataString), dataSecret.getBytes(), dataSecretIV.getBytes()); Map<String, String> map = platformLogic.queryStartCharge(queryStartChargeDTO);
String dataStr = new String(plainText, StandardCharsets.UTF_8);
// 转换成相应对象 return CommonResult.success(Integer.parseInt(map.get("Ret")), map.get("Msg"), map.get("Data"), map.get("Sig"));
QueryStartChargeDTO queryStartChargeDTO = JSONObject.parseObject(dataStr, QueryStartChargeDTO.class);
queryStartChargeDTO.setOperatorId(dto.getOperatorID());
Map<String, String> map = ycbcService.queryStartCharge(queryStartChargeDTO);
logger.info("甬城泊车平台请求启动充电 result:{}", JSON.toJSONString(map));
return CommonResult.success(0, "请求启动充电成功!", map.get("Data"), map.get("Sig"));
} catch (Exception e) { } catch (Exception e) {
logger.error("甬城泊车平台请求启动充电 error", e); logger.error("{}-请求启动充电 error:", platformName, e);
} }
return CommonResult.failed("请求启动充电发生异常"); return CommonResult.failed("请求启动充电发生异常");
} }
@@ -313,37 +298,32 @@ public class YCBCController extends BaseController {
*/ */
@PostMapping("/v1/query_equip_charge_status") @PostMapping("/v1/query_equip_charge_status")
public CommonResult<?> query_equip_charge_status(HttpServletRequest request, @RequestBody CommonParamsDTO dto) { public CommonResult<?> query_equip_charge_status(HttpServletRequest request, @RequestBody CommonParamsDTO dto) {
logger.info("甬城泊车平台查询充电状态 params :{}", JSON.toJSONString(dto)); logger.info("{}-查询充电状态 params:{}", platformName, JSON.toJSONString(dto));
try { try {
// 校验令牌 // 校验令牌
String token = request.getHeader("Authorization"); if (!verifyToken(request.getHeader("Authorization"))) {
if (!JWTUtils.checkThirdPartyToken(token)) {
// 校验失败 // 校验失败
return CommonResult.failed("令牌校验错误"); return CommonResult.failed(ThirdPartyReturnCodeEnum.TOKEN_ERROR);
} }
dto.setPlatformType(platformType);
// 校验签名 // 校验签名
Map<String, String> resultMap = lianLianService.checkoutSign(dto); if (!verifySignature(dto)) {
if (resultMap == null) {
// 签名错误 // 签名错误
return CommonResult.failed("签名校验错误"); return CommonResult.failed(ThirdPartyReturnCodeEnum.SIGN_ERROR);
} }
String operatorSecret = resultMap.get("OperatorSecret");
String dataString = resultMap.get("Data"); // 解析入参
String dataSecret = resultMap.get("DataSecret"); QueryEquipChargeStatusDTO queryEquipChargeStatusDTO = parseParamsDTO(dto, QueryEquipChargeStatusDTO.class);
String dataSecretIV = resultMap.get("DataSecretIV");
// 解密data // 执行逻辑
byte[] plainText = Cryptos.aesDecrypt(Encodes.decodeBase64(dataString), dataSecret.getBytes(), dataSecretIV.getBytes()); Map<String, String> map = platformLogic.queryEquipChargeStatus(queryEquipChargeStatusDTO);
String dataStr = new String(plainText, StandardCharsets.UTF_8);
// 转换成相应对象 return CommonResult.success(Integer.parseInt(map.get("Ret")), map.get("Msg"), map.get("Data"), map.get("Sig"));
QueryEquipChargeStatusDTO queryEquipChargeStatusDTO = JSONObject.parseObject(dataStr, QueryEquipChargeStatusDTO.class);
queryEquipChargeStatusDTO.setOperatorID(dto.getOperatorID());
Map<String, String> map = ycbcService.queryEquipChargeStatus(queryEquipChargeStatusDTO);
logger.info("甬城泊车平台查询充电状态 result:{}", JSON.toJSONString(map));
return CommonResult.success(0, "查询充电状态成功!", map.get("Data"), map.get("Sig"));
} catch (Exception e) { } catch (Exception e) {
logger.error("甬城泊车平台查询充电状态 error", e); logger.error("{}-查询充电状态 error:", platformName, e);
} }
return CommonResult.failed("甬城泊车平台查询充电状态发生异常"); return CommonResult.failed("查询充电状态发生异常");
} }
/** /**
@@ -352,23 +332,23 @@ public class YCBCController extends BaseController {
* @param orderCode * @param orderCode
* @return * @return
*/ */
@GetMapping("/pushChargeStatus/{orderCode}") // @GetMapping("/pushChargeStatus/{orderCode}")
public RestApiResponse<?> pushChargeStatus(@PathVariable("orderCode") String orderCode) { // public RestApiResponse<?> pushChargeStatus(@PathVariable("orderCode") String orderCode) {
logger.info("甬城泊车平台推送充电状态 params:{}", orderCode); // logger.info("甬城泊车平台推送充电状态 params:{}", orderCode);
RestApiResponse<?> response = null; // RestApiResponse<?> response = null;
try { // try {
String result = ycbcService.pushChargeStatus(orderCode); // String result = ycbcService.pushChargeStatus(orderCode);
response = new RestApiResponse<>(result); // response = new RestApiResponse<>(result);
}catch (BusinessException e) { // }catch (BusinessException e) {
logger.error("甬城泊车平台推送充电状态 error",e); // logger.error("甬城泊车平台推送充电状态 error",e);
response = new RestApiResponse<>(e.getCode(), e.getMessage()); // response = new RestApiResponse<>(e.getCode(), e.getMessage());
}catch (Exception e) { // }catch (Exception e) {
logger.error("甬城泊车平台推送充电状态 error", e); // logger.error("甬城泊车平台推送充电状态 error", e);
response = new RestApiResponse<>(e); // response = new RestApiResponse<>(e);
} // }
logger.info("甬城泊车平台推送充电状态 result:{}", response); // logger.info("甬城泊车平台推送充电状态 result:{}", response);
return response; // return response;
} // }
/** /**
* 请求停止充电 * 请求停止充电
@@ -378,37 +358,32 @@ public class YCBCController extends BaseController {
*/ */
@PostMapping("/v1/query_stop_charge") @PostMapping("/v1/query_stop_charge")
public CommonResult<?> query_stop_charge(HttpServletRequest request, @RequestBody CommonParamsDTO dto) { public CommonResult<?> query_stop_charge(HttpServletRequest request, @RequestBody CommonParamsDTO dto) {
logger.info("甬城泊车平台请求停止充电 params :{}", JSON.toJSONString(dto)); logger.info("{}-请求停止充电 params:{}", platformName, JSON.toJSONString(dto));
try { try {
// 校验令牌 // 校验令牌
String token = request.getHeader("Authorization"); if (!verifyToken(request.getHeader("Authorization"))) {
if (!JWTUtils.checkThirdPartyToken(token)) {
// 校验失败 // 校验失败
return CommonResult.failed("令牌校验错误"); return CommonResult.failed(ThirdPartyReturnCodeEnum.TOKEN_ERROR);
} }
dto.setPlatformType(platformType);
// 校验签名 // 校验签名
Map<String, String> resultMap = lianLianService.checkoutSign(dto); if (!verifySignature(dto)) {
if (resultMap == null) {
// 签名错误 // 签名错误
return CommonResult.failed("签名校验错误"); return CommonResult.failed(ThirdPartyReturnCodeEnum.SIGN_ERROR);
} }
String operatorSecret = resultMap.get("OperatorSecret");
String dataString = resultMap.get("Data"); // 解析入参
String dataSecret = resultMap.get("DataSecret"); QueryStartChargeDTO queryStartChargeDTO = parseParamsDTO(dto, QueryStartChargeDTO.class);
String dataSecretIV = resultMap.get("DataSecretIV");
// 解密data // 执行逻辑
byte[] plainText = Cryptos.aesDecrypt(Encodes.decodeBase64(dataString), dataSecret.getBytes(), dataSecretIV.getBytes()); Map<String, String> map = platformLogic.queryStopCharge(queryStartChargeDTO);
String dataStr = new String(plainText, StandardCharsets.UTF_8);
// 转换成相应对象 return CommonResult.success(Integer.parseInt(map.get("Ret")), map.get("Msg"), map.get("Data"), map.get("Sig"));
QueryStartChargeDTO queryStartChargeDTO = JSONObject.parseObject(dataStr, QueryStartChargeDTO.class);
queryStartChargeDTO.setOperatorId(dto.getOperatorID());
Map<String, String> map = ycbcService.queryStopCharge(queryStartChargeDTO);
logger.info("甬城泊车平台请求停止充电 result:{}", JSON.toJSONString(map));
return CommonResult.success(0, "请求停止充电成功!", map.get("Data"), map.get("Sig"));
} catch (Exception e) { } catch (Exception e) {
logger.error("甬城泊车平台请求停止充电 error", e); logger.error("{}-请求停止充电 error:", platformName, e);
} }
return CommonResult.failed("甬城泊车平台请求停止充电发生异常"); return CommonResult.failed("请求停止充电发生异常");
} }
/** /**
@@ -417,23 +392,23 @@ public class YCBCController extends BaseController {
* @param orderCode * @param orderCode
* @return * @return
*/ */
@GetMapping("/pushStopChargeResult/{orderCode}") // @GetMapping("/pushStopChargeResult/{orderCode}")
public RestApiResponse<?> pushStopChargeResult(@PathVariable("orderCode") String orderCode) { // public RestApiResponse<?> pushStopChargeResult(@PathVariable("orderCode") String orderCode) {
logger.info("甬城泊车平台推送停止充电结果 params:{}", orderCode); // logger.info("甬城泊车平台推送停止充电结果 params:{}", orderCode);
RestApiResponse<?> response = null; // RestApiResponse<?> response = null;
try { // try {
String result = ycbcService.pushStopChargeResult(orderCode); // String result = ycbcService.pushStopChargeResult(orderCode);
response = new RestApiResponse<>(result); // response = new RestApiResponse<>(result);
}catch (BusinessException e) { // }catch (BusinessException e) {
logger.error("甬城泊车平台推送停止充电结果 error",e); // logger.error("甬城泊车平台推送停止充电结果 error",e);
response = new RestApiResponse<>(e.getCode(), e.getMessage()); // response = new RestApiResponse<>(e.getCode(), e.getMessage());
}catch (Exception e) { // }catch (Exception e) {
logger.error("甬城泊车平台推送停止充电结果 error", e); // logger.error("甬城泊车平台推送停止充电结果 error", e);
response = new RestApiResponse<>(e); // response = new RestApiResponse<>(e);
} // }
logger.info("甬城泊车平台推送停止充电结果 result:{}", response); // logger.info("甬城泊车平台推送停止充电结果 result:{}", response);
return response; // return response;
} // }
/** /**
* 甬城泊车推送充电订单信息 * 甬城泊车推送充电订单信息
@@ -441,23 +416,23 @@ public class YCBCController extends BaseController {
* @param orderCode * @param orderCode
* @return * @return
*/ */
@GetMapping("/pushChargeOrderInfo/{orderCode}") // @GetMapping("/pushChargeOrderInfo/{orderCode}")
public RestApiResponse<?> pushChargeOrderInfo(@PathVariable("orderCode") String orderCode) { // public RestApiResponse<?> pushChargeOrderInfo(@PathVariable("orderCode") String orderCode) {
logger.info("甬城泊车平台推送充电订单信息 params:{}", orderCode); // logger.info("甬城泊车平台推送充电订单信息 params:{}", orderCode);
RestApiResponse<?> response = null; // RestApiResponse<?> response = null;
try { // try {
String result = ycbcService.pushChargeOrderInfo(orderCode); // String result = ycbcService.pushChargeOrderInfo(orderCode);
response = new RestApiResponse<>(result); // response = new RestApiResponse<>(result);
}catch (BusinessException e) { // }catch (BusinessException e) {
logger.error("甬城泊车平台推送充电订单信息 error",e); // logger.error("甬城泊车平台推送充电订单信息 error",e);
response = new RestApiResponse<>(e.getCode(), e.getMessage()); // response = new RestApiResponse<>(e.getCode(), e.getMessage());
}catch (Exception e) { // }catch (Exception e) {
logger.error("甬城泊车平台推送充电订单信息 error", e); // logger.error("甬城泊车平台推送充电订单信息 error", e);
response = new RestApiResponse<>(e); // response = new RestApiResponse<>(e);
} // }
logger.info("甬城泊车平台推送充电订单信息 result:{}", response); // logger.info("甬城泊车平台推送充电订单信息 result:{}", response);
return response; // return response;
} // }
} }