C#開源的AOP框架--KingAOP基礎(chǔ)
AOP面向切面編程(Aspect Oriented Programming),是通過預(yù)編譯方式和運(yùn)行期動態(tài)代理實現(xiàn)程序功能的統(tǒng)一維護(hù)的一種技術(shù)。Spring框架用的核心技術(shù)就是AOP,是函數(shù)式編程的一種衍生范型。利用AOP的好處就是可以對業(yè)務(wù)邏輯進(jìn)行隔離,降低耦合度,提高程序的可重用性,同時提高了開發(fā)的效率。開源的AOP也有不少,我這里用的KingAOP.
1 項目結(jié)構(gòu)
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對于登錄日志邏輯,只需在此進(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類
該類必須實現(xiàn)IDynamicMetaObjectProvider的GetMetaObject方法,同時在需要切面的方法上用屬性[LoggingAspect]進(jìn)行標(biāo)注,LoggingAspect屬性也就是我們上面定義的LoggingAspect切片處理類.
using System.Dynamic;
using System.Linq.Expressions;
using KingAOP;
namespace AOPDemo.Logging
{
/// <summary>
/// 登錄邏輯處理,只需添加一個LoggingAspect即可實現(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的實現(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必須有一個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#怎么實現(xiàn)手機(jī)短信發(fā)送功能
欄 目:C#教程
本文標(biāo)題:C#開源的AOP框架--KingAOP基礎(chǔ)
本文地址:http://www.jygsgssxh.com/a1/C_jiaocheng/6793.html
您可能感興趣的文章
- 01-10C#通過反射獲取當(dāng)前工程中所有窗體并打開的方法
- 01-10關(guān)于ASP網(wǎng)頁無法打開的解決方案
- 01-10WinForm限制窗體不能移到屏幕外的方法
- 01-10WinForm繪制圓角的方法
- 01-10C#停止線程的方法
- 01-10WinForm實現(xiàn)仿視頻播放器左下角滾動新聞效果的方法
- 01-10C#通過重寫Panel改變邊框顏色與寬度的方法
- 01-10C#實現(xiàn)清空回收站的方法
- 01-10C#實現(xiàn)讀取注冊表監(jiān)控當(dāng)前操作系統(tǒng)已安裝軟件變化的方法
- 01-10C#實現(xiàn)多線程下載文件的方法


閱讀排行
本欄相關(guān)
- 01-10C#通過反射獲取當(dāng)前工程中所有窗體并
- 01-10關(guān)于ASP網(wǎng)頁無法打開的解決方案
- 01-10WinForm限制窗體不能移到屏幕外的方法
- 01-10WinForm繪制圓角的方法
- 01-10C#實現(xiàn)txt定位指定行完整實例
- 01-10WinForm實現(xiàn)仿視頻播放器左下角滾動新
- 01-10C#停止線程的方法
- 01-10C#實現(xiàn)清空回收站的方法
- 01-10C#通過重寫Panel改變邊框顏色與寬度的
- 01-10C#實現(xiàn)讀取注冊表監(jiān)控當(dāng)前操作系統(tǒng)已
隨機(jī)閱讀
- 08-05DEDE織夢data目錄下的sessions文件夾有什
- 04-02jquery與jsp,用jquery
- 01-11ajax實現(xiàn)頁面的局部加載
- 01-10使用C語言求解撲克牌的順子及n個骰子
- 01-10C#中split用法實例總結(jié)
- 01-10delphi制作wav文件的方法
- 01-11Mac OSX 打開原生自帶讀寫NTFS功能(圖文
- 08-05織夢dedecms什么時候用欄目交叉功能?
- 01-10SublimeText編譯C開發(fā)環(huán)境設(shè)置
- 08-05dedecms(織夢)副欄目數(shù)量限制代碼修改


