文档章节

四大通知

n
 name_by_back_fire
发布于 2017/05/19 11:39
字数 807
阅读 2
收藏 0

1.前置通知,实现  MethodBeforeAdvice 接口,重写

            public  void  before(Method  method, Object[]  args, Object  target) throws Throwable方法

     

    import java.lang.reflect.Method;

    import org.springframework.aop.MethodBeforeAdvice;

    public class TestMethodBeforeAdvice implements MethodBeforeAdvice {

        /** arg0  方法

         * arg1 参数

         * arg2 操作对象

         * */

        @Override

        public void before(Method arg0, Object[] arg1, Object arg2) throws Throwable {

          System.out.println("前置通知:----》方法:"+arg0.getName()+"传入参数"+arg1+"操作象"+arg2);

        }

     }

2.后置通知,实现 AfterReturningAdvice  接口,重写

      public void afterReturning(Object returnValue, Method method, Object[] args, Object target) throws Throwable 方法

 

      import java.lang.reflect.Method;

      import org.springframework.aop.AfterReturningAdvice;

      public class TestAfterReturningAdvice implements AfterReturningAdvice{

            /**

             * arg0:return 的返回值

             * arg1:执行的方法对象

             * arg2:方法执行中传递过来的参数

             * arg3:执行方法的对象

             */

            @Override

            public void afterReturning(Object arg0, Method arg1, Object[] arg2, Object arg3) throws Throwable {

               System.out.println("后置通知:----》方法:"+arg1.getName()+"返回值:"+arg0+"执行方对象:"+arg3);

            }  

      }

 

3.环绕通知, 实现 MethodInterceptor  接口,重写

      public  Object  invoke(MethodInvocation  invocation) throws Throwable 方法

 

      import java.lang.reflect.Method;

      import org.aopalliance.intercept.MethodInterceptor;

      import org.aopalliance.intercept.MethodInvocation;

      public class TestMethodinterceptor implements MethodInterceptor {

          @Override

          public Object invoke(MethodInvocation invocation) throws Throwable {

              Method method = invocation.getMethod() ; //方法

              Object[] objs = invocation.getArguments() ; //参数

              Object obj = invocation.getThis() ; //操作对象

              System.out.println("环绕通知:-----》 开始: 方法:"+method.getName()+"传入的参数:"+objs+" 操作对象:"+obj);

              Object result = invocation.proceed() ;   //放行

              System.out.println("环绕通知:-----》 结束:  返回值:"+result);

              return result ;

          }

      }

 

4.异常通知,实现 ThrowsAdvice 接口,重写

         public void afterThrowing(Method  m, Object  args, Object  target,Throwable  e) 方法

 

    import java.lang.reflect.Method;

    import org.springframework.aop.ThrowsAdvice;

    public class TestThrowsAdvice implements ThrowsAdvice {

         public void afterThrowing(Method m, Object args, Object target, Throwable e) {  

                 System.out.println("异常通知:方法"+m.getName()+"发生异常,"+e.getMessage());

                 System.exit(0);

         }

     }

注意:查看ThrowsAdvice源码会发现这个接口里面没有定义方法,但是这个方法必须这么写,

 

Spring 3.X 以后版本

 

    import org.aspectj.lang.JoinPoint;

    import org.aspectj.lang.ProceedingJoinPoint;

    public class TestAdvice {

       public void before(JoinPoint joinPoint){ //前置通知

          System.out.println("操作者"+joinPoint.getTarget()+"参数             "+joinPoint.getArgs()[0]);

          System.out.println("*********************前置通知*********************");

       }

       //后置通知:当方法执行完会触发,出错则不执行

       public void afterReturning(JoinPoint joinPoint,Object obj){

            System.out.println("后置通知");

            System.out.println("返回结果:"+obj);

        }

        //最终通知

        public void after(JoinPoint joinPoint){

            System.out.println("最终通知");

            System.out.println("调用的方法"+joinPoint.getSignature());

        }

        //异常通知

        public void throwAdvice(Exception exception){

            System.out.println("--------异常通知--------");

            System.out.println("异常消息"+exception.getMessage());

        }

        //环绕通知

        public Object around(ProceedingJoinPoint proceedingJoinPoint){

            System.out.println("环绕通知开始");

            try {

              Object  obj = proceedingJoinPoint.proceed() ;

              System.out.println("环绕通知结束");

              return obj ;

            } catch (Throwable e) {

              e.printStackTrace();

            }

            return null ;

      }

  }

 

配置信息

<!--Spring3.X以前-->

<!--后置通知-->

  <bean id="afterAdvice" class="com.spring.advice.TestAfterReturningAdvice"/>

<!--前置通知-->

  <bean id="beforeAdvice" class="com.spring.advice.TestMethodBeforeAdvice"/>

<!--环绕通知-->

  <bean id="interceptorAdvice" class="com.spring.advice.TestMethodinterceptor"/>

<!--异常通知-->

  <bean id="throwsAdvice" class="com.spring.advice.TestThrowsAdvice"/>

