Spring Aop

<!--spring中基于XML的AOP配置步驟?

1朗兵、把通知Bean也交給spring來管理?

2、使用aop:config標(biāo)簽表明開始AOP的配置?

3撬统、使用aop:aspect標(biāo)簽表明配置切面 id屬性:是給切面提供一個唯一標(biāo)識 ref屬性:是指定通知類bean的Id轰异。

?4、在aop:aspect標(biāo)簽的內(nèi)部使用對應(yīng)標(biāo)簽來配置通知的類型

? ? ? ? ? 我們現(xiàn)在示例是讓printLog方法在切入點方法執(zhí)行之前之前:所以是前置通知? ? ? ? ? aop:before:表示配置前置通知? ? ? ? ? ? ? ? method屬性:用于指定Logger類中哪個方法是前置通知? ? ? ? ? ? ? ? pointcut屬性:用于指定切入點表達(dá)式遮怜,該表達(dá)式的含義指的是對業(yè)務(wù)層中哪些方法增強

切入點表達(dá)式的寫法:

? ? ? ? ? ? 關(guān)鍵字:execution(表達(dá)式)

? ? ? ? ? ? 表達(dá)式:

訪問修飾符? 返回值? 包名.包名.包名...類名.方法名(參數(shù)列表)

標(biāo)準(zhǔn)的表達(dá)式寫法:public void com.zk.service.impl.AccountServiceImpl.saveAccount()

訪問修飾符可以省略? void com.zk.service.impl.AccountServiceImpl.saveAccount()

返回值可以使用通配符,表示任意返回值* com.zk.service.impl.AccountServiceImpl.saveAccount()

?包名可以使用通配符鸿市,表示任意包奈泪。但是有幾級包,就需要寫幾個*.

* *.*.*.*.AccountServiceImpl.saveAccount())

?包名可以使用..表示當(dāng)前包及其子包* *..AccountServiceImpl.saveAccount()

? 類名和方法名都可以使用*來實現(xiàn)通配* *..*.*()

?????????????參數(shù)列表:

????????????????????可以直接寫數(shù)據(jù)類型: 基本類型直接寫名稱int

? ? ? ? ? ? ? ? ? ? 引用類型寫? 包名.類名的方式 ? java.lang.String

? ? ? ? ? ? ? ? 可以使用通配符表示任意類型灸芳,但是必須有參數(shù)

? ? ? ? ? ? ? ? 可以使用..表示有無參數(shù)均可,有參數(shù)可以是任意類型

? ? ? ? ? ? 全通配寫法:* *..*.*(..)

?? 實際開發(fā)中切入點表達(dá)式的通常寫法:

? ? ? ? 切到業(yè)務(wù)層實現(xiàn)類下的所有方法* com.zk.service.impl.*.*(..)

前置代碼舉例:

<!-- 配置Logger類 -->

<bean id="logger" class="com.itheima.utils.Logger">

<!--配置AOP-->

<aop:config>

? ? <!--配置切面 -->

? ? <aop:aspect id="logAdvice" ref="logger">

? ? ? ? <!-- 配置通知的類型拜姿,并且建立通知方法和切入點方法的關(guān)聯(lián)-->

? ? ? ? <aop:before method="printLog"?

pointcut="execution(* com.zk.service.impl.*.*(..))"></aop:before>

? ? </aop:aspect>

</aop:config>

配置前置 后置 異常 最終 環(huán)繞

<!--配置AOP-->

<aop:config>

? ? <!-- 配置切入點表達(dá)式 id屬性用于指定表達(dá)式的唯一標(biāo)識烙样。expression屬性用于指定表達(dá)式內(nèi)容? 此標(biāo)簽寫在aop:aspect標(biāo)簽內(nèi)部只能當(dāng)前切面使用。它還可以寫在aop:aspect外面蕊肥,此時就變成了所有切面可用? -->

? ? <aop:pointcut id="pt1" expression="execution(* com.zk.service.impl.*.*(..))"></aop:pointcut>

? ? <!--配置切面 -->

? ? <aop:aspect id="logAdvice" ref="logger">

? ? ? ? <!-- 配置前置通知:在切入點方法執(zhí)行之前執(zhí)行-->

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

? ? ? ? <!-- 配置后置通知:在切入點方法正常執(zhí)行之后值谒获。它和異常通知永遠(yuǎn)只能執(zhí)行一個-->

<aop:after-returning method="afterReturningPrintLog" pointcut-ref="pt1"></aop:after-returning>-->

? ? ? ? <!-- 配置異常通知:在切入點方法執(zhí)行產(chǎn)生異常之后執(zhí)行。它和后置通知永遠(yuǎn)只能執(zhí)行一個-->

