国产成人精品久久免费动漫-国产成人精品天堂-国产成人精品区在线观看-国产成人精品日本-a级毛片无码免费真人-a级毛片毛片免费观看久潮喷

您的位置:首頁技術文章
文章詳情頁

Spring boot AOP通過XML配置文件聲明的方法

瀏覽:18日期:2023-05-09 17:24:15

通過 XML 配置文件聲明

在前兩篇博文和示例中,我們已經展示了如何通過注解配置去聲明切面,下面我們看看如何在 XML 文件中聲明切面。下面先列出 XML 中聲明 AOP 的常用元素:

AOP配置元素 用途 aop:advisor 定義AOP通知器 aop:after 定義AOP后置通知(不管被通知的方法是否執行成功) aop:after-returning 定義AOP返回通知 aop:after-throwing 定義AOP異常通知 aop:around 定義AOP環繞通知 aop:aspect 定義一個切面 aop:aspectj-autoproxy 啟用@AspectJ注解驅動的切面 aop:before 定義一個AOP前置通知 aop:config 頂層的AOP配置元素。大多數的aop:*元素必須包含在aop:config元素內 aop:declare-parents 以透明的方式為被通知的對象引入額外的接口 aop:pointcut 定義一個切點

XML 配置文件中切點指示器

在XML配置文件中,切點指示器表達式與通過注解配置的寫法基本一致,區別前面有提到,即XML文件中需要使用 “and”、“or”、“not”來表示 “且”、“或”、“非”的關系。

XML 文件配置 AOP

新建OrderXmlAop.java:

package com.example.demo.aop; public class OrderXmlAop { /** * @description 在連接點執行之前執行的通知 */ public void doBefore(){ System.out.println('阿里阿塞喲!'); } /** * @description 在連接點執行之后執行的通知(返回通知和異常通知的異常) */ public void doAfter(){ System.out.println('after!'); } /** * @description 在連接點執行之后執行的通知(返回通知) */ public void doAfterReturning(){ System.out.println('返回通知:AfterReturning'); } /** * @description 在連接點執行之后執行的通知(異常通知) */ public void doAfterThrowing(){ System.out.println('異常通知:AfterThrowing'); }}

在 Resource 目錄下新建一個配置文件 aoporder.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' 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.xsd'> <bean class='com.example.demo.service.impl.WMZServiceImpl'></bean> <bean class='com.example.demo.service.impl.ZSServiceImpl'></bean> <!-- 切面類 --> <bean class='com.example.demo.aop.OrderXmlAop'></bean> <!-- Aop配置 --> <aop:config proxy-target-class='true'> <!-- 切面 --> <aop:aspect ref='OrderXmlAop'> <!-- 前置通知: 在目標方法調用前執行 --> <aop:before pointcut='execution(public * com.example.demo.service.TakeawayService.*(..)))' method='doBefore'/> <!-- 后置通知: --> <aop:after pointcut='execution(public * com.example.demo.service.TakeawayService.*(..)))' method='doAfter'/> <!-- 返回后通知 --> <aop:after-returning pointcut='execution(public * com.example.demo.service.TakeawayService.*(..)))' method='doAfterReturning'/> <!-- 異常通知 --> <aop:after-throwing pointcut='execution(public * com.example.demo.service.TakeawayService.*(..)))' method='doAfterThrowing'/> </aop:aspect> </aop:config></beans>

新建 TakeXmlController.java

package com.example.demo.controller; import com.example.demo.entity.Response;import com.example.demo.entity.ResponseResult;import jdk.internal.org.objectweb.asm.tree.analysis.Value;import org.springframework.beans.factory.annotation.Autowired;import org.springframework.beans.factory.annotation.Qualifier;import org.springframework.context.support.ClassPathXmlApplicationContext;import org.springframework.web.bind.annotation.RequestMapping;import org.springframework.web.bind.annotation.RestController;import com.example.demo.service.TakeawayService;@RestController@RequestMapping('/api') public class TakeXmlController { ClassPathXmlApplicationContext context = new ClassPathXmlApplicationContext('aoporder.xml'); @RequestMapping('/orderxml') public ResponseResult Ordexml() { /** ** 注意 此處的getBean(name)中的name 必須要和aoporder.xml 配置的bean節點上的id 保持一致 * 如: <bean class='com.example.demo.service.impl.WMZServiceImpl'></bean> * TakeawayService wmzService=(TakeawayService)context.getBean('wmzService'); */ TakeawayService wmzService=(TakeawayService)context.getBean('wmzService'); String wmz= wmzService.Order(12); System.out.println(wmz); TakeawayService zsService=(TakeawayService)context.getBean('zsService'); String zs=zsService.Order(4396); System.out.println(zs); return Response.makeOKRsp(wmz+';'+zs); }}

