转自:https://blog.csdn.net/educast/article/details/6565447#
动态代理的原理

原理其实很简单,就是在运行时生成新的对象,姑且叫做T,并使T继承自需要代理的原对象,调用过程实际是调用了新的对象T.

通过对T中方法或属性等,添加些自定义的操作,从而实现对原对象访问的封装.

动态代理实现(利用castle)

castle的动态代理需要下面几步

  1. 自定义一个拦截器,必须实现 IInterceptor 接口
  2. 使用 ProxyGenerator 对象创建代理对象,对象中包含很多方法
  3. 对原对象的所有操作,都使用代理对象代替
  4. 在拦截器的方法中,加入自定义的操作,比如 记录参数调用日志,异常记录等.

简单拦截器实现代码:  SampleInterceptor.cs

  1. using System;
  2. using System.Data;
  3. using System.Configuration;
  4. using System.Web;
  5. using System.Web.Security;
  6. using System.Web.UI;
  7. using System.Web.UI.HtmlControls;
  8. using System.Web.UI.WebControls;
  9. using System.Web.UI.WebControls.WebParts;
  10. using Castle.Core.Interceptor;
  11. using System.Reflection;
  12. /// <summary>
  13. /// 拦截器示例
  14. /// </summary>
  15. public class SampleInterceptor : IInterceptor
  16. {
  17. public SampleInterceptor()
  18. {
  19. //
  20. //TODO: 在此处添加构造函数逻辑
  21. //
  22. }
  23. public void Intercept(IInvocation invocation)
  24. {
  25. output("开始进入拦截器");
  26. MethodInfo concreteMethod = invocation.GetConcreteMethod();
  27. if (!invocation.MethodInvocationTarget.IsAbstract)
  28. {
  29. output("开始执行 " + concreteMethod.Name);
  30. //执行原对象中的方法
  31. invocation.Proceed();
  32. output("执行结果 " + invocation.ReturnValue);
  33. }
  34. output("执行完毕");
  35. }
  36. private void output(string Message)
  37. {
  38. HttpContext.Current.Response.Write(Message + "<br>");
  39. }
  40. }
  1. using System;
  2. using System.Data;
  3. using System.Configuration;
  4. using System.Web;
  5. using System.Web.Security;
  6. using System.Web.UI;
  7. using System.Web.UI.HtmlControls;
  8. using System.Web.UI.WebControls;
  9. using System.Web.UI.WebControls.WebParts;
  10. using Castle.Core.Interceptor;
  11. using System.Reflection;
  12. /// <summary>
  13. /// 拦截器示例
  14. /// </summary>
  15. public class SampleInterceptor : IInterceptor
  16. {
  17. public SampleInterceptor()
  18. {
  19. //
  20. //TODO: 在此处添加构造函数逻辑
  21. //
  22. }
  23. public void Intercept(IInvocation invocation)
  24. {
  25. output("开始进入拦截器");
  26. MethodInfo concreteMethod = invocation.GetConcreteMethod();
  27. if (!invocation.MethodInvocationTarget.IsAbstract)
  28. {
  29. output("开始执行 " + concreteMethod.Name);
  30. //执行原对象中的方法
  31. invocation.Proceed();
  32. output("执行结果 " + invocation.ReturnValue);
  33. }
  34. output("执行完毕");
  35. }
  36. private void output(string Message)
  37. {
  38. HttpContext.Current.Response.Write(Message + "<br>");
  39. }
  40. }

示例中使用的接口 : IPerson.cs

  1. using System;
  2. using System.Data;
  3. using System.Configuration;
  4. using System.Web;
  5. using System.Web.Security;
  6. using System.Web.UI;
  7. using System.Web.UI.HtmlControls;
  8. using System.Web.UI.WebControls;
  9. using System.Web.UI.WebControls.WebParts;
  10. /// <summary>
  11. ///IPerson 的摘要说明
  12. /// </summary>
  13. public interface IPerson
  14. {
  15. /// <summary>
  16. /// 姓名
  17. /// </summary>
  18. string Name { get; }
  19. /// <summary>
  20. /// 地址
  21. /// </summary>
  22. string Address { get; }
  23. /// <summary>
  24. /// 正在做什么
  25. /// </summary>
  26. /// <returns></returns>
  27. string Doing();
  28. }
  1. using System;
  2. using System.Data;
  3. using System.Configuration;
  4. using System.Web;
  5. using System.Web.Security;
  6. using System.Web.UI;
  7. using System.Web.UI.HtmlControls;
  8. using System.Web.UI.WebControls;
  9. using System.Web.UI.WebControls.WebParts;
  10. /// <summary>
  11. ///IPerson 的摘要说明
  12. /// </summary>
  13. public interface IPerson
  14. {
  15. /// <summary>
  16. /// 姓名
  17. /// </summary>
  18. string Name { get; }
  19. /// <summary>
  20. /// 地址
  21. /// </summary>
  22. string Address { get; }
  23. /// <summary>
  24. /// 正在做什么
  25. /// </summary>
  26. /// <returns></returns>
  27. string Doing();
  28. }

