springboot AOP异常执行

该博客介绍了如何利用Spring的AOP(面向切面编程)来实现控制器层的异常日志记录功能。通过定义切点表达式,设置不同的通知(前置、后置、返回、异常),可以在方法执行前后及遇到异常时记录相关信息,帮助开发者在bug难以复现时追踪问题。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

当系统出现bug时,很多时候难以重现当时的场景,我们又不知道在哪里出现了bug,这时,我们就需要一个异常时日志记录的功能。

通过AOP实现该功能

//切面类
@Aspect
@Component
public class ControllerLogAspect {
    private final static Logger logger = LoggerFactory.getLogger(ControllerLogAspect.class);

    //切入点表达式
    @Pointcut("execution(public * com.example.rediss.controller..*.*(..))")
    public void log() {
    }

    @Before("log()")
    public void doBefore(JoinPoint joinPoint) {
        logger.info("aop doBefore..");
    }

    @After("log()")
    public void doAfter() {
        logger.info("aop doAfter");
    }
    @AfterReturning(value = "log()")
    public void afterReturning()
    {
        System.out.println("aop @AfterReturning");
    }
    @AfterThrowing("log()")
    public void throwAfter() {
        ServletRequestAttributes attributes = (ServletRequestAttributes) RequestContextHolder.getRequestAttributes();
        HttpServletRequest request = attributes.getRequest();
        Enumeration<String> paramter = request.getParameterNames();
        logger.info("aop erroe,info");
    }


    @Around(value = "log()")
    public Object myAround(ProceedingJoinPoint proceedingJoinPoint)
    {
        Object[] args = proceedingJoinPoint.getArgs();
        Object result=null;
        try {
            //前置通知@Before
            System.out.println("环绕前置通知");
            //目标方法执行
            result = proceedingJoinPoint.proceed(args);
            //环绕返回通知@AfterReturning
            System.out.println("环绕返回通知");
        } catch (Throwable throwable) {
            //环绕异常通知@AfterThrowing
            System.out.println("环绕异常通知");
            throw new RuntimeException(throwable);
        } finally {
            //最终通知@After
            System.out.println("环绕最终通知");
        }
        return result;
    }
}

1.使用不同spring版本,执行顺序会不同
2.如果目标任务出现异常,可直接在@AfterThrow里面记录参数,并写入日志

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值