From 5575818556096be1dadaf5ff356b5db4c832aaa2 Mon Sep 17 00:00:00 2001 From: Helius <wangdoubleone@gmail.com> Date: Wed, 26 May 2021 19:27:09 +0800 Subject: [PATCH] modify --- src/main/java/com/xcong/excoin/common/aop/ExceptionCatchAspect.java | 49 ++++++++++++++++++++++++++++++++++++++++++------- 1 files changed, 42 insertions(+), 7 deletions(-) diff --git a/src/main/java/com/xcong/excoin/common/aop/ExceptionCatchAspect.java b/src/main/java/com/xcong/excoin/common/aop/ExceptionCatchAspect.java index 8e1f8e4..85e1226 100644 --- a/src/main/java/com/xcong/excoin/common/aop/ExceptionCatchAspect.java +++ b/src/main/java/com/xcong/excoin/common/aop/ExceptionCatchAspect.java @@ -3,17 +3,23 @@ import com.xcong.excoin.common.exception.GlobalException; import com.xcong.excoin.common.system.bean.SysExceptionDetailEntity; import com.xcong.excoin.modules.platform.dao.SysExceptionDetailDao; +import com.xcong.excoin.utils.ThreadPoolUtils; +import com.xcong.excoin.utils.dingtalk.DingTalkUtils; import lombok.extern.slf4j.Slf4j; import org.aspectj.lang.JoinPoint; import org.aspectj.lang.annotation.AfterThrowing; import org.aspectj.lang.annotation.Aspect; import org.aspectj.lang.annotation.Pointcut; import org.springframework.beans.factory.annotation.Autowired; +import org.springframework.beans.factory.annotation.Value; import org.springframework.dao.DuplicateKeyException; import org.springframework.security.authentication.BadCredentialsException; +import org.springframework.security.core.userdetails.UsernameNotFoundException; import org.springframework.stereotype.Component; import org.springframework.web.bind.MethodArgumentNotValidException; +import org.springframework.web.client.ResourceAccessException; +import javax.net.ssl.SSLException; import javax.validation.ValidationException; import java.io.PrintWriter; import java.io.StringWriter; @@ -37,13 +43,19 @@ @Autowired private SysExceptionDetailDao sysExceptionDetailDao; + @Value("${spring.profiles.active}") + private String profiles; + + @Value("${app.project}") + private String projectName; + @Pointcut("execution(* com.xcong.excoin..*.*(..))") public void exceptionCatch() { } @AfterThrowing(pointcut = "exceptionCatch()", throwing = "ex") public void afterThrows(JoinPoint jp, Exception ex) throws Exception { - if (ex instanceof GlobalException || ex instanceof MethodArgumentNotValidException || ex instanceof ValidationException || ex instanceof DuplicateKeyException || ex instanceof BadCredentialsException) { + if (ex instanceof ResourceAccessException || ex instanceof GlobalException || ex instanceof MethodArgumentNotValidException || ex instanceof ValidationException || ex instanceof DuplicateKeyException || ex instanceof BadCredentialsException || ex instanceof UsernameNotFoundException || ex instanceof SSLException) { throw ex; } @@ -51,13 +63,36 @@ throw ex; } + if (profiles.equals("dev") || profiles.equals("test")) { + throw ex; + } + SysExceptionDetailEntity exceptionData = new SysExceptionDetailEntity(); - exceptionData.setCreateTime(new Date()); - exceptionData.setMachine(InetAddress.getLocalHost().getHostName()); - exceptionData.setAddress(InetAddress.getLocalHost().getHostAddress()); - exceptionData.setExceptionMsg(printStackTraceToString(ex.fillInStackTrace())); - exceptionData.setSimpleMsg(ex.getMessage()); - sysExceptionDetailDao.insert(exceptionData); + String exStr = printStackTraceToString(ex); + ThreadPoolUtils.EXECUTOR.execute(new Runnable(){ + @Override + public void run() { + try { + log.info("插入"); + exceptionData.setCreateTime(new Date()); + exceptionData.setMachine(projectName + "-" + InetAddress.getLocalHost().getHostName() + "-" + profiles); + exceptionData.setAddress(InetAddress.getLocalHost().getHostAddress()); + exceptionData.setExceptionMsg(exStr); + exceptionData.setSimpleMsg(ex.getMessage()); + sysExceptionDetailDao.insert(exceptionData); + + String msg = ""; + if (exStr.length() > 200) { + msg = exStr.substring(0, 200); + } else { + msg = exStr; + } + DingTalkUtils.sendMsg(projectName + "-" +profiles + "--" + ex.getMessage(), msg, exceptionData.getId()); + } catch (Exception e) { + log.error("exception aop", e); + } + } + }); throw ex; } -- Gitblit v1.9.1