Merge branch 'dev'
commit
cdd7731d98
|
|
@ -0,0 +1,22 @@
|
||||||
|
package com.kimgo.wepush.common;
|
||||||
|
|
||||||
|
import com.fasterxml.jackson.core.JsonProcessingException;
|
||||||
|
import com.fasterxml.jackson.databind.ObjectMapper;
|
||||||
|
|
||||||
|
public class JsonConverter<T> {
|
||||||
|
|
||||||
|
private final ObjectMapper objectMapper;
|
||||||
|
|
||||||
|
public JsonConverter () {
|
||||||
|
this.objectMapper = new ObjectMapper();
|
||||||
|
}
|
||||||
|
|
||||||
|
// 将对象序列化为 JSON 字符串
|
||||||
|
public String serialize(T object) throws JsonProcessingException {
|
||||||
|
return objectMapper.writeValueAsString(object);
|
||||||
|
}
|
||||||
|
// 将 JSON 字符串反序列化为对象
|
||||||
|
public T deserialize(String json, Class<T> clazz) throws JsonProcessingException {
|
||||||
|
return objectMapper.readValue(json, clazz);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
@ -1,57 +0,0 @@
|
||||||
package com.kimgo.wepush.request;
|
|
||||||
|
|
||||||
import com.fasterxml.jackson.core.JsonProcessingException;
|
|
||||||
import com.fasterxml.jackson.databind.ObjectMapper;
|
|
||||||
import com.kimgo.wepush.response.QyWeChatSendMessageApiResponse;
|
|
||||||
import okhttp3.MediaType;
|
|
||||||
import okhttp3.OkHttpClient;
|
|
||||||
import okhttp3.RequestBody;
|
|
||||||
import okhttp3.Response;
|
|
||||||
import org.slf4j.Logger;
|
|
||||||
import org.slf4j.LoggerFactory;
|
|
||||||
import java.io.IOException;
|
|
||||||
|
|
||||||
public class Request {
|
|
||||||
private final Logger logger = LoggerFactory.getLogger(Request.class);
|
|
||||||
|
|
||||||
public <T> QyWeChatSendMessageApiResponse okhttpRequest(String url,String accessToken,T object){
|
|
||||||
OkHttpClient client = new OkHttpClient();
|
|
||||||
|
|
||||||
// 使用Jackson进行序列化
|
|
||||||
ObjectMapper objectMapper = new ObjectMapper();
|
|
||||||
String jsonBody = null;
|
|
||||||
try {
|
|
||||||
jsonBody = objectMapper.writeValueAsString(object);
|
|
||||||
logger.info("jsonBody: {}",jsonBody);
|
|
||||||
} catch (JsonProcessingException e) {
|
|
||||||
logger.error("JSON processing error", e);
|
|
||||||
return null;
|
|
||||||
}
|
|
||||||
// 构建请求体
|
|
||||||
RequestBody body = RequestBody.create(MediaType.parse("application/json; charset=utf-8"), jsonBody);
|
|
||||||
okhttp3.Request request = new okhttp3.Request.Builder().url(url).post(body).build();
|
|
||||||
try (Response response = client.newCall(request).execute()) {
|
|
||||||
String responseBody = response.body().string();
|
|
||||||
logger.info("request sendMessage api ResponseBody: {}", responseBody);
|
|
||||||
|
|
||||||
ObjectMapper objectMapper1 = new ObjectMapper();
|
|
||||||
QyWeChatSendMessageApiResponse apiResponse = objectMapper1.readValue(responseBody, QyWeChatSendMessageApiResponse.class);
|
|
||||||
|
|
||||||
if (apiResponse.getErrcode() == 0) {
|
|
||||||
logger.debug("Request qyWeChat Success.");
|
|
||||||
return apiResponse;
|
|
||||||
} else if (apiResponse.getErrcode() == 42001 || apiResponse.getErrcode() == 40014) {
|
|
||||||
logger.info("Access token expired. Refreshing token...");
|
|
||||||
// 一个方法来刷新accessToken
|
|
||||||
return apiResponse;
|
|
||||||
} else {
|
|
||||||
// 处理其他错误情况
|
|
||||||
logger.error("Error: {}", apiResponse.getErrmsg());
|
|
||||||
return null;
|
|
||||||
}
|
|
||||||
} catch (IOException e) {
|
|
||||||
logger.error("OkHttp request error", e);
|
|
||||||
return null;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
@ -0,0 +1,78 @@
|
||||||
|
package com.kimgo.wepush.request;
|
||||||
|
|
||||||
|
import com.fasterxml.jackson.core.JsonProcessingException;
|
||||||
|
import com.fasterxml.jackson.databind.ObjectMapper;
|
||||||
|
import com.kimgo.wepush.common.JsonConverter;
|
||||||
|
import com.kimgo.wepush.response.QyWeChatSendMessageApiResponse;
|
||||||
|
import com.kimgo.wepush.service.TokenService;
|
||||||
|
import okhttp3.MediaType;
|
||||||
|
import okhttp3.OkHttpClient;
|
||||||
|
import okhttp3.RequestBody;
|
||||||
|
import okhttp3.Response;
|
||||||
|
import org.slf4j.Logger;
|
||||||
|
import org.slf4j.LoggerFactory;
|
||||||
|
|
||||||
|
import java.io.IOException;
|
||||||
|
|
||||||
|
public class SendQyWeChatMsgRequest {
|
||||||
|
private final Logger logger = LoggerFactory.getLogger(SendQyWeChatMsgRequest.class);
|
||||||
|
private final OkHttpClient client = new OkHttpClient();
|
||||||
|
private final TokenService tokenService;
|
||||||
|
private final JsonConverter<Object> jsonConverter = new JsonConverter<>();
|
||||||
|
|
||||||
|
public SendQyWeChatMsgRequest(TokenService tokenService) {
|
||||||
|
this.tokenService = tokenService;
|
||||||
|
}
|
||||||
|
|
||||||
|
public <T> QyWeChatSendMessageApiResponse okhttpRequest(String baseurl, String accessToken, T object) {
|
||||||
|
int retryCount = 0;
|
||||||
|
final int maxRetries = 2;
|
||||||
|
|
||||||
|
while (retryCount <= maxRetries) {
|
||||||
|
String url = baseurl + "?access_token=" + accessToken;
|
||||||
|
// 使用Jackson进行序列化
|
||||||
|
String jsonBody;
|
||||||
|
try {
|
||||||
|
jsonBody = jsonConverter.serialize(object);
|
||||||
|
} catch (JsonProcessingException e) {
|
||||||
|
return new QyWeChatSendMessageApiResponse(-1, "json serialization exception");
|
||||||
|
}
|
||||||
|
// 构建请求体
|
||||||
|
MediaType mediaType = MediaType.parse("application/json; charset=utf-8");
|
||||||
|
RequestBody body = RequestBody.create(jsonBody, mediaType);
|
||||||
|
|
||||||
|
okhttp3.Request request = new okhttp3.Request.Builder().url(url).post(body).build();
|
||||||
|
try (Response response = client.newCall(request).execute()) {
|
||||||
|
String responseBody = null;
|
||||||
|
if (response.body() != null) {
|
||||||
|
responseBody = response.body().string();
|
||||||
|
}
|
||||||
|
logger.info("request sendMessage api ResponseBody: {}", responseBody);
|
||||||
|
|
||||||
|
ObjectMapper objectMapper1 = new ObjectMapper();
|
||||||
|
QyWeChatSendMessageApiResponse apiResponse = objectMapper1.readValue(responseBody, QyWeChatSendMessageApiResponse.class);
|
||||||
|
|
||||||
|
if (apiResponse.getErrcode() == 0) {
|
||||||
|
logger.debug("Request qyWeChat Success.");
|
||||||
|
return apiResponse;
|
||||||
|
} else if (apiResponse.getErrcode() == 42001 || apiResponse.getErrcode() == 40014) {
|
||||||
|
logger.info("Access token expired. Refreshing token...");
|
||||||
|
// 刷新accessToken
|
||||||
|
tokenService.setAccessToken();
|
||||||
|
accessToken = tokenService.getAccessToken();
|
||||||
|
retryCount++;
|
||||||
|
} else {
|
||||||
|
// 处理成功或其他错误情况
|
||||||
|
return apiResponse;
|
||||||
|
}
|
||||||
|
} catch (IOException e) {
|
||||||
|
logger.error("OkHttp request error", e);
|
||||||
|
if (retryCount >= maxRetries) {
|
||||||
|
return new QyWeChatSendMessageApiResponse(-1,"the maximum number of attempts exceeded");
|
||||||
|
}
|
||||||
|
retryCount++;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return new QyWeChatSendMessageApiResponse(-1,"request error.");
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
@ -7,4 +7,9 @@ public class QyWeChatSendMessageApiResponse {
|
||||||
private int errcode;
|
private int errcode;
|
||||||
private String errmsg;
|
private String errmsg;
|
||||||
private String msgid;
|
private String msgid;
|
||||||
|
|
||||||
|
public QyWeChatSendMessageApiResponse(int errcode, String errmsg) {
|
||||||
|
this.errcode = errcode;
|
||||||
|
this.errmsg = errmsg;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
@ -5,7 +5,7 @@ import com.baomidou.mybatisplus.core.conditions.update.UpdateWrapper;
|
||||||
import com.kimgo.wepush.mapper.DeviceInfoDAOMapper;
|
import com.kimgo.wepush.mapper.DeviceInfoDAOMapper;
|
||||||
import com.kimgo.wepush.model.DeviceInfoDAO;
|
import com.kimgo.wepush.model.DeviceInfoDAO;
|
||||||
import com.kimgo.wepush.model.TextCardMessage;
|
import com.kimgo.wepush.model.TextCardMessage;
|
||||||
import com.kimgo.wepush.request.Request;
|
import com.kimgo.wepush.request.SendQyWeChatMsgRequest;
|
||||||
import com.kimgo.wepush.response.QyWeChatSendMessageApiResponse;
|
import com.kimgo.wepush.response.QyWeChatSendMessageApiResponse;
|
||||||
import org.slf4j.Logger;
|
import org.slf4j.Logger;
|
||||||
import org.slf4j.LoggerFactory;
|
import org.slf4j.LoggerFactory;
|
||||||
|
|
@ -81,10 +81,11 @@ public class MonitorService {
|
||||||
|
|
||||||
|
|
||||||
private void sendNotification(DeviceInfoDAO deviceInfoDAO){
|
private void sendNotification(DeviceInfoDAO deviceInfoDAO){
|
||||||
Request request = new Request();
|
SendQyWeChatMsgRequest sendQyWeChatMsgRequest = new SendQyWeChatMsgRequest(tokenService);
|
||||||
String accessToken = tokenService.getAccessToken();
|
String accessToken = tokenService.getAccessToken();
|
||||||
String url = qyWeChatURLService.getSendTextCardMessageUrl() + "?access_token=" + accessToken;
|
String url = qyWeChatURLService.getSendTextCardMessageUrl();
|
||||||
QyWeChatSendMessageApiResponse qyWeChatSendMessageApiResponse = request.okhttpRequest(url,accessToken,setTextCardMessage(deviceInfoDAO));
|
QyWeChatSendMessageApiResponse qyWeChatSendMessageApiResponse = sendQyWeChatMsgRequest.okhttpRequest(url,
|
||||||
|
accessToken,setTextCardMessage(deviceInfoDAO));
|
||||||
if (qyWeChatSendMessageApiResponse ==null){
|
if (qyWeChatSendMessageApiResponse ==null){
|
||||||
logger.info("Send Notification Fail");
|
logger.info("Send Notification Fail");
|
||||||
}
|
}
|
||||||
|
|
|
||||||
Loading…
Reference in New Issue