|
真爱的事业和真正的爱情一生只有一次,都值得我们温柔地相待,因为那种感觉是永远都无法复制的, 这世界真正属于你的东西其实并不多,你不好好珍惜,它便会离你而去,包括机遇,包括爱情,包括生命。 不要找任何理由, 当幸福在你身边的时候就抓住它,你就一定会很幸福! |
时 间 记 忆 |
« | September 2025 | » | 日 | 一 | 二 | 三 | 四 | 五 | 六 | | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10 | 11 | 12 | 13 | 14 | 15 | 16 | 17 | 18 | 19 | 20 | 21 | 22 | 23 | 24 | 25 | 26 | 27 | 28 | 29 | 30 | | | | | |
|
blog名称:玻璃杯中的花生壳 日志总数:162 评论数量:249 留言数量:1 访问次数:826995 建立时间:2004年11月4日 |
 | | |
|
|
1.首先我们来创建一个自己的interceptor 这个类必须继承org.aopalliance.intercept. MethodInterceptor接口。Spring的AOP框架就是参照aopalliance这个标准实现的,所以我们的MyInterceptor要继承这个标准中的接口。 这个接口只有一个要求实现的方法: public Object invoke(MethodInvocation methodInvocation) throws Throwable; 下面是我们的MyIntercptor: public class MyInterceptor implements MethodInterceptor { private final Log logger = LogFactory.getLog(getClass()); public Object invoke(MethodInvocation methodInvocation) throws Throwable { logger.info("Beginning method (1): " + methodInvocation.getMethod().getDeclaringClass() + "." + methodInvocation.getMethod().getName() + "()"); long startTime = System.currentTimeMillis(); try{ Object result = methodInvocation.proceed(); return result; }finally{ logger.info("Ending method (1): " + methodInvocation.getMethod().getDeclaringClass() + "." + methodInvocation.getMethod().getName() + "()"); logger.info("Method invocation time (1): " + (System.currentTimeMillis() - startTime) + " ms."); } } } 对于上面的代码需要说明的是下面两行代码: Object result = methodInvocation.proceed(); return result; 整个程序的流程是这样的: 1,先是执行在Object result = methodInvocation.proceed();前面的代码; 2,接着执行Object result = methodInvocation.proceed();,它把执行控制权交给了interceptor stack(拦截器栈)内的下一个interceptor,如果没有了就交给真正的业务方法; 3,然后执行return result;之前的代码; 4,最后执行return result;,它把控制权交回它之上的interceptor,如果没有了就退出interceptor stack。 2.写出我们的业务对象及其接口 为了方便我们的业务接口只有一个hello方法: public interface BusinessInterface { public void hello(); } 业务对象的代码如下: public class BusinessInterfaceImpl implements BusinessInterface{ public void hello() { System.out.println("hello Spring AOP."); } } 3.接下来,我们来看看如何使用我们的写的interceptor 我们把业务对象作为AOP的target: <bean id="businessTarget" class="com.rst.spring.testaop.BusinessInterfaceImpl"/> 接着在bean定义中声明interceptor: <bean id="myInterceptor" class="com.rst.spring.testaop.MyInterceptor"/> 最后,我们来声明真正的业务对象,通过使用它的接口以及Spring的ProxyFactoryBean: <bean id="businessBean" class="org.springframework.aop.framework.ProxyFactoryBean"> <property name="proxyInterfaces"> <value>com.rst.spring.testaop.BusinessInterface</value> </property> <property name="interceptorNames"> <list> <value>myInterceptor</value> <value>businessTarget</value> </list> </property> </bean> 这里需要说明两点: proxyInterfaces:就是我们的业务对象的实际接口; interceptorNames:定义了所有interceptors的执行顺序,其中业务对象的target作为list的最后一个。记着一定要把业务对象的target放到list中,否则你的业务对象就不会工作。 4.最后,写我们的测试类 ClassPathResource resource = new ClassPathResource("com/rst/spring/testaop/aop_bean.xml"); XmlBeanFactory beanFactory = new XmlBeanFactory(resource); BusinessInterface businessBean = (BusinessInterface) beanFactory.getBean("businessBean"); businessBean.hello(); 一切正常就可以在log上看到相应的信息了。 以下是附件源代码的执行效果: 2004-09-08 16:04:51,210 INFO - Beginning method (1): interface com.rst.spring.testaop.BusinessInterface.hello() 2004-09-08 16:04:51,210 INFO - Beginning method (2): interface com.rst.spring.testaop.BusinessInterface.hello() hello Spring AOP. 2004-09-08 16:04:51,210 INFO - Ending method (2): interface com.rst.spring.testaop.BusinessInterface.hello() 2004-09-08 16:04:51,210 INFO - Ending method (1): interface com.rst.spring.testaop.BusinessInterface.hello() 2004-09-08 16:04:51,210 INFO - Method invocation time (1): 0 ms. 源代码需要spring.jar, aopallience.jar, commons-logging.jar。 |
|
| | |
|