| | |
| | | package com.xcong.excoin.common.aop; |
| | | |
| | | import cn.hutool.http.HttpException; |
| | | 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.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; |
| | |
| | | |
| | | @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 || ex instanceof UsernameNotFoundException) { |
| | | if (ex instanceof HttpException || 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; |
| | | } |
| | | |
| | |
| | | } |
| | | |
| | | SysExceptionDetailEntity exceptionData = new SysExceptionDetailEntity(); |
| | | exceptionData.setCreateTime(new Date()); |
| | | exceptionData.setMachine(InetAddress.getLocalHost().getHostName()+"-"+profiles); |
| | | exceptionData.setAddress(InetAddress.getLocalHost().getHostAddress()); |
| | | exceptionData.setExceptionMsg(printStackTraceToString(ex)); |
| | | 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(InetAddress.getLocalHost().getHostName() + "-" + profiles); |
| | | exceptionData.setAddress(InetAddress.getLocalHost().getHostAddress()); |
| | | exceptionData.setExceptionMsg(exStr); |
| | | exceptionData.setSimpleMsg(ex.getMessage()); |
| | | sysExceptionDetailDao.insert(exceptionData); |
| | | |
| | | DingTalkUtils.sendActionCard(6); |
| | | // DingTalkUtils.sendMsg(profiles + "--" + ex.getMessage(), exStr.substring(0, 200), exceptionData.getId()); |
| | | } catch (Exception e) { |
| | | log.error("exception aop", e); |
| | | } |
| | | } |
| | | }); |
| | | throw ex; |
| | | } |
| | | |