運行結果:

Spring boot AOP通過XML配置文件聲明的方法

聲明環繞通知

修改OrderXmlAop.java:

package com.example.demo.aop; import org.aspectj.lang.ProceedingJoinPoint; public class OrderXmlAop { /** * @description 在連接點執行之前執行的通知 */ public void doBefore(){ System.out.println('阿里阿塞喲!'); } /** * @description 在連接點執行之后執行的通知(返回通知和異常通知的異常) */ public void doAfter(){ System.out.println('after!'); } /** * @description 在連接點執行之后執行的通知(返回通知) */ public void doAfterReturning(){ System.out.println('返回通知:AfterReturning'); } /** * @description 在連接點執行之后執行的通知(異常通知) */ public void doAfterThrowing(){ System.out.println('異常通知:AfterThrowing'); } /** * @description 在連接點執行之后執行的通知(異常通知) */ public void doAround(ProceedingJoinPoint pj) { try { System.out.println('Around 調用方法前 '); pj.proceed(); System.out.println('Around 調用方法后'); } catch (Throwable throwable) { throwable.printStackTrace(); } }}

aoporder.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' 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.xsd'> <bean class='com.example.demo.service.impl.WMZServiceImpl'></bean> <bean class='com.example.demo.service.impl.ZSServiceImpl'></bean> <!-- 切面類 --> <bean class='com.example.demo.aop.OrderXmlAop'></bean> <!-- Aop配置 --> <aop:config proxy-target-class='true'> <!-- 切面 --> <aop:aspect ref='OrderXmlAop'> <!-- 環繞通知 --> <aop:around pointcut='execution(public * com.example.demo.service.TakeawayService.*(..)))' method='doAround'/> <!-- 前置通知: 在目標方法調用前執行 --> <aop:before pointcut='execution(public * com.example.demo.service.TakeawayService.*(..)))' method='doBefore'/> <!-- 后置通知: --> <aop:after pointcut='execution(public * com.example.demo.service.TakeawayService.*(..)))' method='doAfter'/> <!-- 返回后通知 --> <aop:after-returning pointcut='execution(public * com.example.demo.service.TakeawayService.*(..)))' method='doAfterReturning'/> <!-- 異常通知 --> <aop:after-throwing pointcut='execution(public * com.example.demo.service.TakeawayService.*(..)))' method='doAfterThrowing'/> </aop:aspect> </aop:config></beans>

運行結果:

Spring boot AOP通過XML配置文件聲明的方法

結果和我們預期的一致,環繞通知通過xml配置成功。

XML 文件配置聲明切點

在上面的例子中,我們發現有切點表達式多次重復出現,那么可不可以和aspectj配置一樣,單獨聲明切點,后面復用,答案是當然可以。如下修改aoporder.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' 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.xsd'> <bean class='com.example.demo.service.impl.WMZServiceImpl'></bean> <bean class='com.example.demo.service.impl.ZSServiceImpl'></bean> <!-- 切面類 --> <bean class='com.example.demo.aop.OrderXmlAop'></bean> <!-- Aop配置 --> <aop:config proxy-target-class='true'> <!-- 切點 --> <aop:pointcut expression='execution(public * com.example.demo.service.TakeawayService.*(..)))'/> <!-- 切面 --> <aop:aspect ref='OrderXmlAop'> <!-- 環繞通知 --> <aop:around pointcut-ref='point' method='doAround'/> <!-- 前置通知: 在目標方法調用前執行 --> <aop:before pointcut-ref='point' method='doBefore'/> <!-- 后置通知: --> <aop:after pointcut-ref='point' method='doAfter'/> <!-- 返回后通知 --> <aop:after-returning pointcut-ref='point' method='doAfterReturning'/> <!-- 異常通知 --> <aop:after-throwing pointcut-ref='point' method='doAfterThrowing'/> </aop:aspect> </aop:config></beans>