<aop:after-throwing method="afterThrowingPrintLog" pointcut-ref="pt1"></aop:after-throwing>-->

? ? ? ? <!-- 配置最終通知:無論切入點方法是否正常執(zhí)行它都會在其后面執(zhí)行->

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

? ? ? ? <!-- 配置環(huán)繞通知 詳細(xì)的注釋請看Logger類中-->

? ? ? ? <aop:around method="aroundPringLog" pointcut-ref="pt1"></aop:around>

? ? </aop:aspect>

</aop:config>


環(huán)繞通知在Logger類中的說明

環(huán)繞通知需要明確調(diào)用切入點方法才會執(zhí)行

環(huán)繞通知代碼示例


測試代碼

基于注解的Aop配置

注解配置如下:在Loaager類上@Component 聲明創(chuàng)建對象交給Spring,

@Aspect 聲明當(dāng)前類為一個切面類

可個方法聲明PointCut的exeution的表達(dá)式供其他通知ref ? 注意:引用時方法名后需要加()壁却,例如:pt1()

用注解實現(xiàn)AOP有個問題:就是后置通知或者異常通知總在最終通知之后

'z
最終

此時在Bean.xml中需要掃描注解并打開對aop注解的支持

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市,隨后出現(xiàn)的幾起案子替劈,更是在濱河造成了極大的恐慌岩调,老刑警劉巖,帶你破解...
    沈念sama閱讀 216,843評論 6 502
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件盐肃,死亡現(xiàn)場離奇詭異爪膊,居然都是意外死亡权悟,警方通過查閱死者的電腦和手機,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,538評論 3 392
  • 文/潘曉璐 我一進店門推盛,熙熙樓的掌柜王于貴愁眉苦臉地迎上來峦阁,“玉大人,你說我怎么就攤上這事耘成±莆簦” “怎么了?”我有些...
    開封第一講書人閱讀 163,187評論 0 353
  • 文/不壞的土叔 我叫張陵瘪菌,是天一觀的道長撒会。 經(jīng)常有香客問我,道長控嗜,這世上最難降的妖魔是什么茧彤? 我笑而不...
    開封第一講書人閱讀 58,264評論 1 292
  • 正文 為了忘掉前任,我火速辦了婚禮疆栏,結(jié)果婚禮上曾掂,老公的妹妹穿的比我還像新娘。我一直安慰自己壁顶,他們只是感情好珠洗,可當(dāng)我...
    茶點故事閱讀 67,289評論 6 390
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著若专,像睡著了一般许蓖。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上调衰,一...
    開封第一講書人閱讀 51,231評論 1 299
  • 那天膊爪,我揣著相機與錄音,去河邊找鬼嚎莉。 笑死米酬,一個胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的趋箩。 我是一名探鬼主播赃额,決...
    沈念sama閱讀 40,116評論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼叫确!你這毒婦竟也來了跳芳?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 38,945評論 0 275
  • 序言:老撾萬榮一對情侶失蹤竹勉,失蹤者是張志新(化名)和其女友劉穎飞盆,沒想到半個月后,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 45,367評論 1 313
  • 正文 獨居荒郊野嶺守林人離奇死亡桨啃,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 37,581評論 2 333
  • 正文 我和宋清朗相戀三年车胡,在試婚紗的時候發(fā)現(xiàn)自己被綠了。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片照瘾。...
    茶點故事閱讀 39,754評論 1 348
  • 序言:一個原本活蹦亂跳的男人離奇死亡匈棘,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出析命,到底是詐尸還是另有隱情主卫,我是刑警寧澤,帶...
    沈念sama閱讀 35,458評論 5 344
  • 正文 年R本政府宣布鹃愤,位于F島的核電站簇搅,受9級特大地震影響,放射性物質(zhì)發(fā)生泄漏软吐。R本人自食惡果不足惜瘩将,卻給世界環(huán)境...
    茶點故事閱讀 41,068評論 3 327
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望凹耙。 院中可真熱鬧姿现,春花似錦、人聲如沸肖抱。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,692評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽意述。三九已至提佣,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間荤崇,已是汗流浹背拌屏。 一陣腳步聲響...
    開封第一講書人閱讀 32,842評論 1 269
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留术荤,地道東北人倚喂。 一個月前我還...
    沈念sama閱讀 47,797評論 2 369
  • 正文 我出身青樓,卻偏偏與公主長得像喜每,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子雳攘,可洞房花燭夜當(dāng)晚...
    茶點故事閱讀 44,654評論 2 354

推薦閱讀更多精彩內(nèi)容