对接口的实现:Person.cs

  1. using System;
  2. using System.Data;
  3. using System.Configuration;
  4. using System.Web;
  5. using System.Web.Security;
  6. using System.Web.UI;
  7. using System.Web.UI.HtmlControls;
  8. using System.Web.UI.WebControls;
  9. using System.Web.UI.WebControls.WebParts;
  10. /// <summary>
  11. ///Person 的摘要说明
  12. /// </summary>
  13. public class Person : IPerson
  14. {
  15. public Person()
  16. {
  17. //
  18. //TODO: 在此处添加构造函数逻辑
  19. //
  20. }
  21. #region IPerson 成员
  22. public string Name
  23. {
  24. get { return "我是花生米"; }
  25. }
  26. public string Address
  27. {
  28. get { return "我住在 http://pignut-wang.iteye.com/ "; }
  29. }
  30. public string Doing()
  31. {
  32. return "我正在写blog";
  33. }
  34. #endregion
  35. }
  1. using System;
  2. using System.Data;
  3. using System.Configuration;
  4. using System.Web;
  5. using System.Web.Security;
  6. using System.Web.UI;
  7. using System.Web.UI.HtmlControls;
  8. using System.Web.UI.WebControls;
  9. using System.Web.UI.WebControls.WebParts;
  10. /// <summary>
  11. ///Person 的摘要说明
  12. /// </summary>
  13. public class Person : IPerson
  14. {
  15. public Person()
  16. {
  17. //
  18. //TODO: 在此处添加构造函数逻辑
  19. //
  20. }
  21. #region IPerson 成员
  22. public string Name
  23. {
  24. get { return "我是花生米"; }
  25. }
  26. public string Address
  27. {
  28. get { return "我住在 http://pignut-wang.iteye.com/ "; }
  29. }
  30. public string Doing()
  31. {
  32. return "我正在写blog";
  33. }
  34. #endregion
  35. }

所有要使用到的对象都准备好了,下面就是调用的代码

  1. using System;
  2. using System.Configuration;
  3. using System.Data;
  4. using System.Web;
  5. using System.Web.Security;
  6. using System.Web.UI;
  7. using System.Web.UI.HtmlControls;
  8. using System.Web.UI.WebControls;
  9. using System.Web.UI.WebControls.WebParts;
  10. using Castle.DynamicProxy;
  11. public partial class _Default : System.Web.UI.Page
  12. {
  13. protected void Page_Load(object sender, EventArgs e)
  14. {
  15. //创建拦截器对象
  16. SampleInterceptor Interceptor = new SampleInterceptor();
  17. //给person类生成代理
  18. ProxyGenerator Generator = new ProxyGenerator();
  19. IPerson p = Generator.CreateInterfaceProxyWithTarget<IPerson>(new Person(), Interceptor);
  20. //执行方法看效果
  21. p.Doing();
  22. }
  23. }
  1. using System;
  2. using System.Configuration;
  3. using System.Data;
  4. using System.Web;
  5. using System.Web.Security;
  6. using System.Web.UI;
  7. using System.Web.UI.HtmlControls;
  8. using System.Web.UI.WebControls;
  9. using System.Web.UI.WebControls.WebParts;
  10. using Castle.DynamicProxy;
  11. public partial class _Default : System.Web.UI.Page
  12. {
  13. protected void Page_Load(object sender, EventArgs e)
  14. {
  15. //创建拦截器对象
  16. SampleInterceptor Interceptor = new SampleInterceptor();
  17. //给person类生成代理
  18. ProxyGenerator Generator = new ProxyGenerator();
  19. IPerson p = Generator.CreateInterfaceProxyWithTarget<IPerson>(new Person(), Interceptor);
  20. //执行方法看效果
  21. p.Doing();
  22. }
  23. }

执行的效果就是在页面上输出4句话,如下

开始进入拦截器
开始执行 Doing
执行结果 我正在写blog
执行完毕

