IDE下springboot学习笔记(6)----------AOP全局日志控制以及全局异常处理

文章目录

  • 前言
  • 环境准备
  • AOP全局日志控制
  • 全局异常处理
  • 总结

前言

这里只是介绍了一下最简单的处理方法,具体深度的运用还得大家自己取摸索

环境准备

由于这边用的是AOP做的全局日志管理,所以需要导入以下依赖
pom.xml

        <!--aop-->
		<dependency>
			<groupId>org.springframework.boot</groupId>
			<artifactId>spring-boot-starter-aop</artifactId>
		</dependency>

controller
这里准备一个测试接口,模拟一个异常

@ResponseBody
    @RequestMapping(value = "/throw")
    public Integer throwTest(){
        int i=0;
        return 5/i;
    }

AOP全局日志控制

注意这里用的日志还是springboot原生的,想要整合自己的日志管理,如:Log4j,就必须导入Log4j依赖并排除原生的日志依赖,然后导入自己的日志配置文件
WebLogControl

@Aspect
@Component
public class WebLogControl {
    private static final Logger logger = LoggerFactory.getLogger(WebLogControl.class);

    @Pointcut("execution(public * com.example.demo.controller.*.*(..))")
    public void webLog() {
    }

    @Before("webLog()")
    public void doBefore(JoinPoint joinPoint) throws Throwable {
        // 接收到请求,记录请求内容
        ServletRequestAttributes attributes = (ServletRequestAttributes) RequestContextHolder.getRequestAttributes();
        HttpServletRequest request = attributes.getRequest();
        // 记录下请求内容
        logger.info("URL : " + request.getRequestURL().toString());
        logger.info("HTTP_METHOD : " + request.getMethod());
        logger.info("IP : " + request.getRemoteAddr());
        Enumeration<String> enu = request.getParameterNames();
        while (enu.hasMoreElements()) {
            String name = (String) enu.nextElement();
            logger.info("name:{},value:{}", name, request.getParameter(name));
        }
    }

    @AfterReturning(returning = "ret", pointcut = "webLog()")
    public void doAfterReturning(Object ret) throws Throwable {
        // 处理完请求,返回内容
        logger.info("RESPONSE : " + ret);
    }

    @AfterThrowing(pointcut = "webLog()",throwing = "e")
    public void logThrowing(JoinPoint joinPoint,Throwable e){
        logger.info("***************抛出异常***************");

        logger.info("请求类方法:"+joinPoint.getSignature().getName());
        logger.info("异常内容:"+e);
        logger.info("***************抛出异常***************");
    }

测试
用刚准备好的异常接口做测试
IDE下springboot学习笔记(6)----------AOP全局日志控制以及全局异常处理_第1张图片
可以看到日志是已经打印出来了的,但由于还没有做出异常处理所以报出异常了,下面来做全局异常处理吧

全局异常处理

这里只是一个小例子就不做多余介绍了,找到上图的异常类ArithmeticException,对这个异常做出处理,自定义返回
WebExceptionControl

@RestControllerAdvice
public class WebExceptionControl {

   @ExceptionHandler(ArithmeticException.class)
    public String ArithmeticExceptionHandler(ArithmeticException e){
       return "不好意思数据出错啦";
   }

}

添加如上文件后让我们再来测试一下
测试结果
IDE下springboot学习笔记(6)----------AOP全局日志控制以及全局异常处理_第2张图片
IDE下springboot学习笔记(6)----------AOP全局日志控制以及全局异常处理_第3张图片
可以看到现在已经并没有报出异常了,而且返回也和我们自己定义的是一样的结果

总结

这里的例子非常的简单,实际当中的具体运用就需要大家根据情况去做相应的处理了,不要害怕实践,实践才能出真理

你可能感兴趣的:(springboot,spring,boot)