From 3e156b18eeeadd56de16b33940379cb1cd76e6fa Mon Sep 17 00:00:00 2001 From: YunaiV <> Date: Sun, 21 Apr 2019 20:34:26 +0800 Subject: [PATCH] =?UTF-8?q?=E5=90=8E=E7=AB=AF=EF=BC=9Apingxx=20=E5=9B=9E?= =?UTF-8?q?=E8=B0=83=E6=8E=A5=E5=8F=A3=EF=BC=8C=E5=A2=9E=E5=8A=A0=E9=94=99?= =?UTF-8?q?=E8=AF=AF=E6=97=A5=E5=BF=97?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- .../controller/users/PayTransactionController.java | 1 + .../cn/iocoder/mall/pay/biz/service/PayServiceImpl.java | 6 +++++- 2 files changed, 6 insertions(+), 1 deletion(-) diff --git a/pay/pay-application/src/main/java/cn/iocoder/mall/pay/application/controller/users/PayTransactionController.java b/pay/pay-application/src/main/java/cn/iocoder/mall/pay/application/controller/users/PayTransactionController.java index 1bfcb1043..15e247792 100644 --- a/pay/pay-application/src/main/java/cn/iocoder/mall/pay/application/controller/users/PayTransactionController.java +++ b/pay/pay-application/src/main/java/cn/iocoder/mall/pay/application/controller/users/PayTransactionController.java @@ -49,6 +49,7 @@ public class PayTransactionController { @PostMapping(value = "pingxx_pay_success", consumes = MediaType.APPLICATION_JSON_VALUE) // @GetMapping(value = "pingxx_pay_success") public String pingxxSuccess(HttpServletRequest request) throws IOException { + logger.info("[pingxxSuccess][被回调]"); // 读取 webhook StringBuilder sb = new StringBuilder(); try (BufferedReader reader = request.getReader()) { diff --git a/pay/pay-service-impl/src/main/java/cn/iocoder/mall/pay/biz/service/PayServiceImpl.java b/pay/pay-service-impl/src/main/java/cn/iocoder/mall/pay/biz/service/PayServiceImpl.java index 78b342d91..61a09c02d 100644 --- a/pay/pay-service-impl/src/main/java/cn/iocoder/mall/pay/biz/service/PayServiceImpl.java +++ b/pay/pay-service-impl/src/main/java/cn/iocoder/mall/pay/biz/service/PayServiceImpl.java @@ -154,7 +154,8 @@ public class PayServiceImpl implements PayTransactionService { if (updateCounts == 0) { // 校验状态,必须是待支付 throw ServiceExceptionUtil.exception(PayErrorCodeEnum.PAY_TRANSACTION_EXTENSION_STATUS_IS_NOT_WAITING.getCode()); } - // 2.1 + logger.info("[updateTransactionPaySuccess][PayTransactionExtensionDO({}) 更新为已支付]", payTransactionExtension.getId()); + // 2.1 判断 PayTransactionDO 是否处于待支付 PayTransactionDO payTransactionDO = payTransactionMapper.selectById(payTransactionExtension.getTransactionId()); if (payTransactionDO == null) { return ServiceExceptionUtil.error(PayErrorCodeEnum.PAY_TRANSACTION_NOT_FOUND.getCode()); @@ -175,6 +176,7 @@ public class PayServiceImpl implements PayTransactionService { if (updateCounts == 0) { // 校验状态,必须是待支付 TODO 这种类型,需要思考下。需要返回错误,但是又要保证事务回滚 throw ServiceExceptionUtil.exception(PayErrorCodeEnum.PAY_TRANSACTION_STATUS_IS_NOT_WAITING.getCode()); } + logger.info("[updateTransactionPaySuccess][PayTransactionDO({}) 更新为已支付]", payTransactionDO.getId()); // 3.1 插入 PayTransactionNotifyTaskDO payTransactionNotifyTask = new PayTransactionNotifyTaskDO() .setTransactionId(payTransactionExtension.getTransactionId()).setTransactionExtensionId(payTransactionExtension.getId()) @@ -184,9 +186,11 @@ public class PayServiceImpl implements PayTransactionService { .setNextNotifyTime(DateUtil.addDate(Calendar.SECOND, PayTransactionNotifyTaskDO.NOTIFY_FREQUENCY[0])) .setNotifyUrl(payTransactionDO.getNotifyUrl()); payTransactionNotifyTaskMapper.insert(payTransactionNotifyTask); + logger.info("[updateTransactionPaySuccess][PayTransactionNotifyTaskDO({}) 新增一个任务]", payTransactionNotifyTask.getId()); // 3.2 发送 MQ rocketMQTemplate.convertAndSend(MQConstant.TOPIC_PAY_TRANSACTION_PAY_SUCCESS, PayTransactionConvert.INSTANCE.convert(payTransactionNotifyTask)); + logger.info("[updateTransactionPaySuccess][PayTransactionNotifyTaskDO({}) 发送 MQ 任务]", payTransactionNotifyTask.getId()); // 返回结果 return CommonResult.success(true); }