苏飞论坛

 找回密码
 马上注册

QQ登录

只需一步,快速开始

分布式系统框架(V2.0) 轻松承载百亿数据,千万流量!讨论专区 - 源码下载 - 官方教程

HttpHelper爬虫框架(V2.7-含.netcore) HttpHelper官方出品,爬虫框架讨论区 - 源码下载 - 在线测试和代码生成

HttpHelper爬虫类(V2.0) 开源的爬虫类,支持多种模式和属性 源码 - 代码生成器 - 讨论区 - 教程- 例子

查看: 17595|回复: 1
打印 上一主题 下一主题

[C#语言基础] C# AOP实现方法拦截器

[复制链接]
跳转到指定楼层
楼主
发表于 2013-8-13 10:04:51 | 只看该作者 |只看大图 回帖奖励 |倒序浏览 |阅读模式
本帖最后由 qq576733600 于 2013-8-13 10:17 编辑

在写程序的时候,很多方法都加了。日志信息。比如打印方法开始,方法结束,错误信息。等等。由于辅助性功能的代码几乎是完全相同的,这样就会令同样的代码在各个函数中出现,引入了大量冗余代码。最后找到了AOP解决方案,分享出来。供大家参考。

实现步骤。
一、下载安装 PostSharp-1.5.6.629-Release-x86.msi 或者 PostSharp-1.5.7.1081-Release-x64.msi 具体根据自己电脑来。安装的时候记得先退出自己的 Microsoft Visual Studio
下载地址: http://www.postsharp.net/downloads/postsharp-1.5/sp-1

、在项目中添加引用



、事例,直接贴代码了。
[code=csharp][Serializable] //必须加入这个
  [AttributeUsage(AttributeTargets.Method,AllowMultiple=true,Inherited=true)] //设置类的访问访问
  public sealed class LoggingAttribute:OnMethodBoundaryAspect
  {

    public string BusinessName { get; set; }


    /// <summary>
    /// 方法进入时执行
    /// </summary>
    /// <param name="eventArgs"></param>
    public override void OnEntry(MethodExecutionEventArgs eventArgs)
    {

      Console.WriteLine("---------------方法:" + eventArgs.Method.Name+"开始--------------");
    }

    /// <summary>
    /// 方法退出时执行
    /// </summary>
    /// <param name="eventArgs"></param>
    public override void OnExit(MethodExecutionEventArgs eventArgs)
    {
      Console.WriteLine("---------------方法:" + eventArgs.Method.Name + "结束--------------");
    }


    /// <summary>
    /// 错误的时候执行
    /// </summary>
    /// <param name="eventArgs"></param>
    public override void OnException(MethodExecutionEventArgs eventArgs)
    {
      base.OnException(eventArgs);
    }

    //还有别的方法自己研究

  }[/code]

注意点:类必须序列化 需要加 [Serializable]    类要配置 Attribute  设置的他的调用方式


四、调用,非常简单。 在需要调用的 方法前面加入方法的 Attribute   就行了  下面是代码
[code=csharp]    /// <summary>
    /// 调用事例1
    /// </summary>
    [Logging()]
    void debugInfo() {

      for (int i = 0; i < 3;i++ )
      {
         
        Console.WriteLine("i="+i);
      }
    }


    /// <summary>
    /// 调用事例2 ,可以给属性赋值
    /// </summary>
    [Logging(BusinessName="aaa")]
    void debugError() {
      for (int i = 0; i < 3; i++)
      {

        Console.WriteLine("i=" + i);
      }
   
    }[/code]

五、测试结果







本帖被以下淘专辑推荐:

  • · C#|主题: 2, 订阅: 0


1. 开通SVIP会员,免费下载本站所有源码,不限次数据,不限时间
2. 加官方QQ群,加官方微信群获取更多资源和帮助
3. 找站长苏飞做网站、商城、CRM、小程序、App、爬虫相关、项目外包等点这里
沙发
发表于 2013-8-13 10:07:05 | 只看该作者
呵呵这个不错,支持一下
您需要登录后才可以回帖 登录 | 马上注册

本版积分规则

QQ|手机版|小黑屋|手机版|联系我们|关于我们|广告合作|苏飞论坛 ( 豫ICP备18043678号-2)

GMT+8, 2025-1-20 00:49

© 2014-2021

快速回复 返回顶部 返回列表