C#開源的AOP框架--KingAOP基礎(chǔ)
AOP面向切面編程(Aspect Oriented Programming),是通過預(yù)編譯方式和運(yùn)行期動(dòng)態(tài)代理實(shí)現(xiàn)程序功能的統(tǒng)一維護(hù)的一種技術(shù)。Spring框架用的核心技術(shù)就是AOP,是函數(shù)式編程的一種衍生范型。利用AOP的好處就是可以對業(yè)務(wù)邏輯進(jìn)行隔離,降低耦合度,提高程序的可重用性,同時(shí)提高了開發(fā)的效率。開源的AOP也有不少,我這里用的KingAOP.
1 項(xiàng)目結(jié)構(gòu)
2 定義一個(gè)日志記錄的實(shí)體類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對于登錄日志邏輯,只需在此進(jìn)行修改即可,無需修改被切面的處理類 /// </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類
該類必須實(shí)現(xiàn)IDynamicMetaObjectProvider的GetMetaObject方法,同時(shí)在需要切面的方法上用屬性[LoggingAspect]進(jìn)行標(biāo)注,LoggingAspect屬性也就是我們上面定義的LoggingAspect切片處理類.
using System.Dynamic; using System.Linq.Expressions; using KingAOP; namespace AOPDemo.Logging { /// <summary> /// 登錄邏輯處理,只需添加一個(gè)LoggingAspect即可實(shí)現(xiàn)日志功能,達(dá)到邏輯和通用處理的邏輯分離 /// </summary> internal class Login : IDynamicMetaObjectProvider { //添加登錄切面 [LoggingAspect] public void LoginValdate(User entity) { //只需進(jìn)行業(yè)務(wù)邏輯處理,無需進(jìn)行日志處理 if (entity.Name == "jack" && entity.Pwd == "wang") { entity.State = "Logged"; } else { entity.State = "Error"; } } /// <summary> /// IDynamicMetaObjectProvider的實(shí)現(xiàn) /// </summary> /// <param name="parameter"></param> /// <returns></returns> public DynamicMetaObject GetMetaObject(Expression parameter) { //need for AOP weaving return new AspectWeaver(parameter, this); } } }
調(diào)試代碼如下:
//測試感覺KingAOP必須有一個(gè)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);
相關(guān)文章
C#操作本地文件及保存文件到數(shù)據(jù)庫的基本方法總結(jié)
C#使用System.IO中的文件操作方法在Windows系統(tǒng)中處理本地文件相當(dāng)順手,這里我們還總結(jié)了在Oracle中保存文件的方法,嗯,接下來就來看看整理的C#操作本地文件及保存文件到數(shù)據(jù)庫的基本方法總結(jié)2016-05-05c#泛型學(xué)習(xí)詳解 創(chuàng)建線性鏈表
Visual C# 2.0 的一個(gè)最受期待的(或許也是最讓人畏懼)的一個(gè)特性就是對于泛型的支持。這篇文章將告訴你泛型用來解決什么樣的問題,以及如何使用它們來提高你的代碼質(zhì)量,還有你不必恐懼泛型的原因2014-01-01解析C#中委托的同步調(diào)用與異步調(diào)用(實(shí)例詳解)
本篇文章是對C#中委托的同步調(diào)用與異步調(diào)用進(jìn)行了詳細(xì)的分析介紹,需要的朋友參考下2013-05-05c#實(shí)現(xiàn)隱藏與顯示任務(wù)欄的方法詳解
本篇文章是對c#中任務(wù)欄隱藏與顯示的實(shí)現(xiàn)方法進(jìn)行了詳細(xì)的分析介紹,需要的朋友參考下2013-06-06C# WPF 建立無邊框(標(biāo)題欄)的登錄窗口的示例
這篇文章主要介紹了C# WPF 建立無邊框(標(biāo)題欄)的登錄窗口的示例,幫助大家更好的理解和使用c#,感興趣的朋友可以了解下2020-12-12