From ce8e087fedd5e6949ab98b0859b824236f042841 Mon Sep 17 00:00:00 2001
From: 1098226878@qq.com <1098226878@qq.com>
Date: 星期二, 28 十二月 2021 22:21:07 +0800
Subject: [PATCH] 优化代码
---
service-acct/src/main/java/com/java110/acct/cmd/payment/QrCodePaymentCmd.java | 54 +++++++++++++++++++++++++++++++++++++++++++++++-------
1 files changed, 47 insertions(+), 7 deletions(-)
diff --git a/service-acct/src/main/java/com/java110/acct/cmd/payment/QrCodePaymentCmd.java b/service-acct/src/main/java/com/java110/acct/cmd/payment/QrCodePaymentCmd.java
index 8cbc7cd..e9a2863 100644
--- a/service-acct/src/main/java/com/java110/acct/cmd/payment/QrCodePaymentCmd.java
+++ b/service-acct/src/main/java/com/java110/acct/cmd/payment/QrCodePaymentCmd.java
@@ -1,33 +1,73 @@
package com.java110.acct.cmd.payment;
import com.alibaba.fastjson.JSONObject;
-import com.alipay.api.AlipayApiException;
-import com.alipay.api.AlipayClient;
-import com.alipay.api.DefaultAlipayClient;
-import com.alipay.api.domain.AlipayTradeAppPayModel;
-import com.alipay.api.request.AlipayTradeAppPayRequest;
-import com.alipay.api.response.AlipayTradeAppPayResponse;
+import com.java110.acct.smo.IQrCodePaymentSMO;
import com.java110.core.annotation.Java110Cmd;
import com.java110.core.context.ICmdDataFlowContext;
import com.java110.core.event.cmd.AbstractServiceCmdListener;
import com.java110.core.event.cmd.CmdEvent;
+import com.java110.core.factory.CallApiServiceFactory;
+import com.java110.core.factory.GenerateCodeFactory;
+import com.java110.utils.constant.CommonConstant;
import com.java110.utils.exception.CmdException;
+import com.java110.utils.factory.ApplicationContextFactory;
+import com.java110.utils.util.Assert;
+import com.java110.utils.util.StringUtil;
+import com.java110.vo.ResultVo;
+import org.slf4j.Logger;
+import org.slf4j.LoggerFactory;
+import org.springframework.http.HttpStatus;
+import org.springframework.http.ResponseEntity;
/**
* 鎵爜浠�
*/
@Java110Cmd(serviceCode = "payment.qrCodePayment")
public class QrCodePaymentCmd extends AbstractServiceCmdListener {
+ private static Logger logger = LoggerFactory.getLogger(QrCodePaymentCmd.class);
+
+ private IQrCodePaymentSMO qrCodePaymentSMOImpl;
@Override
public void validate(CmdEvent event, ICmdDataFlowContext cmdDataFlowContext, JSONObject reqJson) {
-
+ Assert.hasKeyAndValue(reqJson, "authCode", "鏈寘鍚巿鏉冪爜");
}
@Override
public void doCmd(CmdEvent event, ICmdDataFlowContext cmdDataFlowContext, JSONObject reqJson) throws CmdException {
+ String orderId = GenerateCodeFactory.getGeneratorId(GenerateCodeFactory.CODE_PREFIX_orderId);
+ double receivedAmount = Double.parseDouble(reqJson.getString("receivedAmount"));
+ String authCode = reqJson.getString("authCode");
+ if (StringUtil.isEmpty(authCode) || authCode.length() < 2) {
+ throw new IllegalArgumentException("鎺堟潈鐮侀敊璇�");
+ }
+ int pre = Integer.parseInt(authCode.substring(0, 2));
+ if (pre > 24 && pre < 31) { // 鏀粯瀹�
+ qrCodePaymentSMOImpl = ApplicationContextFactory.getBean("qrCodeAliPaymentAdapt", IQrCodePaymentSMO.class);
+ } else {
+ qrCodePaymentSMOImpl = ApplicationContextFactory.getBean("qrCodeWechatPaymentAdapt", IQrCodePaymentSMO.class);
+ }
+
+ ResultVo resultVo = null;
+ try {
+ resultVo = qrCodePaymentSMOImpl.pay(reqJson.getString("communityId"), orderId, receivedAmount, authCode, "");
+ } catch (Exception e) {
+ logger.error("寮傚父浜�", e);
+ cmdDataFlowContext.setResponseEntity(ResultVo.error(e.getLocalizedMessage()));
+ return;
+ }
+ logger.debug("閫傞厤鍣ㄨ繑鍥炵粨鏋�:" + resultVo.toString());
+ if (ResultVo.CODE_OK != resultVo.getCode()) {
+ reqJson.put("orderId", orderId);
+ cmdDataFlowContext.setResponseEntity(ResultVo.error(resultVo.getMsg(), reqJson));
+ return;
+ }
+ String appId = cmdDataFlowContext.getReqHeaders().get(CommonConstant.APP_ID);
+ String userId = cmdDataFlowContext.getReqHeaders().get(CommonConstant.USER_ID);
+ JSONObject paramOut = CallApiServiceFactory.postForApi(appId, reqJson, "fee.payFee", JSONObject.class, userId);
+ cmdDataFlowContext.setResponseEntity(ResultVo.createResponseEntity(paramOut));
}
}
--
Gitblit v1.8.0