国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 編程 > C# > 正文

C#開源的AOP框架--KingAOP基礎

2019-10-29 21:34:26
字體:
來源:轉載
供稿:網友
這篇文章主要介紹了一款C#開源的AOP框架--KingAOP框架的基礎知識,對于想學習AOP的小伙伴來說,非常不錯,希望大家能夠喜歡。
 

  AOP面向切面編程(Aspect Oriented Programming),是通過預編譯方式和運行期動態代理實現程序功能的統一維護的一種技術。Spring框架用的核心技術就是AOP,是函數式編程的一種衍生范型。利用AOP的好處就是可以對業務邏輯進行隔離,降低耦合度,提高程序的可重用性,同時提高了開發的效率。開源的AOP也有不少,我這里用的KingAOP.

1 項目結構

C#開源的AOP框架--KingAOP基礎

2 定義一個日志記錄的實體類User和LoggingAspect切面日志類

namespace AOPDemo.Logging{ class User {  public int ID { get; set; }  public string Name { get; set; }  public string Pwd{get;set;}  public string IP { get; set; }  public string State { get; set; }  public System.DateTime LoginTime { get; set; } }}

 

using System;using System.Text;using KingAOP.Aspects;namespace AOPDemo.Logging{ internal class LoggingAspect : OnMethodBoundaryAspect {  public override void OnEntry(MethodExecutionArgs args)  {   string logData = CreateLogData("Entering", args);   Console.WriteLine(logData);  }  public override void OnExit(MethodExecutionArgs args)  {   string logData = CreateLogData("Leaving", args);   Console.WriteLine(logData);  }  /// <summary>  /// AOP對于登錄日志邏輯,只需在此進行修改即可,無需修改被切面的處理類  /// </summary>  /// <param name="methodStage"></param>  /// <param name="args"></param>  /// <returns></returns>  private string CreateLogData(string methodStage, MethodExecutionArgs args)  {   var str = new StringBuilder();   str.AppendLine();   str.AppendLine(string.Format(methodStage + " {0} ", args.Method));   foreach (var argument in args.Arguments)   {    var argType = argument.GetType();    str.Append(argType.Name + ": ");    if (argType == typeof(string) || argType.IsPrimitive)    {     str.Append(argument);    }    else    {     foreach (var property in argType.GetProperties())     {      str.AppendFormat("{0} = {1}; ",       property.Name, property.GetValue(argument, null));     }    }   }   return str.ToString();  } }}

3 Login類

該類必須實現IDynamicMetaObjectProvider的GetMetaObject方法,同時在需要切面的方法上用屬性[LoggingAspect]進行標注,LoggingAspect屬性也就是我們上面定義的LoggingAspect切片處理類.

 

using System.Dynamic;using System.Linq.Expressions;using KingAOP;namespace AOPDemo.Logging{ /// <summary> /// 登錄邏輯處理,只需添加一個LoggingAspect即可實現日志功能,達到邏輯和通用處理的邏輯分離 /// </summary> internal class Login : IDynamicMetaObjectProvider {  //添加登錄切面  [LoggingAspect]   public void LoginValdate(User entity)  {   //只需進行業務邏輯處理,無需進行日志處理   if (entity.Name == "jack" && entity.Pwd == "wang")   {    entity.State = "Logged";   }   else   {    entity.State = "Error";   }     }  /// <summary>  /// IDynamicMetaObjectProvider的實現  /// </summary>  /// <param name="parameter"></param>  /// <returns></returns>  public DynamicMetaObject GetMetaObject(Expression parameter)  {   //need for AOP weaving   return new AspectWeaver(parameter, this);  } }}

C#開源的AOP框架--KingAOP基礎

調試代碼如下:

//測試感覺KingAOP必須有一個dynamic才能切面Logging.Login test = new Logging.Login();dynamic entity = new Logging.User { Name = "Jon", ID = 99,Pwd="wang",State="",LoginTime=System.DateTime.Now};test.LoginValdate(entity);
 


注:相關教程知識閱讀請移步到c#教程頻道。
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 伊宁县| 汝阳县| 固原市| 辉南县| 麻江县| 余江县| 通辽市| 三江| 西贡区| 会泽县| 北票市| 牙克石市| 新竹县| 宜丰县| 赫章县| 鹤山市| 板桥市| 益阳市| 科尔| 沐川县| 涞水县| 纳雍县| 卢湾区| 麦盖提县| 白玉县| 宁晋县| 阿拉善盟| 静海县| 南京市| 卢氏县| 富平县| 普格县| 会泽县| 广东省| 临邑县| 古田县| 西丰县| 永德县| 敦化市| 吉木乃县| 英德市|