修改后執行結果:

Spring boot AOP通過XML配置文件聲明的方法

XML文件配置為通知傳遞參數

修改OrderXmlAop.java

public String doAround(ProceedingJoinPoint pj,double price) { try { System.out.println('Around 調用方法前 '); pj.proceed(); if(price>=4396) { System.out.println('zs下單超過了4399,贈送一份鮮果飲匯源牌飲料'); return '爆漿牛丸和飲料'; } System.out.println('Around 調用方法后'); } catch (Throwable throwable) { throwable.printStackTrace(); } return '爆漿牛丸'; }

修改aoporder.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' 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.xsd'> <bean class='com.example.demo.service.impl.WMZServiceImpl'></bean> <bean class='com.example.demo.service.impl.ZSServiceImpl'></bean> <!-- 切面類 --> <bean class='com.example.demo.aop.OrderXmlAop'></bean> <!-- Aop配置 --> <aop:config proxy-target-class='true'> <!-- 切點 --> <aop:pointcut expression='execution(com.example.demo.service.TakeawayService.Order(double)) and args(price) and bean(zsService)'/> <!-- 切面 --> <aop:aspect ref='OrderXmlAop'> <!-- 環繞通知 --> <aop:around pointcut-ref='point' method='doAround'/> </aop:aspect> </aop:config></beans>

總結

本文主要通過XML配置文件使用 Spring AOP進行編程,和上一篇的注解方式兩者聯系起來對于剛入門的應該多多少少還是有點幫助的吧,針對于aop 通過三篇博客簡單的描述,相信大家對此都有點印象了,記錄了 AOP 的編程思想,然后介紹了 Spring 中 AOP 的相關概念,以及通過注解方式和XML配置文件兩種方式使用 Spring AOP進行編程。所以對aop的博文就簡單到這兒了,有人要問了,aop里面的代理啊還有各種各樣的,如果真要吧aop重頭到尾來一遍的話,這個系列可以單獨提出來一個專欄了,所以后面的博文應該都是圍繞連接數據庫,記錄日志,接入swagger文檔等功能相繼展開了。在此過程中,我有錯誤使用的地方,或者表達有問題,還請您及時告知,本人會在第一時間予以改正。最后在祝大家周末愉快,C Y L L

標簽: Spring
相關文章:
主站蜘蛛池模板: 欧美黑人巨大最猛性xxxxx | 最新亚洲一区二区三区四区 | 国产一区二区三区在线观看影院 | 国产精品爱久久久久久久小 | 国产精品一级片 | 欧美一区欧美二区 | 日韩亚洲成a人片在线观看 日韩亚洲精品不卡在线 | 午夜国产精品不卡在线观看 | 免费观看一级欧美大 | 河边性xxxxfreexxxxx | 亚洲人成网址在线观看 | 国产91精品在线 | 国产一区二区三区成人久久片 | 国产精品极品美女自在线看免费一区二区 | 亚洲一区二区三区免费视频 | 免费91最新地址永久入口 | 日本精品高清一区二区不卡 | 性做久久久久免费观看 | 在线观看国产精成人品 | 国产精品久久久久久一区二区 | 男女性男女刺激大片免费观看 | 国产成人理在线观看视频 | 日韩国产午夜一区二区三区 | 欧美啊啊啊| 国产精品亚洲欧美云霸高清 | 久久久久久久亚洲精品一区 | 亚洲人成亚洲精品 | 日本不卡免费高清一级视频 | 黑人一级大毛片 | 欧美日韩一区二区三区在线视频 | 兔子先生节目在线观看免费 | www.av在线免费观看 | 欧美精品久久久久久久免费观看 | 欧美视频精品在线观看 | 日本不卡免费高清视频 | 日本久久综合 | 欧美日韩精品一区二区三区高清视频 | 草草视频免费在线观看 | 国内亚州视频在线观看 | 久久男人的天堂色偷偷 | 久久免费久久 |