Spring配置AOP没有反应

来源:互联网 发布:zbrush for mac 编辑:程序博客网 时间:2024/04/28 03:31

添加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@Aspectpublic 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。

0 1