.NET AOP微型框架發佈 --CleanAOP

CleanAOP--簡介

做者:立地(歐文)
郵箱:jarvin_g@126.com
微博:立地J

導語:

  AOP爲Aspect Oriented Programming的縮寫。 意爲:面向切面編程。將日誌記錄,性能統計,安全控制,事務處理,異常處理等代碼從業務邏輯代碼中劃分出來,經過對這些行爲的分離,將它們獨立到非指導業務邏輯的方法中,進而改變這些行爲的時候不影響業務邏輯的代碼。git

一:認識Aop

  在平常的編程任務中,不少的代碼都是進行一些通用的功能(日誌、檢測、一層處理等等),而後代碼都是機械般的複製粘貼,實際上的業務邏輯代碼只佔很少的份額。那麼,aop能更好的組織通用的代碼、而後以標記的方式讓某個方法切入,使得業務邏輯和通用代碼分離,使其互不影響。github

使用Aop的優勢

  • 容易擴展新的切面。編程

  • 業務邏輯與切面邏輯解耦合。安全

  • 對修改封閉、對擴展開放。框架

使用Aop的缺點

  • 對於一些已存在修飾符的方法沒法使用,需添加外圍方法包含。異步

CleanAop支持語言

C#

版本歷史

最新版本:v2.0.0

  • v1.0.0:框架搭建完成、支持同步異步、提供Demo切面(錯誤捕獲,log,時間記錄)、先後切面選擇。async

  • v2.0.0:函數

    1. 攔截面切入方式改變,優化代理類生成方式。性能

    2. 使用AOP的類不能有帶參構造函數bug修復。測試

哪裏下載?

  1. github地址

  2. 網盤下載:

Demo測試案例

  1. 多切面、同步

    [TryCatchAttrubute]
       [LogAopAttrubute]
       [TimeAop]
       public virtual void DoWord()
       {
           throw new Exception("錯誤測試");
           Debug.WriteLine("123");
       }

    結果:

    開始捕捉異常([TryCatchAttrubute])
       開始執行([LogAopAttrubute])
       2015/11/5 0:47:19([TimeAop])
       錯誤測試(異常捕獲處理)
       執行中([LogAopAttrubute])
       執行結束,Void DoWord()方法([LogAopAttrubute])
       2015/11/4 23:47:19    [TimeAop])
  2. 多切面、異步

    [TryCatchAttrubute]
       [LogAopAttrubute]
       [TimeAop]
       public virtual async Task DoWord()
       {
           await GetValueAsync(1234.5123, 1.01);
           Debug.WriteLine("123");
           throw new Exception("錯誤測試");
           Debug.WriteLine("123");
       }

    結果:

    開始捕捉異常([TryCatchAttrubute])
       開始執行([LogAopAttrubute])
       2015/11/5 1:05:23([TimeAop])
       執行中([LogAopAttrubute])
       123
       處理錯誤,錯誤信息爲:錯誤測試([TryCatchAttrubute])
       執行結束,System.Threading.Tasks.Task DoWord()方法([LogAopAttrubute])
       2015/11/5 0:05:23([TimeAop])
相關文章
相關標籤/搜索