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

首頁 > 編程 > C# > 正文

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

2020-01-24 01:20:30
字體:
來源:轉載
供稿:網友

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

1 項目結構

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);  } }}

調試代碼如下:

//測試感覺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);

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 灵川县| 阳山县| 铅山县| 广灵县| 江口县| 嘉兴市| 农安县| 合江县| 库尔勒市| 红安县| 酒泉市| 湖口县| 织金县| 会同县| 馆陶县| 喜德县| 洱源县| 八宿县| 麻城市| 甘孜| 内黄县| 武隆县| 宜兴市| 蓬莱市| 红河县| 宜兰县| 和硕县| 章丘市| 苏州市| 长白| 营山县| 扎囊县| 双江| 崇礼县| 巴彦淖尔市| 云阳县| 巴塘县| 云林县| 岢岚县| 河间市| 拜城县|