From b4dddeebc073ed81b001eda1c2a58cc1ef92d335 Mon Sep 17 00:00:00 2001
From: KKSU <15274802129@163.com>
Date: Thu, 23 Jan 2025 15:34:43 +0800
Subject: [PATCH] refactor(mall): 优化 WxxcxJob 类

---
 src/main/java/cc/mrbird/febs/mall/quartz/WxxcxJob.java |   74 +++++++++++++++++++-----------------
 1 files changed, 39 insertions(+), 35 deletions(-)

diff --git a/src/main/java/cc/mrbird/febs/mall/quartz/WxxcxJob.java b/src/main/java/cc/mrbird/febs/mall/quartz/WxxcxJob.java
index ccd49dd..54669cd 100644
--- a/src/main/java/cc/mrbird/febs/mall/quartz/WxxcxJob.java
+++ b/src/main/java/cc/mrbird/febs/mall/quartz/WxxcxJob.java
@@ -3,17 +3,22 @@
 import cc.mrbird.febs.common.utils.RedisUtils;
 import cc.mrbird.febs.mall.entity.MallMemberCoupon;
 import cc.mrbird.febs.mall.mapper.MallMemberCouponMapper;
-import cc.mrbird.febs.mall.service.MallInvoiceService;
+import cc.mrbird.febs.pay.util.WechatConfigure;
 import cn.hutool.core.collection.CollUtil;
 import cn.hutool.core.date.DateUtil;
+import cn.hutool.core.util.StrUtil;
+import com.alibaba.fastjson.JSONObject;
+import com.baomidou.mybatisplus.extension.exceptions.ApiException;
 import lombok.extern.slf4j.Slf4j;
 import org.springframework.beans.factory.annotation.Autowired;
+import org.springframework.beans.factory.annotation.Value;
 import org.springframework.boot.autoconfigure.condition.ConditionalOnProperty;
 import org.springframework.scheduling.annotation.Scheduled;
 import org.springframework.stereotype.Component;
 import org.springframework.web.client.RestTemplate;
 
 import javax.annotation.Resource;
+import java.io.IOException;
 import java.util.List;
 
 @Slf4j
@@ -21,50 +26,49 @@
 @ConditionalOnProperty(prefix = "system", name = "job", havingValue = "true")
 public class WxxcxJob {
 
-//    private final XcxProperties xcxProperties = SpringContextHolder.getBean(XcxProperties.class);
-
     @Autowired
     private RedisUtils redisUtils;
     @Autowired
     private MallMemberCouponMapper mallMemberCouponMapper;
-    @Autowired
-    private MallInvoiceService mallInvoiceService;
     @Resource
     RestTemplate restTemplate;
-//    @Autowired
-//    private SpringContextHolder springContextHolder;
     /**
      * 获取access_token
      * 有效期两小时
      */
-//    @Scheduled(cron = "0 0 0/1 * * ? ")
-//    public void getAccessToken() throws IOException {
-//        log.info("执行access_token刷新");
-//        String appId = xcxProperties.getXcxAppid();
-//        String appSecret = xcxProperties.getXcxSecret();
-//        String url = "https://api.weixin.qq.com/cgi-bin/token?grant_type=client_credential&appid=" + appId + "&secret=" + appSecret;
-//        String jsonStr = restTemplate.getForObject(url, String.class);
-//
-//        /**
-//         * 返回结果
-//         * {"access_token":"ACCESS_TOKEN","expires_in":7200}
-//         */
-//        if (!jsonStr.contains("access_token")) {
-//            System.out.println("获取微信access_token失败");
-//        }
-//
-//        String accessTokenKey = WechatConfigure.WX_ACCESS_TOKEN_REDIS_KEY;
-//        JSONObject jsonObject = JSONObject.parseObject(jsonStr);
-//        String accessToken = jsonObject.getString(accessTokenKey);
-//        if (StrUtil.isEmpty(accessToken)) {
-//            log.error("获取access token失败: {}" , jsonObject.getString("errmsg"));
-//            throw new ApiException("获取access token失败");
-//        } else {
-//            log.info("wx access_token : {}",accessToken);
-//            redisUtils.set(accessTokenKey,accessToken);
-//        }
-//
-//    }
+    @Value("${xcx.xcx_appid}")
+    private String xcxAppid;
+    // 文件保存目录URL
+    @Value("${xcx.xcx_secret}")
+    private String xcxSecret;
+    @Scheduled(cron = "0 0 0/1 * * ? ")
+    public void getAccessToken() throws IOException {
+        log.info("执行access_token刷新");
+        String appId = xcxAppid;
+        String appSecret = xcxSecret;
+        String url = "https://api.weixin.qq.com/cgi-bin/token?grant_type=client_credential&appid=" + appId + "&secret=" + appSecret;
+        String jsonStr = restTemplate.getForObject(url, String.class);
+
+        /**
+         * 返回结果
+         * {"access_token":"ACCESS_TOKEN","expires_in":7200}
+         */
+        if (!jsonStr.contains("access_token")) {
+            System.out.println("获取微信access_token失败");
+        }
+
+        String accessTokenKey = WechatConfigure.WX_ACCESS_TOKEN_REDIS_KEY;
+        JSONObject jsonObject = JSONObject.parseObject(jsonStr);
+        String accessToken = jsonObject.getString(accessTokenKey);
+        if (StrUtil.isEmpty(accessToken)) {
+            log.error("获取access token失败: {}" , jsonObject.getString("errmsg"));
+            throw new ApiException("获取access token失败");
+        } else {
+            log.info("wx access_token : {}",accessToken);
+            redisUtils.set(accessTokenKey,accessToken);
+        }
+
+    }
 
     @Scheduled(cron = "0 0 0/1 * * ? ")
     public void expireCoupon() {

--
Gitblit v1.9.1