本篇博文用一个稍复杂点的案例来对比一下基于XML配置与基于AspectJ注解配置的AOP编程的不同。
相关引入包等Spring AOP编程准备,请参考小编的其他博文,这里不再赘述。
案例要求:
写一个简单的实现四则运算的计算器。
加入AOP功能:日志功能;检测参数中是否有负数的功能。
废话不多说了,直接上代码:
(一)基于XML配置:
定义了一个接口类:
package com.edu.aop; public interface ArithmeticCalculator { int add(int i,int j); int sub(int i,int j); int mul(int i,int j); int div(int i,int j); }
实现类:
package com.edu.aop; public class ArithmeticCalculatorImpl implements ArithmeticCalculator { @Override public int add(int i, int j) { return i+j; } @Override public int sub(int i, int j) { return i-j; } @Override public int mul(int i, int j) { return i*j; } @Override public int div(int i, int j) { return i/j; } }
日志切片类:
package com.edu.aop; import java.util.Arrays; import org.aspectj.lang.JoinPoint; public class LoggingAspect { /** * 日志切面类 */ public void beforeMethod(JoinPoint joinPoint){ //获取方法名 String methodName=joinPoint.getSignature().getName(); //获取方法实参值列表 Object[] args=joinPoint.getArgs(); System.out.println("The method "+methodName+" begin with "+Arrays.asList(args)); } public void afterMethod(JoinPoint joinPoint){ String methodName=joinPoint.getSignature().getName(); System.out.println("The method "+methodName+" ends"); } }
检测参数中是否有负数的切片类:
package com.edu.aop; import java.util.Arrays; import org.aspectj.lang.JoinPoint; public class ValidationAspect { public void validationArgs(JoinPoint joinPoint){ String methodName=joinPoint.getSignature().getName(); Object[] args=joinPoint.getArgs(); System.out.println("待验证参数:"+Arrays.asList(args)); if(args!=null&&args.length>0){ for(int i=0;i<args.length;++i){ if(((Integer)args[i]).intValue()<0){ System.out.println("警告:方法"+methodName+"()第"+(i+1)+"个参数为负数:"+args[i]); } } } } }
xml配置文件:
<?xml version="1.0" encoding="UTF-8"?> <beans xmlns="http://www.springframework.org/schema/beans" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns:aop="http://www.springframework.org/schema/aop" xsi:schemaLocation=" http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans.xsd http://www.springframework.org/schema/aop http://www.springframework.org/schema/aop/spring-aop.xsd"> <!-- 配置bean --> <bean id="arithmetic" class="com.edu.aop.ArithmeticCalculatorImpl"></bean> <!-- 分别将切面类声明配置成一个bean --> <bean id="logging" class="com.edu.aop.LoggingAspect"></bean> <bean id="validation" class="com.edu.aop.ValidationAspect"></bean> <aop:config> <!-- 配置日志切片类 --> <aop:aspect ref="logging"> <!-- 配置前置通知 及前置通知的切入点--> <aop:before method="beforeMethod" pointcut="execution(* com.edu.aop.ArithmeticCalculatorImpl.*(..))"></aop:before> <!-- 配置后置通知及后置通知的切入点 --> <aop:after method="afterMethod" pointcut="execution(* com.edu.aop.ArithmeticCalculatorImpl.*(..))"></aop:after> </aop:aspect> <!-- 配置检测参数切片类 --> <aop:aspect ref="validation"> <!-- 配置前置通知 及前置通知的切入点--> <aop:before method="validationArgs" pointcut="execution(* com.edu.aop.ArithmeticCalculatorImpl.*(..))"></aop:before> </aop:aspect> </aop:config> </beans>
主方法检测类:
package com.edu.aop; import org.springframework.context.ApplicationContext; import org.springframework.context.support.ClassPathXmlApplicationContext; public class Main { public static void main(String[] args) { ApplicationContext act=new ClassPathXmlApplicationContext("applicationContext.xml"); ArithmeticCalculator arithmetic=(ArithmeticCalculator)act.getBean("arithmetic"); int result=arithmetic.add(10, 20); System.out.println("result:"+result); result=arithmetic.div(-36, 4); System.out.println("result:"+result); } }
运行结果:
(二)基于AspectJ注解配置的AOP编程:
未完待续。