castle动态代理的使用的更多相关文章

  1. Castle动态代理拦截

    比如现在有一个方法,进行积分奖励 PointAdd 在不改变原来方法的基础上,增加积分奖励的日志 using Castle.DynamicProxy; public class AuditTraceI ...

  2. Aop之使用Castle动态代理实现对方法的拦截

    using System; using System.Linq; using Castle.DynamicProxy; namespace AopTest { class AopTest { stat ...

  3. AOP之Castle DynamicProxy 动态代理

    这里主要介绍使用castle这个动态代理,在.net一些开源的框架里可以找到它的影子,就连微软的rchard也是使用这个进行方法拦截等可以基于这个进行方法拦截,在这个方面PostSharp算是比较好用 ...

  4. castle之动态代理

    动态代理 DynamicProxy,这里说的动态代理是直接使用Castle.net 中提供的,并非自己实现的,因为别人写的很好,拿着用就行了. 动态代理的工作模式: 一般我们获取一个类型的实例都是通过 ...

  5. Castle Windsor 的动态代理类如何获取实际类型

    问题 在实际开发过程当中我们可能会针对某些类型使用动态代理技术(AOP),注入了一些拦截器进行处理,但是一旦某个类型被动态代理了,那么就会生成一个代理类.这个时候在该类内部使用 GetType() 方 ...

  6. ASP.NET Core搭建多层网站架构【9.2-使用Castle.Core实现动态代理拦截器】

    2020/01/31, ASP.NET Core 3.1, VS2019, Autofac.Extras.DynamicProxy 4.5.0, Castle.Core.AsyncIntercepto ...

  7. 不用Unity库,利用.NET动态代理自己实现AOP

    AOP意为面向切面的程序设计,主要表现为对不同的代码逻辑进行隔离,从而降低不同业务逻辑之间的耦合性,AOP又理解为“横切”,可以在不改变原有实现的情况下,对代码进行拦截和扩展,如果原有设计像一个瓶子, ...

  8. Autofac高级用法之动态代理

    前言 Autofac的DynamicProxy来自老牌的Castle项目.DynamicProxy(以下称为动态代理)起作用主要是为我们的类生成一个代理类,这个代理类可以在我们调用原本类的方法之前,调 ...

  9. 5.动态代理AOP实现-DynamicProxy模式

    通过动态代理模式Interceptor实现在RegUser()方法本身业务前后加上一些自己的功能,如:PreProceed和PostProceed,即不修改UserProcessor类又能增加新功能 ...

随机推荐

  1. hive存储、数据模型、内部表

    创建内部表 加一列元素 删除表

  2. python删除数组元素导致跳过元素

    复现的情况大概可以写成这样 abc = [1, 2, 2, 3, 4] print abc for index, i in enumerate(abc): if i == 2: del abc[ind ...

  3. PostgreSQL、SQL Server数据库中的数据类型的映射关系

    PostgreSQL 8.1 轰动发布,我也打算将原来使用 SQL Server 的一些应用迁移到 PostgreSQL 上,首先需要迁移的是表,那么这就必须要先搞清楚这两个数据库中的数据类型的映射关 ...

  4. Conjugate Function

    共轭函数 共轭函数的定义: 设函数f:Rn→R,定义函数f∗:Rn→R为: f∗(y)=sup(<y,x>−f(x))  x∈D 此函数称为函数f的共轭函数.即函数yx和函数f(x)之间差 ...

  5. solr string类型表示不支持分词

    solr string类型表示不支持分词

  6. [代码]--python爬虫联系--爬取成语

    闲来无事,玩了个成语接龙,于是就想用python爬取下成语网站上的成语,直接上代码: #coding=utf-8 import requests from bs4 import BeautifulSo ...

  7. BZOJ2277[Poi2011]Strongbox——数论

    题目描述 Byteasar is a famous safe-cracker, who renounced his criminal activity and got into testing and ...

  8. BZOJ1001 BJOI2006狼抓兔子(最小割+最短路)

    显然答案就是最小割.直接跑dinic也能过,不过显得不太靠谱. 考虑更正确的做法.作为一个平面图,如果要把他割成两半,那么显然可以用一条曲线覆盖且仅覆盖所有割边.于是我们把空白区域看成点,隔开他们的边 ...

  9. 12 Zabbix Item类型之Zabbix JMX类型

    点击返回:自学Zabbix之路 12 Zabbix Item类型之Zabbix JMX类型 JMX 全称是Java Management Extensions,即Java管理扩展.Java程序会开放一 ...

  10. 自学Linux Shell18.2-sed编辑器高级特性

    点击返回 自学Linux命令行与Shell脚本之路 18.2-sed编辑器高级特性 linux世界中最广泛使用的两个命令行编辑器: sed gawk 1. sed小结 命令格式: 1 sed [opt ...