From c10d6358b9f014375a13821465bc978d0c0da22e Mon Sep 17 00:00:00 2001
From: linwe <872216996@qq.com>
Date: Wed, 29 May 2024 17:17:08 +0800
Subject: [PATCH] 通过E呼即办数据统计

---
 src/main/java/org/springblade/modules/pay/service/impl/WxPayServiceImpl.java |   27 ++++++++++++++++++---------
 1 files changed, 18 insertions(+), 9 deletions(-)

diff --git a/src/main/java/org/springblade/modules/pay/service/impl/WxPayServiceImpl.java b/src/main/java/org/springblade/modules/pay/service/impl/WxPayServiceImpl.java
index 2d1ed80..925189e 100644
--- a/src/main/java/org/springblade/modules/pay/service/impl/WxPayServiceImpl.java
+++ b/src/main/java/org/springblade/modules/pay/service/impl/WxPayServiceImpl.java
@@ -20,6 +20,7 @@
 import org.springblade.common.enums.wxpay.WxNotifyType;
 import org.springblade.common.enums.wxpay.WxRefundStatus;
 import org.springblade.common.enums.wxpay.WxTradeState;
+import org.springblade.common.exception.CustomException;
 import org.springblade.common.utils.HttpUtils;
 import org.springblade.common.utils.SpringUtils;
 import org.springblade.common.utils.WechatPay2ValidatorForRequest;
@@ -57,8 +58,8 @@
 	@Resource
 	private WxPayConfig wxPayConfig;
 
-	@Resource
-	private CloseableHttpClient wxPayClient;
+//	@Resource
+//	private CloseableHttpClient wxPayClient;
 
 	@Resource
 	private IOrderInfoService orderInfoService;
@@ -145,7 +146,7 @@
 		httpGet.setHeader("Accept", "application/json");
 
 		//完成签名并执行请求
-		CloseableHttpResponse response = wxPayClient.execute(httpGet);
+		CloseableHttpResponse response = null;//wxPayClient.execute(httpGet);
 
 		try {
 			String bodyAsString = EntityUtils.toString(response.getEntity());//响应体
@@ -257,7 +258,7 @@
 		httpPost.setHeader("Accept", "application/json");//设置响应报文格式
 
 		//完成签名并执行请求,并完成验签
-		CloseableHttpResponse response = wxPayClient.execute(httpPost);
+		CloseableHttpResponse response =null;// wxPayClient.execute(httpPost);
 
 		try {
 
@@ -303,7 +304,7 @@
 		httpGet.setHeader("Accept", "application/json");
 
 		//完成签名并执行请求
-		CloseableHttpResponse response = wxPayClient.execute(httpGet);
+		CloseableHttpResponse response = null;//wxPayClient.execute(httpGet);
 
 		try {
 			String bodyAsString = EntityUtils.toString(response.getEntity());
@@ -410,13 +411,13 @@
 
 
 	@Override
-	public Map<String, String> jsapiPay(Long properChargeRecordId) throws Exception {
+	public Map<String, String> jsapiPay(Long properChargeRecordId) throws IOException {
 
 		String prepayId = "";
 		//生成订单
 		OrderInfoEntity orderInfo = orderInfoService.getOne(Wrappers.<OrderInfoEntity>lambdaQuery().eq(OrderInfoEntity::getProperChargeRecordId, properChargeRecordId));
 		if (orderInfo.getTotalFee() <= 0) {
-			throw new Exception("支付金额不能低于等于0元");
+			throw new CustomException("支付金额不能低于等于0元");
 		}
 		IUserService userService = SpringUtils.getBean(IUserService.class);
 		User serviceOne = userService.getOne(Wrappers.<User>lambdaQuery().eq(User::getId, AuthUtil.getUserId()));
@@ -460,7 +461,7 @@
 		httpPost.setHeader("Accept", "application/json");
 
 		//完成签名并执行请求
-		CloseableHttpResponse response = wxPayClient.execute(httpPost);
+		CloseableHttpResponse response = null;//wxPayClient.execute(httpPost);
 
 		try {
 			String bodyAsString = EntityUtils.toString(response.getEntity());//响应体
@@ -493,6 +494,14 @@
 			payMap.put("paySign", paySign);
 			logger.info("返回参数 ===> {}" + gson.toJson(payMap));
 			return payMap;
+		} catch (IOException e) {
+			throw new RuntimeException(e);
+		} catch (SignatureException e) {
+			throw new RuntimeException(e);
+		} catch (NoSuchAlgorithmException e) {
+			throw new RuntimeException(e);
+		} catch (InvalidKeyException e) {
+			throw new RuntimeException(e);
 		} finally {
 			response.close();
 		}
@@ -582,7 +591,7 @@
 		httpPost.setHeader("Accept", "application/json");
 
 		//完成签名并执行请求
-		CloseableHttpResponse response = wxPayClient.execute(httpPost);
+		CloseableHttpResponse response = null;//wxPayClient.execute(httpPost);
 
 		try {
 			int statusCode = response.getStatusLine().getStatusCode();//响应状态码

--
Gitblit v1.9.3