第一步 加入jar包 aspectjweaver.jar aspectj织入jar包 ;aspectjrt.jar aspect runningtime aspect运行时环境jar包
第二步 配置xml文件 在xml文件加入
这句话的意思是 在需要的时候 spring会自动创建动态代理
逻辑代码如下
具体流程如下:容器扫描 com.bjsxt 路径 ,发现 LogInterceptor 是一个 Component(组件) 而且是一个 Aspect(切面) 并且 @Before("")
所以在执行 save方法之前 会调用 切面逻辑 before() . LogInterceptor 是独立的且不受其他组件影响的逻辑块,执行与否完全自己决定.
第二步 配置xml文件 在xml文件加入
<aop:annoaction-config/>
<aop:aspect-autoproxy/>
<context:component-scan base-package="com.bjsxt" />
这句话的意思是 在需要的时候 spring会自动创建动态代理
逻辑代码如下
package com.bjsxt.aop;
import org.aspectj.lang.ProceedingJoinPoint;
import org.aspectj.lang.annotation.Around;
import org.aspectj.lang.annotation.Aspect;
import org.aspectj.lang.annotation.Before;
import org.aspectj.lang.annotation.Pointcut;
import org.springframework.stereotype.Component;
@Aspect
@Component
public class LogInterceptor {
@Before("execution(public void com.bjsxt.service.save(com.bjsxt.model.User))")
public void before() {
System.out.println("method before");
}
}
具体流程如下:容器扫描 com.bjsxt 路径 ,发现 LogInterceptor 是一个 Component(组件) 而且是一个 Aspect(切面) 并且 @Before("")
所以在执行 save方法之前 会调用 切面逻辑 before() . LogInterceptor 是独立的且不受其他组件影响的逻辑块,执行与否完全自己决定.