Aop之Xml aspect配置

前端之家收集整理的这篇文章主要介绍了Aop之Xml aspect配置前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。

上篇博文《3幅图让你了解Spring AOP》中介绍了aop通知类型,AOP的配置方式有2种方式:xml配置和AspectJ注解方式。今天我们就来实践一下xml配置方式。


我采用的jdk代理,所以首先将接口和实现类代码附上

[java] view plain copy
  1. packagecom.tgb.aop;
  2. publicinterfaceUserManager{
  3. publicStringfindUserById(intuserId);
  4. }
  5. classUserManagerImplimplementsUserManager{
  6. intuserId){
  7. System.out.println("---------UserManagerImpl.findUserById()--------");
  8. if(userId<=0){
  9. thrownewIllegalArgumentException("该用户不存在!");
  10. }
  11. return"张三";
  12. }

单独写一个Advice通知类进行测试。这个通知类可以换成安全性检测、日志管理等等。

    importorg.aspectj.lang.JoinPoint;
  1. importorg.aspectj.lang.ProceedingJoinPoint;
  2. /**
  3. *Advice通知
  4. *测试after,before,around,throwing,returningAdvice.
  5. *@authorAdmin
  6. *
  7. */
  8. classXMLAdvice{
  9. *在核心业务执行前执行,不能阻止核心业务的调用
  10. *@paramjoinPoint
  11. privatevoiddoBefore(JoinPointjoinPoint){
  12. System.out.println("-----doBefore().invoke-----");
  13. System.out.println("此处意在执行核心业务逻辑前,做一些安全性的判断等等");
  14. System.out.println("可通过joinPoint来获取所需要的内容");
  15. System.out.println("-----EndofdoBefore()------");
  16. /**
  17. *手动控制调用核心业务逻辑,以及调用前和调用后的处理,
  18. *
  19. *注意:当核心业务抛异常后,立即退出,转向AfterAdvice
  20. *执行完毕AfterAdvice,再转到ThrowingAdvice
  21. *@parampjp
  22. *@return
  23. *@throwsThrowable
  24. privateObjectdoAround(ProceedingJoinPointpjp)throwsThrowable{
  25. System.out.println("-----doAround().invoke-----");
  26. System.out.println("此处可以做类似于BeforeAdvice的事情");
  27. //调用核心逻辑
  28. ObjectretVal=pjp.proceed();
  29. System.out.println("此处可以做类似于AfterAdvice的事情");
  30. System.out.println("-----EndofdoAround()------");
  31. returnretVal;
  32. *核心业务逻辑退出后(包括正常执行结束和异常退出),执行此Advice
  33. voiddoAfter(JoinPointjoinPoint){
  34. System.out.println("-----doAfter().invoke-----");
  35. System.out.println("此处意在执行核心业务逻辑之后,做一些日志记录操作等等");
  36. System.out.println("-----EndofdoAfter()------");
  37. *核心业务逻辑调用正常退出后,不管是否有返回值,正常退出后,均执行此Advice
  38. *@paramjoinPoint
  39. */
  40. voiddoReturn(JoinPointjoinPoint){
  41. System.out.println("-----doReturn().invoke-----");
  42. System.out.println("此处可以对返回值做进一步处理");
  43. System.out.println("可通过joinPoint来获取所需要的内容");
  44. System.out.println("-----EndofdoReturn()------");
  45. *核心业务逻辑调用异常退出后,执行此Advice,处理错误信息
  46. *@paramex
  47. voiddoThrowing(JoinPointjoinPoint,Throwableex){
  48. System.out.println("-----doThrowing().invoke-----");
  49. System.out.println("错误信息:"+ex.getMessage());
  50. System.out.println("此处意在执行核心业务逻辑出错时,捕获异常,并可做一些日志记录操作等等");
  51. System.out.println("-----EndofdoThrowing()------");
  52. }

只有Advice还不行,还需要在application-config.xml中进行配置:

[html]
    <?xmlversion="1.0"encoding="UTF-8"?>
  1. <beansxmlns="http://www.springframework.org/schema/beans"
  2. xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
  3. xmlns:aop="http://www.springframework.org/schema/aop"
  4. xmlns:tx="http://www.springframework.org/schema/tx"
  5. xsi:schemaLocation="http://www.springframework.org/schema/beanshttp://www.springframework.org/schema/beans/spring-beans-2.0.xsd
  6. http://www.springframework.org/schema/aophttp://www.springframework.org/schema/aop/spring-aop-2.0.xsd
  7. http://www.springframework.org/schema/txhttp://www.springframework.org/schema/tx/spring-tx-2.0.xsd">
  8. beanid="userManager"class="com.tgb.aop.UserManagerImpl"/>
  9. <!--<beanid="aspcejHandler"class="com.tgb.aop.AspceJAdvice"/>-->
  10. beanid="xmlHandler"class="com.tgb.aop.XMLAdvice"/>
  11. aop:config>
  12. aop:aspectid="aspect"ref="xmlHandler"aop:pointcutid="pointUserMgr"expression="execution(*com.tgb.aop.*.find*(..))"aop:beforemethod="doBefore"pointcut-ref="pointUserMgr"aop:aftermethod="doAfter"pointcut-ref="pointUserMgr"aop:aroundmethod="doAround"pointcut-ref="pointUserMgr"aop:after-returningmethod="doReturn"pointcut-ref="pointUserMgr"aop:after-throwingmethod="doThrowing"throwing="ex"pointcut-ref="pointUserMgr"</aop:aspectbeans>

编一个客户端类进行测试一下:

    importorg.springframework.beans.factory.beanfactory;
  1. importorg.springframework.context.support.ClassPathXmlApplicationContext;
  2. classClient{
  3. staticvoidmain(String[]args){
  4. beanfactoryfactory=newClassPathXmlApplicationContext("applicationContext.xml");
  5. UserManageruserManager=(UserManager)factory.getBean("userManager");
  6. //可以查找张三
  7. userManager.findUserById(1);
  8. System.out.println("=====我==是==分==割==线=====");
  9. try{
  10. //查不到数据,会抛异常,异常会被AfterThrowingAdvice捕获
  11. 0);
  12. }catch(IllegalArgumentExceptione){
  13. }

结果如图:


值得注意的是Around与Before和After的执行顺序。3者的执行顺序取决于在xml中的配置顺序。图中标记了3块,分别对应Before,Around,After。其中②中包含有③。这是因为aop:after配置到了aop:around的前面,如果2者调换一下位置,这三块就会分开独立显示。如果配置顺序是aop:after -> aop:around ->aop:before,那么①和③都会包含在②中。这种情况的产生是由于Around的特殊性,它可以做类似于Before和After的操作。当安全性的判断不通过时,可以阻止核心业务逻辑的调用,这是Before做不到的。



使用xml可以对aop进行集中配置。很方便而简单。可以对所有的aop进行配置,当然也可以分开到单独的xml中进行配置。当需求变动时,不用修改代码,只要重新配置aop,就可以完成修改操作。

猜你在找的XML相关文章