Spring配置AOP没有反应

本文介绍如何使用Spring AOP实现日志记录功能。通过创建Aspect类并定义Pointcut和Advice,可以轻松地为Controller层的方法添加日志记录。此外,还需要在Spring配置文件中启用AspectJ自动代理。

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

添加AOP很简单,如下添加一个aspect:

package com.mk.aop;

import org.aspectj.lang.annotation.After;
import org.aspectj.lang.annotation.Aspect;
import org.aspectj.lang.annotation.Before;
import org.aspectj.lang.annotation.Pointcut;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import org.springframework.stereotype.Component;

/**
 */

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

    @Pointcut("execution(* com.mk.controller.*.*(..))")
    private void pointCut() {

    }

    @Before("pointCut()")
    public void beforeAdvice() {
        logger.info("---------------HTTP REQUEST-----------------");

    }

}

然后配置xml:

<aop:aspectj-autoproxy/>

要注意两点:
1、在头添加了@Component注解,或者在xml中添加了bean配置。这样Spring容器才会去实例化aspect类。才能发现我们的aspect注解,切入点、advice等。

2、如果采用了spring mvc,配置要写在spring-mvc的配置文件里。也就是 <aop:aspectj-autoproxy/> 这句

3、切入点是否写对。 切入点含义
(* 包名.类名.方法(参数)) ,类名和方法可以采用 * 通配符表示,比如示例中,就是com.mk.controller 包下全部类的全部方法,均织入aspect。

评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值