<!--Spring3.X以后整合-->

  <bean id="advice" class="com.spring.advice.TestAdvice"/>

<!-- AOP设置 -->

<aop:config>

    <aop:pointcut expression="execution(* com.spring.service.*.*(..))" id="mycut"/>

    <aop:advisor advice-ref="afterAdvice" pointcut-ref="mycut"/>

    <aop:advisor advice-ref="beforeAdvice" pointcut-ref="mycut"/>

    <aop:advisor advice-ref="interceptorAdvice" pointcut-ref="mycut"/>

    <aop:advisor advice-ref="throwsAdvice" pointcut-ref="mycut"/>

    <!-- 新版本 -->

    <aop:aspect ref="advice">

        <aop:before method="before" pointcut-ref="mycut"/>

        <aop:after-returning method="afterReturning" returning="obj" pointcut-ref="mycut"/>

        <aop:after method="after" pointcut-ref="mycut"/>

        <aop:after-throwing method="throwAdvice" throwing="exception" pointcut-ref="mycut"/>

        <aop:around method="around" pointcut-ref="mycut"/>

     </aop:aspect>

</aop:config>

两种方法:

  Spring3.X版本以前写法思路更清晰,新版本,虽然把4个通知整合在了一起,但是,如果业务复杂的话,通知较多建议分开写,

两种方法区别不是很大,具体还得开需求

 

expression的value值

任意公共方法的执行:

  execution(public * *(..))

任何一个以“set”开始的方法的执行:

  execution(* set*(..))

AccountService 接口的任意方法的执行:

  execution(* com.xyz.service.AccountService.*(..))

定义在service包里的任意方法的执行:

  execution(* com.xyz.service.*.*(..))

定义在service包或者子包里的任意方法的执行:

  execution(* com.xyz.service..*.*(..))

 

© 著作权归作者所有

共有 人打赏支持
n
粉丝 0
博文 12
码字总数 4996
作品 0
昌平
程序员
小白入门Android必须知道的四大组件

学习App开发从布局入手之后,以能够顺利识别并搭建一个页面所需要的UI组件为目标。但是搭建好的不同界面间如何切换呢?不同界面间的数据是如何传递的呢?除了我们看到的界面,App后台还能做其...

冬风破10
01/12
0
0
微软发布 iPhone 版的 Windows Live Messenger

微软今天正式为iPhone和iPod touch发布了Windows Live Messenger应用程序,iPhone用户可以使用手机与好友进行即时通信,查看好友社交网络的状态及更新,浏览、评价好友相片,时刻了解好友的最...

红薯
2010/06/21
1K
2
12.16 游戏行业财务交流 厦门

12月16日(本周六)将在美丽的厦门组织一次游戏行业财务交流活动,活动主要信息如下: 1、时间:12月16日(本周六)全天; 2、地点:小范围活动,报名成功后单独通知; 3、主题:游戏行业财务...

上善若水
2017/12/14
0
0
Spark源码之BlockManager

BlockManager是分布式块存储管理。核心机制是每个节点存储自己的内存空间和磁盘空间。BlockManagerMaster负责与其他节点的BlockManager通信并负责块在节点间的复制。BlockInfoManager负责管理...

守望者之父
06/15
0
0
极光征文 | 参赛附录说明,帮你确立选题

「写写文章就能赢 Flico,岂不美滋滋」的极光征文活动正在火热开展,本文是活动的附录说明,简单介绍了极光的产品,并推荐了一些写作主题,如果你不知道如何下笔,就来看看吧! 附录 1:你可...

极小光
2017/12/15
0
0

没有更多内容

加载失败,请刷新页面

加载更多

python中的base64加密和解密

python中的base64加密和解密 代码如下: import base64import jsondef row_data(): content = { "buyer_nick": "家有亲亲", "payment": "109.40", "status":......

_Change_
11分钟前
0
0
常见的几种单例模式

单例模式:是一种常用的软件设计模式,在它的核心结构中值包含一个被称为单例的特殊类。一个类只有一个实例,即一个类只有一个对象实例。   对于系统中的某些类来说,只有一个实例很重要,...

rechardchensir
14分钟前
0
0
mongodb根据多个字段查询模糊查询某个值

MongoCollection<Document> collection = db.getCollection("test"); /*******************mongodb根据多个字段查询模糊查询某个值*******************/ //定义一个Basic......

开源中国封号找我
16分钟前
0
0
JSCH会大量使用服务器内存吗?会

java实现一个需求用到了jsch,发现服务器内存会被占满。 写了个50进程的jsch-sftp测试连接 put一个文件 ExecutorService fixedThreadPool = Executors.newFixedThreadPool(50);for (int j =...

just-coding
32分钟前
1
0
聊聊redis的数据结构的应用

序 本文主要研究一下redis的数据结构的应用 string 最常用的就是incr操作,比如可以用来维护用户在某个抽奖活动的剩余抽奖次数 setnx方法可以用来实现分布式锁 hashmap 可以用来存储session...

go4it
33分钟前
4
0

没有更多内容

加载失败,请刷新页面

加载更多

返回顶部
顶部