From 9e6054ca0612a05ec2b698b8a63db7605c600725 Mon Sep 17 00:00:00 2001 From: Helius <wangdoubleone@gmail.com> Date: Fri, 05 Mar 2021 14:51:08 +0800 Subject: [PATCH] modify --- src/main/java/com/xcong/excoin/common/aop/ExceptionCatchAspect.java | 69 ++++++++++++++++++++++++++++++++++ 1 files changed, 69 insertions(+), 0 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 new file mode 100644 index 0000000..3eeff37 --- /dev/null +++ b/src/main/java/com/xcong/excoin/common/aop/ExceptionCatchAspect.java @@ -0,0 +1,69 @@ +package com.xcong.excoin.common.aop; + +import com.xcong.excoin.common.exception.GlobalException; +import com.xcong.excoin.common.system.bean.SysExceptionDetailEntity; +import com.xcong.excoin.modules.platform.dao.SysExceptionDetailDao; +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.dao.DuplicateKeyException; +import org.springframework.security.authentication.BadCredentialsException; +import org.springframework.stereotype.Component; +import org.springframework.web.bind.MethodArgumentNotValidException; + +import javax.validation.ValidationException; +import java.io.PrintWriter; +import java.io.StringWriter; +import java.net.InetAddress; +import java.util.ArrayList; +import java.util.Arrays; +import java.util.Date; +import java.util.List; + +/** + * @author wzy + * @date 2021-03-05 + **/ +@Slf4j +@Aspect +@Component +public class ExceptionCatchAspect { + + private static final List EXCLUDE_EXCEPTION = new ArrayList(Arrays.asList("java.io.IOException: Broken pipe")); + + @Autowired + private SysExceptionDetailDao sysExceptionDetailDao; + + @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) { + throw ex; + } + + if (EXCLUDE_EXCEPTION.contains(ex.getMessage())) { + throw ex; + } + + SysExceptionDetailEntity exceptionData = new SysExceptionDetailEntity(); + exceptionData.setCreateTime(new Date()); + exceptionData.setMachine(InetAddress.getLocalHost().getHostName()); + exceptionData.setAddress(InetAddress.getLocalHost().getHostAddress()); + exceptionData.setExceptionMsg(printStackTraceToString(ex)); + exceptionData.setSimpleMsg(ex.getMessage()); + sysExceptionDetailDao.insert(exceptionData); + throw ex; + } + + public String printStackTraceToString(Throwable t) { + StringWriter sw = new StringWriter(); + t.printStackTrace(new PrintWriter(sw, true)); + return sw.getBuffer().toString(); + } +} -- Gitblit v1.9.1