转自: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. 关于flask 上直接使用py.test测试框架进行测试

    这个周末基本上都在研究这玩意儿中度过了,虽然效率不高,英文文档看得晕头转向,但是好歹弄出来了 有个结果测试也通过了现在粗略总结一下有时间补上更多详细的例子. 首先使用py.test测试框架,可以做最简 ...

  2. python之zip函数和sorted函数

    # zip()函数和sorted()函数 # zip()函数:将两个序列合并,返回zip对象,可强制转换为列表或字典 # sorted()函数:对序列进行排序,返回一个排序后的新列表,原数据不改变 # ...

  3. Lodop打印控件中PRINT_INITA()和PRINT_PAGESIZE()宽高

    Lodop中有两个初始化语句,PRINT_INIT()和PRINT_INITA(),PRINT_INITA()多了四个参数,前两个是整体偏移值,第三四参数是宽高,这个宽高是指打印设计可视化编辑区域的宽 ...

  4. 03 基于umi搭建React快速开发框架(封装列表增删改查)

    前言 大家在做业务系统的时候,很多地方都是列表增删改查,做这些功能占据了大家很长时间,如果我们有类似的业务,半个小时就能做出一套那是不是很爽呢. 这样我们就可以有更多的时间学习一些新的东西.我们这套框 ...

  5. BZOJ3129 SDOI2013方程(容斥原理+扩展lucas)

    没有限制的话算一个组合数就好了.对于不小于某个数的限制可以直接减掉,而不大于某个数的限制很容易想到容斥,枚举哪些超过限制即可. 一般情况下n.m.p都是1e9级别的组合数没办法算.不过可以发现模数已经 ...

  6. Redundant Paths POJ - 3177(边—双连通分量)

    题意: 在图中加边 看最少能通过加多少条边把 图变成边—双连通分量 解析: 先做一次dfs,不同的连通分量的low是不同的  注意重边 缩点 统计度为1的点  那么需要加的边为(ret+1)/2 #i ...

  7. day5 算数,比较,赋值,逻辑运算符,表达式

    算数运算符 + 加- 减* 乘/ 除// 整除% 取余** 指数 算数优先级: 指数>乘除>加减 ps:python里面区分优先级只有小括号 () 没有 [] 和 {} , 比较运算符 = ...

  8. 有趣的线段树模板合集(线段树,最短/长路,单调栈,线段树合并,线段树分裂,树上差分,Tarjan-LCA,势能线段树,李超线段树)

    线段树分裂 以某个键值为中点将线段树分裂成左右两部分,应该类似Treap的分裂吧(我菜不会Treap).一般应用于区间排序. 方法很简单,就是把分裂之后的两棵树的重复的\(\log\)个节点新建出来, ...

  9. Java -- JDBC 学习--通过Statement进行数据库更新操作

    通过 JDBC 向指定的数据表中插入一条记录. 1. Statement: 用于执行 SQL 语句的对象 1). 通过 Connection 的 createStatement() 方法来获取 2). ...

  10. Looper Handler Mssage

    1. 一个Handler只有一个队列;2. 在调用Handler.post(Runnable runnable)方法时,会将runnable封装成一个Message;3. 在队列执行时,会判断当前的M ...