refactor(消息通知): 修改发送通知的方式,避免在高版本jdk中出现反射警告

This commit is contained in:
CaptainB 2022-04-01 18:18:51 +08:00 committed by 刘瑞斌
parent 97713d7d3c
commit 2c781b7fa4
3 changed files with 28 additions and 44 deletions

View File

@ -29,11 +29,6 @@ public @interface SendNotice {
*/ */
Class<?> targetClass() default Object.class; Class<?> targetClass() default Object.class;
/**
* 保存资源的 json
*/
String source() default "";
/** /**
* 消息内容 * 消息内容
*/ */

View File

@ -1,19 +1,16 @@
package io.metersphere.notice.sender; package io.metersphere.notice.sender;
import com.alibaba.fastjson.JSON;
import io.metersphere.commons.constants.NoticeConstants; import io.metersphere.commons.constants.NoticeConstants;
import io.metersphere.commons.user.SessionUser; import io.metersphere.commons.user.SessionUser;
import io.metersphere.dto.BaseSystemConfigDTO; import io.metersphere.dto.BaseSystemConfigDTO;
import io.metersphere.notice.annotation.SendNotice; import io.metersphere.notice.annotation.SendNotice;
import io.metersphere.notice.service.NoticeSendService; import io.metersphere.notice.service.NoticeSendService;
import io.metersphere.service.SystemParameterService; import io.metersphere.service.SystemParameterService;
import org.apache.commons.beanutils.BeanMap;
import org.apache.commons.lang3.StringUtils; import org.apache.commons.lang3.StringUtils;
import org.springframework.scheduling.annotation.Async; import org.springframework.scheduling.annotation.Async;
import org.springframework.stereotype.Component; import org.springframework.stereotype.Component;
import javax.annotation.Resource; import javax.annotation.Resource;
import java.util.ArrayList;
import java.util.HashMap; import java.util.HashMap;
import java.util.List; import java.util.List;
import java.util.Map; import java.util.Map;
@ -26,23 +23,8 @@ public class AfterReturningNoticeSendService {
private NoticeSendService noticeSendService; private NoticeSendService noticeSendService;
@Async @Async
public void sendNotice(SendNotice sendNotice, Object retValue, SessionUser sessionUser, String currentProjectId) { public void sendNotice(SendNotice sendNotice, List<Map> resources, SessionUser sessionUser, String currentProjectId) {
//
List<Map> resources = new ArrayList<>();
String source = sendNotice.source();
if (StringUtils.isNotBlank(source)) {
// array
if (StringUtils.startsWith(source, "[")) {
resources.addAll(JSON.parseArray(source, Map.class));
}
// map
else {
Map<?, ?> value = JSON.parseObject(source, Map.class);
resources.add(value);
}
} else {
resources.add(new BeanMap(retValue));
}
// 有批量操作发送多次 // 有批量操作发送多次
BaseSystemConfigDTO baseSystemConfigDTO = systemParameterService.getBaseInfo(); BaseSystemConfigDTO baseSystemConfigDTO = systemParameterService.getBaseInfo();
for (Map resource : resources) { for (Map resource : resources) {

View File

@ -6,6 +6,7 @@ import io.metersphere.commons.utils.CommonBeanFactory;
import io.metersphere.commons.utils.LogUtil; import io.metersphere.commons.utils.LogUtil;
import io.metersphere.commons.utils.SessionUtils; import io.metersphere.commons.utils.SessionUtils;
import io.metersphere.notice.annotation.SendNotice; import io.metersphere.notice.annotation.SendNotice;
import org.apache.commons.beanutils.BeanMap;
import org.apache.commons.lang3.StringUtils; import org.apache.commons.lang3.StringUtils;
import org.aspectj.lang.JoinPoint; import org.aspectj.lang.JoinPoint;
import org.aspectj.lang.annotation.AfterReturning; import org.aspectj.lang.annotation.AfterReturning;
@ -22,10 +23,9 @@ import org.springframework.expression.spel.support.StandardEvaluationContext;
import org.springframework.stereotype.Component; import org.springframework.stereotype.Component;
import javax.annotation.Resource; import javax.annotation.Resource;
import java.lang.reflect.Field;
import java.lang.reflect.InvocationHandler;
import java.lang.reflect.Method; import java.lang.reflect.Method;
import java.lang.reflect.Proxy; import java.util.ArrayList;
import java.util.List;
import java.util.Map; import java.util.Map;
import static com.alibaba.fastjson.serializer.SerializerFeature.WriteMapNullValue; import static com.alibaba.fastjson.serializer.SerializerFeature.WriteMapNullValue;
@ -38,7 +38,7 @@ public class SendNoticeAspect {
private ExpressionParser parser = new SpelExpressionParser(); private ExpressionParser parser = new SpelExpressionParser();
private LocalVariableTableParameterNameDiscoverer discoverer = new LocalVariableTableParameterNameDiscoverer(); private LocalVariableTableParameterNameDiscoverer discoverer = new LocalVariableTableParameterNameDiscoverer();
private ThreadLocal<String> source = new ThreadLocal<>();
@Pointcut("@annotation(io.metersphere.notice.annotation.SendNotice)") @Pointcut("@annotation(io.metersphere.notice.annotation.SendNotice)")
public void pointcut() { public void pointcut() {
@ -55,10 +55,6 @@ public class SendNoticeAspect {
Object[] args = joinPoint.getArgs(); Object[] args = joinPoint.getArgs();
SendNotice sendNotice = method.getAnnotation(SendNotice.class); SendNotice sendNotice = method.getAnnotation(SendNotice.class);
InvocationHandler invocationHandler = Proxy.getInvocationHandler(sendNotice);
Field value = invocationHandler.getClass().getDeclaredField("memberValues");
value.setAccessible(true);
if (StringUtils.isNotEmpty(sendNotice.target())) { if (StringUtils.isNotEmpty(sendNotice.target())) {
// 操作内容 // 操作内容
//获取方法参数名 //获取方法参数名
@ -73,8 +69,7 @@ public class SendNoticeAspect {
String target = sendNotice.target(); String target = sendNotice.target();
Expression titleExp = parser.parseExpression(target); Expression titleExp = parser.parseExpression(target);
Object v = titleExp.getValue(context, Object.class); Object v = titleExp.getValue(context, Object.class);
Map<String, Object> memberValues = (Map<String, Object>) value.get(invocationHandler); source.set(JSON.toJSONString(v, WriteMapNullValue));
memberValues.put("source", JSON.toJSONString(v, WriteMapNullValue));
} }
} catch (Exception e) { } catch (Exception e) {
LogUtil.error(e.getMessage(), e); LogUtil.error(e.getMessage(), e);
@ -95,9 +90,6 @@ public class SendNoticeAspect {
//获取操作 //获取操作
SendNotice sendNotice = method.getAnnotation(SendNotice.class); SendNotice sendNotice = method.getAnnotation(SendNotice.class);
// 再次从数据库查询一次内容方便获取最新参数 // 再次从数据库查询一次内容方便获取最新参数
InvocationHandler invocationHandler = Proxy.getInvocationHandler(sendNotice);
Field value = invocationHandler.getClass().getDeclaredField("memberValues");
value.setAccessible(true);
if (StringUtils.isNotEmpty(sendNotice.target())) { if (StringUtils.isNotEmpty(sendNotice.target())) {
//将参数纳入Spring管理 //将参数纳入Spring管理
@ -113,20 +105,35 @@ public class SendNoticeAspect {
// 查询结果如果是null或者是{}不使用这个值 // 查询结果如果是null或者是{}不使用这个值
String jsonObject = JSON.toJSONString(v); String jsonObject = JSON.toJSONString(v);
if (v != null && !StringUtils.equals("{}", jsonObject) && !StringUtils.equals("[]", jsonObject)) { if (v != null && !StringUtils.equals("{}", jsonObject) && !StringUtils.equals("[]", jsonObject)) {
Map<String, Object> memberValues = (Map<String, Object>) value.get(invocationHandler); source.set(JSON.toJSONString(v, WriteMapNullValue));
memberValues.put("source", JSON.toJSONString(v, WriteMapNullValue));
} }
} }
EvaluationContext context = new StandardEvaluationContext(); //
for (int len = 0; len < params.length; len++) { List<Map> resources = new ArrayList<>();
context.setVariable(params[len], args[len]); String v = source.get();
if (StringUtils.isNotBlank(v)) {
// array
if (StringUtils.startsWith(v, "[")) {
resources.addAll(JSON.parseArray(v, Map.class));
} }
// map
else {
Map<?, ?> value = JSON.parseObject(v, Map.class);
resources.add(value);
}
} else {
resources.add(new BeanMap(retValue));
}
SessionUser sessionUser = SessionUtils.getUser(); SessionUser sessionUser = SessionUtils.getUser();
String currentProjectId = SessionUtils.getCurrentProjectId(); String currentProjectId = SessionUtils.getCurrentProjectId();
afterReturningNoticeSendService.sendNotice(sendNotice, retValue, sessionUser, currentProjectId); afterReturningNoticeSendService.sendNotice(sendNotice, resources, sessionUser, currentProjectId);
} catch (Exception e) { } catch (Exception e) {
LogUtil.error(e.getMessage(), e); LogUtil.error(e.getMessage(), e);
} finally {
source.remove();
} }
} }
} }