Spring基于XML實現(xiàn)Aop
更新時間:2021年07月16日 11:35:22 作者:寧在春
這篇文章主要介紹了Spring中基于xml的AOP的詳細(xì)步驟,本文通過實例代碼給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下
項目結(jié)構(gòu)
具體步驟
1、創(chuàng)建maven 項目 導(dǎo)入依賴 創(chuàng)建好項目結(jié)構(gòu)
<dependencies> <dependency> <groupId>org.projectlombok</groupId> <artifactId>lombok</artifactId> <version>1.18.18</version> </dependency> <dependency> <groupId>junit</groupId> <artifactId>junit</artifactId> <version>4.12</version> <scope>test</scope> </dependency> <dependency> <groupId>org.springframework</groupId> <artifactId>spring-context</artifactId> <version>5.3.4</version> </dependency> <dependency> <groupId>org.springframework</groupId> <artifactId>spring-beans</artifactId> <version>5.3.4</version> </dependency> <dependency> <groupId>org.springframework</groupId> <artifactId>spring-core</artifactId> <version>5.3.4</version> </dependency> <dependency> <groupId>org.springframework</groupId> <artifactId>spring-expression</artifactId> <version>5.3.4</version> </dependency> <dependency> <groupId>org.springframework</groupId> <artifactId>spring-aop</artifactId> <version>5.3.4</version> </dependency> <dependency> <groupId>org.aspectj</groupId> <artifactId>aspectjweaver</artifactId> <version>1.9.6</version> </dependency> <dependency> <groupId>org.aspectj</groupId> <artifactId>aspectjrt</artifactId> <version>1.9.6</version> </dependency> </dependencies>
2、寫一個TestDao接口 及實現(xiàn)類
/** * @version 1.0 * @author: crush * @date: 2021-03-05 10:26 */ public interface TestDao { public void sayHello(); public void save(); public void modify(); public void delete(); }
/** * @version 1.0 * @author: crush * @date: 2021-03-05 10:27 */ public class TestDaoImpl implements TestDao { public void sayHello() { System.out.println("正在執(zhí)行的方法-->武漢加油!中國加油!"); } public void save() { System.out.println("正在執(zhí)行的方法-->保存"); } public void modify() { System.out.println("正在執(zhí)行的方法-->修改"); } public void delete() { System.out.println("正在執(zhí)行的方法-->刪除"); } }
3、編寫切面類
/** * @version 1.0 * @author: crush * @date: 2021-03-10 17:12 */ public class MyAspectXml { /** * 前置通知 使用JoinPoint 接口作為參數(shù)獲得目標(biāo)對象的信息 **/ public void before(JoinPoint jp){ System.out.print("前置通知:模擬權(quán)限控制 "); System.out.println("目標(biāo)對象:"+jp.getTarget()+",被增強的方法:"+jp.getSignature().getName()); } public void afterReturning(JoinPoint jp){ System.out.print("后置返回通知:"+"模擬刪除臨時文件" ); System.out.println(",被增強的方法"+jp.getSignature().getName()); } public Object around(ProceedingJoinPoint pjp) throws Throwable { System.out.println("環(huán)繞開始:執(zhí)行目標(biāo)方法前,模擬開啟事務(wù)"); Object obj = pjp.proceed(); System.out.println("環(huán)繞結(jié)束:執(zhí)行目標(biāo)方法后,模擬關(guān)閉事務(wù)"); return obj; } public void except(Throwable throwable){ System.out.println("異常通知:"+"程序執(zhí)行異常"+throwable.getMessage()); } public void after(){ System.out.println("最終通知:釋放資源"); } }``` ### 4、application.xml文件 ```xml <?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" xmlns:context="http://www.springframework.org/schema/context" xsi:schemaLocation="http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans.xsd http://www.springframework.org/schema/aop https://www.springframework.org/schema/aop/spring-aop.xsd http://www.springframework.org/schema/context https://www.springframework.org/schema/context/spring-context.xsd"> <!-- <aop:aspectj-autoproxy /> 聲明自動為spring容器中那些配置@aspectJ切面的bean創(chuàng)建代理,織入切面。 proxy-target-class屬性,默認(rèn)為false,表示使用jdk動態(tài)代理織入增強, 為true時: 表示使用CGLib動態(tài)代理技術(shù)織入增強。 --> <aop:aspectj-autoproxy proxy-target-class="true"/> <bean id="testDaoImpl" class="com.dao.TestDaoImpl"/> <bean id="myAspectXML" class="com.aspect.MyAspectXml"/> <!-- <bean id="myAspectXML2" class="com.aspect.MyAspectXml2"/>--> <!-- 補充:<aop:pointcut>如果位于<aop:aspect>元素中,則命名切點只能被當(dāng)前<aop:aspect>內(nèi)定義的元素訪問到, 為了能被整個<aop:config>元素中定義的所有增強訪問,則必須在<aop:config>下定義切點。 --> <aop:config> <!--切入點 execution 表達(dá)式 通過這個表達(dá)式篩選連接點 --> <aop:pointcut id="myPointCut" expression="execution(* com.dao.*.*(..))"/> <aop:aspect ref="myAspectXML"> <!--aop:after 是表示 這個方法是那種通知類型after 是方法之后 method="after" 這個after是切面類中的方法 --> <aop:after method="after" pointcut-ref="myPointCut"/> <aop:before method="before" pointcut-ref="myPointCut"/> <aop:after-returning method="afterReturning" pointcut-ref="myPointCut"/> <aop:after-throwing method="except" throwing="throwable" pointcut-ref="myPointCut"/> <aop:around method="around" pointcut-ref="myPointCut"/> </aop:aspect> </aop:config> </beans>
測試
@Test public void Test(){ ApplicationContext applicationContext = new ClassPathXmlApplicationContext("applicationContext.xml"); TestDao testDao = applicationContext.getBean("testDaoImpl", TestDaoImpl.class); testDao.save(); /** * 輸出: * 前置通知:模擬權(quán)限控制 目標(biāo)對象:com.dao.TestDaoImpl@704f1591,被增強的方法:save * 環(huán)繞開始:執(zhí)行目標(biāo)方法前,模擬開啟事務(wù) * 正在執(zhí)行的方法-->保存 * 環(huán)繞結(jié)束:執(zhí)行目標(biāo)方法后,模擬關(guān)閉事務(wù) * 后置返回通知:模擬刪除臨時文件,被增強的方法save * 最終通知:釋放資源 */ }
總結(jié)
本篇文章就到這里了,希望能給你帶來幫助,也希望能夠您能夠關(guān)注腳本之家的更多內(nèi)容!
相關(guān)文章
如何自定義Mybatis-Plus分布式ID生成器(解決ID長度超過JavaScript整數(shù)安全范圍問題)
MyBatis-Plus默認(rèn)生成的是 64bit 長整型,而 JS 的 Number 類型精度最高只有 53bit,這篇文章主要介紹了如何自定義Mybatis-Plus分布式ID生成器(解決ID長度超過JavaScript整數(shù)安全范圍問題),需要的朋友可以參考下2024-08-08java中Servlet監(jiān)聽器的工作原理及示例詳解
這篇文章主要介紹了java中Servlet監(jiān)聽器的工作原理及示例詳解。Servlet監(jiān)聽器用于監(jiān)聽一些重要事件的發(fā)生,監(jiān)聽器對象可以在事情發(fā)生前、發(fā)生后可以做一些必要的處理。感興趣的可以來了解一下2020-07-07