afrag  
          記錄學(xué)習(xí)和成長的歷程
          日歷
          <2009年8月>
          2627282930311
          2345678
          9101112131415
          16171819202122
          23242526272829
          303112345
          統(tǒng)計(jì)
          • 隨筆 - 9
          • 文章 - 5
          • 評論 - 2
          • 引用 - 0

          導(dǎo)航

          常用鏈接

          留言簿

          隨筆分類

          隨筆檔案

          文章檔案

          搜索

          •  

          積分與排名

          • 積分 - 10292
          • 排名 - 2368

          最新評論

          閱讀排行榜

          評論排行榜

           

          在Spring 的AOP中,如果一個(gè)Proxy同時(shí)實(shí)現(xiàn)MethodBeforeAdvice、AfterReturningAdvice和MethodInterceptor接口,那么這三個(gè)Advice的執(zhí)行順序是什么樣的呢?
          經(jīng)過試驗(yàn),是和xml文件中的定義順序有關(guān)的。
          如果Proxy的接口實(shí)現(xiàn)定義為
          ?????
          ?????????
          ??????????? MethodBeforeAdvice
          ??????????? AfterReturningAdvice
          ??????????? MethodInterceptor
          ?????????

          ?????

          那么執(zhí)行的結(jié)果是
          MethodBeforeAdvice

          MethodInterceptor: before call

          Really method excuting

          MethodInterceptor: after call

          AfterReturningAdvice

          也就是說,執(zhí)行順序是:MethodBeforeAdvice,MethodInterceptor的調(diào)用前的部分,目標(biāo)方法,MethodInterceptor的調(diào)用后的部分,AfterReturningAdvice。

          如果proxy的定義是
          ?????
          ?????????
          ??????????? MethodBeforeAdvice
          ??????????? MethodInterceptor
          ??????????? AfterReturningAdvice
          ?????????

          ?????

          執(zhí)行的結(jié)果是
          MethodBeforeAdvice

          MethodInterceptor: before call

          Really method excuting

          AfterReturningAdvice

          MethodInterceptor: after call
          也就是說,執(zhí)行的順序是:MethodBeforeAdvice,MethodInterceptor的調(diào)用前的部分,目標(biāo)方法,AfterReturningAdvice,MethodInterceptor的調(diào)用后的部分。

          如果proxy的定義是
          ?????
          ?????????
          ??????????? MethodInterceptor
          ??????????? MethodBeforeAdvice
          ??????????? AfterReturningAdvice
          ?????????

          ?????

          執(zhí)行的結(jié)果是:
          MethodInterceptor: before call

          MethodBeforeAdvice

          Really method excuting

          AfterReturningAdvice

          MethodInterceptor: after call
          也就是說,執(zhí)行的順序是:MethodInterceptor的調(diào)用前的部分,MethodBeforeAdvice,目標(biāo)方法,AfterReturningAdvice,MethodInterceptor的調(diào)用后的部分。
          以上的順序是在springframework 1.2.5中測試的。

          posted on 2005-11-02 18:10 afrag 閱讀(3729) 評論(1)  編輯  收藏 所屬分類: Java隨想
          評論:
          • # re: Spring AOP中MethodBeforeAdvice、AfterReturningAdvice和MethodInterceptor的執(zhí)行順序  jadmin Posted @ 2009-08-29 00:33
            是這樣的嗎?  回復(fù)  更多評論   

           
          Copyright © afrag Powered by: 博客園 模板提供:滬江博客
          主站蜘蛛池模板: 九龙坡区| 周至县| 建平县| 板桥市| 芜湖县| 民和| 铜川市| 汉川市| 金山区| 延安市| 宜阳县| 门头沟区| 阳新县| 金塔县| 郎溪县| 绥德县| 休宁县| 临武县| 米脂县| 浪卡子县| 建宁县| 兴山县| 竹溪县| 新干县| 福建省| 上虞市| 肇源县| 洪湖市| 宝山区| 漳浦县| 翁牛特旗| 额济纳旗| 鄂温| 玉门市| 肥城市| 广宗县| 潼南县| 永登县| 阳高县| 曲水县| 鄂托克旗|