參考資料:http://www.cnblogs.com/zuowj/p/7501896.html
1、通過NuGet下載Castle.Core
2、創建代理類並繼承StandardInterceptor

參考代碼如下
using Castle.DynamicProxy; using System; using System.Collections.Generic; using System.Linq; using System.Text; using System.Threading.Tasks; namespace ConsoleApplication2 { public class TestInterceptor : StandardInterceptor { /// <summary> /// 創建代理類 /// </summary> /// <typeparam name="T"></typeparam> /// <returns></returns> public static T CreateProxy<T>() where T : class { ProxyGenerator generator = new ProxyGenerator(); var testa = generator.CreateClassProxy<T>(new TestInterceptor()); return testa; } /// <summary> /// 執行前 /// </summary> /// <param name="invocation"></param> protected override void PreProceed(IInvocation invocation) { Console.WriteLine(invocation.Method.Name + "執行前,入參:" + string.Join(",", invocation.Arguments)); } /// <summary> /// 執行中 /// </summary> /// <param name="invocation"></param> protected override void PerformProceed(IInvocation invocation) { Console.WriteLine(invocation.Method.Name + "執行中"); try { base.PerformProceed(invocation); } catch (Exception ex) { Console.WriteLine(ex.ToString()); } } /// <summary> /// 執行后 /// </summary> /// <param name="invocation"></param> protected override void PostProceed(IInvocation invocation) { Console.WriteLine(invocation.Method.Name + "執行后,返回值:" + invocation.ReturnValue); } } }
3、創建測試類
public class TestB { public virtual string GetResult() { string str = DateTime.Now + "TestB-GetResult"; Console.WriteLine(str); return str; } public virtual string GetResult2() { string str = DateTime.Now + "TestB-GetResult2"; Console.WriteLine(str); return str; } }
4、使用AOP方式調用方法
TestInterceptor.CreateProxy<TestB>().GetResult();
重點:virtual
Castle只會對virtual標記的虛方法進行代理
