New file |
| | |
| | | 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(); |
| | | } |
| | | } |