方式一:spring的API
<!--在spring的配置文件中配置-->
<!--注册bean-->
<bean id="log" class="com.linging.config.Log"></bean>
<bean id="afterLog" class="com.linging.config.AfterLog"></bean>
<!--配置aop-->
<aop:config>
<!--配置切入点 写expression表达式-->
<aop:pointcut id="pointcut" expression="execution(* com.linging.service.*.*(..))"></aop:pointcut>
<!--执行环绕增加-->
<aop:advisor advice-ref="log" pointcut-ref="pointcut"></aop:advisor>
<aop:advisor advice-ref="afterLog" pointcut-ref="pointcut"></aop:advisor>
</aop:config>
//实现spring提供的接口
public class AfterLog implements AfterReturningAdvice {
public void afterReturning(Object returnValue, Method method, Object[] args, Object target) throws Throwable {
System.out.println("afterReturning方法执行了。。。。");
}
}
public class Log implements MethodBeforeAdvice {
public void before(Method method, Object[] args, Object target) throws Throwable {
System.out.println("before 方法执行了。。。。");
}
}
方式二:自定义类
<!--spring配置文件中-->
<!--注册bean-->
<bean id="myAop" class="com.linging.diy.MyAop"></bean>
<aop:config>
<!--自定义切面-->
<aop:aspect ref="myAop">
<!--切入点-->
<aop:pointcut id="point" expression="execution(* com.linging.service.*.*(..))"/>
<!--通知-->
<aop:before method="before" pointcut-ref="point"></aop:before>
<aop:after method="after" pointcut-ref="point"></aop:after>
</aop:aspect>
</aop:config>
public class MyAop {
public void before(){
System.out.println("before方法执行了。。。。");
}
public void after(){
System.out.println("after方法执行了。。。。");
}
}
方式三:通过注解
<!--spring配置文件中-->
<!--注册bean-->
<bean id="annotationPointcut" class="com.linging.annotation.annotationPointcut"></bean>
<!--开启注解支持 JDK(默认 proxy-target-class="false") cglib(proxy-target-class="true")-->
<aop:aspectj-autoproxy proxy-target-class="true"></aop:aspectj-autoproxy>
@Aspect
public class annotationPointcut {
@Pointcut("execution(* com.linging.service.*.*(..))")
public void log(){}
@Before("log()")
public void before(){
System.out.println("-------before执行了。。。");
}
@After("log()")
public void after(){
System.out.println("-------after执行了。。。");
}
@Around("log()")
public void around(ProceedingJoinPoint pj) throws Throwable {
System.out.println("前。。。。");
Object proceed = pj.proceed();
System.out.println("后。。。。。");
Signature signature = pj.getSignature();
System.out.println(signature);
System.out.println(proceed);
}
}
上边注意配置的包名路径。