自拍偷在线精品自拍偷,亚洲欧美中文日韩v在线观看不卡

Spring AOP學(xué)習(xí)筆記

開發(fā) 后端
本文將詳細(xì)介紹如何通過Spring.AOP特性實(shí)現(xiàn)異常的統(tǒng)一處理,以及其中中括號(hào)括起來的前三個(gè)參數(shù)是可選的,返回值可以是任意數(shù)據(jù)類型。

通常我們對(duì)于異常的處理方式都是大同小異的,要么直接捕獲并處理,要么讓它拋向上一層,要么就是記錄到日志里,或者發(fā)郵件提供管理員,但這樣下來一個(gè)項(xiàng)目中便會(huì)到處充斥著 try/catch ,并且 catch 中的代碼基本類似,于是我們聞到的其中難聞的壞味道。

本文將介紹如何通過 Spring.AOP 特性實(shí)現(xiàn)異常的統(tǒng)一處理,如果我們需要在異常發(fā)生時(shí)做一些操作的話我們就必須實(shí)現(xiàn) Spring.Aop.IThrowsAdvice,該接口沒有任何實(shí)現(xiàn)方法,是一個(gè)空接口,它僅僅做為一個(gè)標(biāo)記接口而存在,但實(shí)現(xiàn)了 IThrowsAdvice 接口的類必須定義至少一個(gè) AfterThrowing 方法,方法的簽名如下:AfterThrowing([MethodInfo method, Object[] args, Object target], Exception subclass);

其中中括號(hào)括起來的前三個(gè)參數(shù)是可選的,返回值可以是任意數(shù)據(jù)類型。 Spring.Aop.Framework.Adapter.ThrowsAdviceInterceptor 類實(shí)現(xiàn)對(duì)實(shí)現(xiàn)了 Spring.Aop.IThrowsAdvice 派生類中的方法依賴注入,其中的 ThrowsAdviceInterceptor() 方法檢查 Spring.Aop.IThrowsAdvice 的派生類是否定義了至少一個(gè)異常處理方法,如果沒有則拋出 ArgumentException 異常,MapAllExceptionHandlingMethods()方法則在定義好的重載方法中查找出異常類型與最后一個(gè)參數(shù)所定義的類型中最接近的方法,而且我們不應(yīng)該在其中實(shí)現(xiàn)了兩個(gè)相同異常類型的方法,即使他們的參數(shù)數(shù)目不同,否則也將拋出 ArgumentException 異常。

[下面引用自《Spring 技術(shù)手冊(cè)》第4章 P94 頁(yè)中的一段話]注意到當(dāng)異常發(fā)生時(shí), Throw Advice 的任務(wù)只是執(zhí)行對(duì)應(yīng)的方法,您并不能在 Throw Advice 中將異常處理掉,在 Throw Advice 執(zhí)行完畢后,原告的異常仍將傳播至應(yīng)用程序之中, Throw Advice 并不介入應(yīng)用程序的異常處理,異常處理仍舊是應(yīng)用程序本身所要負(fù)責(zé)的,如果想要在 Throw Advice 處理時(shí)中止應(yīng)用程序的處理流程,作法是拋出其它的異常。

接下來看個(gè) Throws Advice 的實(shí)際例子,首先定義 IHello 接口:

  1. using System;  
  2.     namespace TestThrowAdvice  
  3.     {  
  4.         public interface IHello  
  5.         {  
  6.             void Hello(string name);  
  7.         }  
  8.     } 

接著定義一個(gè) HelloSpeaker 類來實(shí)現(xiàn) IHello 接口,并在 Hello() 方法中模擬程序發(fā)生錯(cuò)誤時(shí)的異常拋出:

  1. using System;  
  2.     namespace TestThrowAdvice  
  3.     {  
  4.         public class HelloSpeaker : IHello  
  5.         {  
  6.             public void Hello(string name)  
  7.             {  
  8.                 Console.WriteLine("Hello, " + name);  
  9.                 //抱歉! 程序錯(cuò)誤! 發(fā)生異常 XD  
  10.                 throw new Exception("發(fā)生異常");  
  11.             }  
  12.         }  
  13.     } 

