基于spring中的aop簡(jiǎn)單實(shí)例講解
aop,即面向切面編程,面向切面編程的目標(biāo)就是分離關(guān)注點(diǎn),比如:一個(gè)騎士只需要關(guān)注守護(hù)安全,或者遠(yuǎn)征,而騎士輝煌一生的事跡由誰(shuí)來(lái)記錄和歌頌?zāi)?,?dāng)然不會(huì)是自己了,這個(gè)完全可以由詩(shī)人去歌頌,比如當(dāng)騎士出征的時(shí)候詩(shī)人可以去歡送,當(dāng)騎士英勇?tīng)奚臅r(shí)候,詩(shī)人可以寫(xiě)詩(shī)歌頌騎士的一生。那么騎士只需要關(guān)注怎么打仗就好了。而詩(shī)人也只需要關(guān)注寫(xiě)詩(shī)歌頌和歡送就好了,那么這樣就把功能分離了。所以可以把詩(shī)人當(dāng)成一個(gè)切面,當(dāng)騎士出征的前后詩(shī)人分別負(fù)責(zé)歡送和寫(xiě)詩(shī)歌頌(記錄)。而且,這個(gè)切面可以對(duì)多個(gè)騎士或者明人使用,并不只局限于一個(gè)騎士。這樣,既分離了關(guān)注點(diǎn),也減低了代碼的復(fù)雜程度。
代碼示例如下:
騎士類:
package com.cjh.aop2;
/**
* @author Caijh
*
* 2017年7月11日 下午3:53:19
*/
public class BraveKnight {
public void saying(){
System.out.println("我是騎士");
}
}
詩(shī)人類:
package com.cjh.aop2;
/**
* @author Caijh
*
* 2017年7月11日 下午3:47:04
*/
public class Minstrel {
public void beforSay(){
System.out.println("前置通知");
}
public void afterSay(){
System.out.println("后置通知");
}
}
spring配置文件:
<?xml version="1.0" encoding="UTF-8"?> <beans xmlns="http://www.springframework.org/schema/beans" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns:aop="http://www.springframework.org/schema/aop" xsi:schemaLocation="http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans.xsd http://www.springframework.org/schema/aop http://www.springframework.org/schema/aop/spring-aop-4.3.xsd"> <!-- 目標(biāo)對(duì)象 --> <bean id="knight" class="com.cjh.aop2.BraveKnight"/> <!-- 切面bean --> <bean id="mistrel" class="com.cjh.aop2.Minstrel"/> <!-- 面向切面編程 --> <aop:config> <aop:aspect ref="mistrel"> <!-- 定義切點(diǎn) --> <aop:pointcut expression="execution(* *.saying(..))" id="embark"/> <!-- 聲明前置通知 (在切點(diǎn)方法被執(zhí)行前調(diào)用)--> <aop:before method="beforSay" pointcut-ref="embark"/> <!-- 聲明后置通知 (在切點(diǎn)方法被執(zhí)行后調(diào)用)--> <aop:after method="afterSay" pointcut-ref="embark"/> </aop:aspect> </aop:config> </beans>
測(cè)試代碼:
package com.cjh.aop2;
import org.springframework.context.ApplicationContext;
import org.springframework.context.support.ClassPathXmlApplicationContext;
/**
* @author Caijh
*
* 2017年7月11日 下午4:02:04
*/
public class Test {
public static void main(String[] args) {
ApplicationContext ac = new ClassPathXmlApplicationContext("com/cjh/aop2/beans.xml");
BraveKnight br = (BraveKnight) ac.getBean("knight");
br.saying();
}
}
執(zhí)行結(jié)果如下:
前置通知
我是騎士
后置通知
=====================================================
aop(面向切面編程)的好處就是,當(dāng)執(zhí)行了我們主要關(guān)注的行為(騎士類對(duì)象),也就是切點(diǎn),那么切面(詩(shī)人對(duì)象)就會(huì)自動(dòng)為我們進(jìn)行服務(wù),無(wú)需過(guò)多關(guān)注。如上測(cè)試代碼,我們只調(diào)用了BraveKnight類的saying()方法,它就自己在saying方法前執(zhí)行了前置通知方法,在執(zhí)行完saying之后就自動(dòng)執(zhí)行后置通知。通過(guò)這樣我們可以做權(quán)限設(shè)置和日志處理。
補(bǔ)充:pointcut執(zhí)行方法書(shū)寫(xiě)格式如下

工程目錄結(jié)構(gòu):

如果運(yùn)行過(guò)程中出現(xiàn)nofoundclass的錯(cuò)誤,一般是少了:aspectjweaver.jar這個(gè)包,需要下載
以上這篇基于spring中的aop簡(jiǎn)單實(shí)例講解就是小編分享給大家的全部?jī)?nèi)容了,希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。
相關(guān)文章
SpringCloud Gateway加載斷言predicates與過(guò)濾器filters的源碼分析
這篇文章主要介紹了SpringCloud Gateway加載斷言predicates與過(guò)濾器filters的詳細(xì)過(guò)程,本文通過(guò)源碼給大家解析的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2021-05-05
idea?Maven?插件?docker-maven-plugin?打包docker鏡像上傳到遠(yuǎn)程倉(cāng)庫(kù)的過(guò)程詳解
這篇文章主要介紹了idea Maven插件docker-maven-plugin打包docker鏡像上傳到遠(yuǎn)程倉(cāng)庫(kù),本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2023-05-05
Java 實(shí)現(xiàn)分布式服務(wù)的調(diào)用鏈跟蹤
分布式服務(wù)中完成某一個(gè)業(yè)務(wù)動(dòng)作,需要服務(wù)之間的相互協(xié)作才能完成,在這一次動(dòng)作引起的多服務(wù)的聯(lián)動(dòng)我們需要用1個(gè)唯一標(biāo)識(shí)關(guān)聯(lián)起來(lái),關(guān)聯(lián)起來(lái)就是調(diào)用鏈的跟蹤。本文介紹了Java 實(shí)現(xiàn)分布式服務(wù)的調(diào)用鏈跟蹤的步驟2021-06-06
Map映射LinkedHashSet與LinkedHashMap應(yīng)用解析
這篇文章主要為大家介紹了Map映射LinkedHashSet與LinkedHashMap的應(yīng)用解析,有需要的朋友可以借鑒參考下,希望能夠有所幫助祝大家多多進(jìn)步2022-03-03
springMVC不掃描controller中的方法問(wèn)題
這篇文章主要介紹了springMVC不掃描controller中的方法問(wèn)題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2022-02-02

