From 24e986fa22f7e1b94c0b2197fb1b62ae51023cef Mon Sep 17 00:00:00 2001
From: xiaoyong931011 <15274802129@163.com>
Date: Wed, 10 Aug 2022 17:18:50 +0800
Subject: [PATCH] 20220810
---
src/main/java/cc/mrbird/febs/mall/quartz/WxxcxJob.java | 24 +++++++----
src/main/java/cc/mrbird/febs/FebsShiroApplication.java | 13 ++++++
src/test/java/cc/mrbird/febs/ProfitTest.java | 27 +++++++++++++
3 files changed, 55 insertions(+), 9 deletions(-)
diff --git a/src/main/java/cc/mrbird/febs/FebsShiroApplication.java b/src/main/java/cc/mrbird/febs/FebsShiroApplication.java
index 3f01173..0983d5c 100644
--- a/src/main/java/cc/mrbird/febs/FebsShiroApplication.java
+++ b/src/main/java/cc/mrbird/febs/FebsShiroApplication.java
@@ -4,9 +4,14 @@
import org.springframework.boot.WebApplicationType;
import org.springframework.boot.autoconfigure.SpringBootApplication;
import org.springframework.boot.builder.SpringApplicationBuilder;
+import org.springframework.context.annotation.Bean;
+import org.springframework.http.converter.StringHttpMessageConverter;
import org.springframework.scheduling.annotation.EnableAsync;
import org.springframework.scheduling.annotation.EnableScheduling;
import org.springframework.transaction.annotation.EnableTransactionManagement;
+import org.springframework.web.client.RestTemplate;
+
+import java.nio.charset.StandardCharsets;
/**
* @author MrBird
@@ -24,4 +29,12 @@
.run(args);
}
+ @Bean
+ RestTemplate getRestTemplate(){
+ RestTemplate restTemplate = new RestTemplate();
+ //解决中文乱码问题
+ restTemplate.getMessageConverters().set(1, new StringHttpMessageConverter(StandardCharsets.UTF_8));
+ return restTemplate;
+ }
+
}
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 a301c09..8c587d6 100644
--- a/src/main/java/cc/mrbird/febs/mall/quartz/WxxcxJob.java
+++ b/src/main/java/cc/mrbird/febs/mall/quartz/WxxcxJob.java
@@ -6,13 +6,16 @@
import cc.mrbird.febs.common.utils.SpringContextHolder;
import cc.mrbird.febs.pay.util.WechatConfigure;
import cn.hutool.core.util.StrUtil;
+import com.alibaba.fastjson.JSON;
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.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.HashMap;
import java.util.Map;
@@ -25,26 +28,29 @@
@Autowired
private RedisUtils redisUtils;
+ @Resource
+ RestTemplate restTemplate;
/**
* 获取access_token
* 有效期两小时
*/
@Scheduled(cron = "0 0/5 * * * ? ")
public void getAccessToken() throws IOException {
-
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);
- Map<String,String> params = new HashMap<>();
- params.put("grant_type","client_credential");
- params.put("appid",appId);
- params.put("secret",appSecret);
-
- //发送请求
- String result = HttpCurlUtil.sendGetHttp(WechatConfigure.WX_ACCESS_TOKEN , params);
+ /**
+ * 返回结果
+ * {"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(result);
+ JSONObject jsonObject = JSONObject.parseObject(jsonStr);
String accessToken = jsonObject.getString(accessTokenKey);
if (StrUtil.isEmpty(accessToken)) {
log.error("获取access token失败: {}" , jsonObject.getString("errmsg"));
diff --git a/src/test/java/cc/mrbird/febs/ProfitTest.java b/src/test/java/cc/mrbird/febs/ProfitTest.java
index 435c997..64cd7ae 100644
--- a/src/test/java/cc/mrbird/febs/ProfitTest.java
+++ b/src/test/java/cc/mrbird/febs/ProfitTest.java
@@ -7,10 +7,14 @@
import cc.mrbird.febs.mall.service.IMallAchieveService;
import cc.mrbird.febs.mall.service.IMemberProfitService;
import cc.mrbird.febs.rabbit.consumer.AgentConsumer;
+import com.alibaba.fastjson.JSON;
+import com.alibaba.fastjson.JSONObject;
import org.junit.jupiter.api.Test;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.boot.test.context.SpringBootTest;
+import org.springframework.web.client.RestTemplate;
+import javax.annotation.Resource;
import java.math.BigDecimal;
import java.util.Date;
import java.util.HashMap;
@@ -92,4 +96,27 @@
public void changeAmount(Map<String, Integer> amount) {
amount.put("amount", 2);
}
+
+ @Resource
+ RestTemplate restTemplate;
+
+ @Test
+ public void getWeChatAccessToken() {
+
+ String appId = "wx5cc58f796224af61";
+ String appSecret = "71403646f666f9b9dca308d4f357765c";
+ 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失败");
+ }
+
+ JSONObject jsonObject = JSON.parseObject(jsonStr);
+ System.out.println(jsonObject.get("access_token").toString());
+ }
}
--
Gitblit v1.9.1