如果您需要在應(yīng)用程序拋出異常時(shí),介入 Throw Advice 提供一些服務(wù),例如記錄一些異常信息,則可以實(shí)現(xiàn) Spring.Aop.IThrowsAdvice 接口,在這個(gè)例子中我使用了 log4net 組件來實(shí)現(xiàn)日志的記錄:

  1. using System;  
  2. using Spring.Aop;  
  3. using log4net;  
  4. using log4net.Core;  
  5. using System.Reflection;  
  6. [assembly: log4net.Config.XmlConfigurator(Watch = true)]  
  7. namespace TestThrowAdvice  
  8. {  
  9.    public class SomeThrowAdvice : IThrowsAdvice  
  10.   {  
  11.       private ILog logger;  
  12.       public SomeThrowAdvice()  
  13.       {  
  14.          logger = LogManager.GetLogger(this.GetType());  
  15.       }  
  16.       public void AfterThrowing(MethodInfo method, Object[] args, Object target, Exception exception)  
  17.       {  
  18.          // 記錄異常  
  19.         logger.Info("記錄異常", exception);  
  20.       }  
  21.    }  
  22.  } 

接著在配置文件(我這里使用了獨(dú)立配置文件)中寫下以下的定義,讓 Throw Advice 在異常發(fā)生時(shí)提供記錄服務(wù):

  1. xml version="1.0" encoding="utf-8"?> 
  2.     <objects xmlns="http://www.Springframework.net" xmlns:xsi=                                      "http://www.w3.org/2001/XMLSchema-instance" 
  3.              xsi:schemaLocation="http://www.Springframework.net  
  4.              http://www.Springframework.net/xsd/Spring-objects.xsd"> 
  5.       <object id="SomeThrowAdvice" type="TestThrowAdvice.                              SomeThrowAdvice, TestThrowAdvice" /> 
  6.       <object id="HelloSpeaker" type="TestThrowAdvice.HelloSpeaker,                                                    TestThrowAdvice" /> 
  7.       <object id="HelloProxy" type="Spring.Aop.Framework.                                                 ProxyFactoryObject, Spring.Aop" > 
  8.         <property name="ProxyInterfaces"> 
  9.           <list> 
  10.             <value>TestThrowAdvice.IHello,TestThrowAdvicevalue> 
  11.           list> 
  12.         property> 
  13.         <property name="Target"> 
  14.           <ref object="HelloSpeaker" /> 
  15.         property> 
  16.         <property name="InterceptorNames"> 
  17.           <list> 
  18.             <value>SomeThrowAdvicevalue> 
  19.           list> 
  20.         property> 
  21.       object> 
  22.     objects> 

最后剩下我們的程序入口 Main() 函數(shù)了:

  1. using System;  
  2. using Spring.Context;  
  3. using Spring.Context.Support;  
  4.     namespace TestThrowAdvice  
  5.     {  
  6.         public class Program  
  7.         {  
  8.             static void Main(string[] args)  
  9.             {  
  10.                 log4net.Config.XmlConfigurator.Configure();  
  11.                 IApplicationContext context = new XmlApplicationContext(@"../../SpringNet.xml");  
  12.                 IHello helloProxy = (IHello)context.GetObject("HelloProxy");  
  13.                 try  
  14.                 {  
  15.                     helloProxy.Hello("Justin");  
  16.                 }  
  17.                 catch (Exception ex)  
  18.                 {  
  19.                     // 應(yīng)用程序的異常處理  
  20.                     Console.WriteLine(ex.Message);  
  21.                 }  
  22.             }  
  23.         }  
  24.     } 

【編輯推薦】

  1. Spring控制反轉(zhuǎn)(IoC)容器
  2. Spring is coming
  3. 在Spring中進(jìn)行集成測(cè)試
  4. Spring中的TopLink ServerSession
  5. Spring聲明式事務(wù)
責(zé)任編輯:佚名 來源: 中國(guó)IT實(shí)驗(yàn)室
相關(guān)推薦

2009-06-19 18:38:01

Spring

2009-06-19 13:28:30

Spring AOPSpring 2.0

2022-06-07 07:58:45

SpringSpring AOP

2022-02-17 13:39:09

AOP接口方式

2017-03-29 09:08:25

Spring筆記

2022-06-08 08:04:28

Springservicerepository

2009-06-19 11:09:27

Spring AOP

2009-09-29 10:00:40

Spring AOP框

2024-12-24 14:01:10

2023-03-29 08:24:30

2021-03-01 23:26:41

日志Spring BootAOP

2024-11-04 16:29:19

2012-09-28 10:20:14

IBMdw

2021-05-06 07:58:57

Spring BeanIOCAOP

2024-09-26 14:48:35

SpringAOP范式

2022-02-16 13:46:40

Spring Aop代碼注解

2022-02-08 17:07:54

Spring BooSpring Aop日志記錄

2012-09-27 09:47:43

SpringJava面向?qū)ο?/a>

2009-06-18 14:54:52

Spring AOP

2019-11-29 16:21:22

Spring框架集成
點(diǎn)贊
收藏

51CTO技術(shù)棧公眾號(hào)