首 页 | 精品电影 | 音乐天堂 | 在线游戏 | Flash MTV | 三湘书屋 | 幽默笑话 | 三湘图库 | 美女写真 | IT知识库 | QQ贴图 | 加入书签

网页制作网络编程图形图象操作系统冲浪宝典软件教学网络安全认证考试通信技术电子商务业内动态书籍教程原码

最近更新 文章分类 多媒体类 精品软件

本站搜索:
您的位置:三湘时空 -> IT知识库 -> 文章分类 -> ASP.NET技巧 -> 在 ASP.NET 中用匿名委托简单模拟 AOP 做异常和日志处理
在 ASP.NET 中用匿名委托简单模拟 AOP 做异常和日志处理


文章类别:ASP.NET技巧 来源: 作者: 发表日期:2006-11-16 字体:[ ]

小游戏 | 在线影院 | 幽默笑话 | 源码下载 | Flash MTV | 音乐试听 | 书屋 | 美女写真

这两天写 ASP.NET 写晕了,老想偷点懒。由于在后台的代码里几乎每个方法里都要 try..catch 这么来一遍,感觉很烦琐。又联想到 AOP, 但 AOP 的做法相对比较复杂,做法也很多。比如用 Dynamic Proxy, Attribute, 或者 Emit 等。我忽然联想到了 C# 2.0 的新特性匿名委托,觉得这个虽然丑一点。。。不过其实也可以比较轻量级的简单模拟 AOP 的效果:

// asp.net 里面强制做一个页面基类的要求是不过分的。。。
public partial class TestLogger: PageBase {
    protected void Page_Load(object sender, EventArgs e) {
        // 这个方法实现在页面基类里面,可以往里面实现通用的异常处理,日志逻辑等。
        TryDo(
            // 这个里面干实际的事情
            delegate() {
                int a = 1;
                int b = 0;
                int c = a / b;
            },
            // 这是一个可选的异常处理,如果传递一个 null 就会干脆忽略异常
            delegate() {
                Response.Write("Sorry, 发生了一个错误。");
            }
        );
    }
}
在页面基类里面的实现代码就很简单了,也可以方便的统一管理。这里我假定仅仅简单的用 log4net 来对异常做日志记录:
using System;
using System.Web.UI;
using log4net;

namespace SomeNamespace {
    // 定义一个简单的委托用于传递匿名委托
    public delegate void MyAction();
   
    // 定义页面基类
    public class PageBase : Page {
        protected ILog logger;

        // 页面基类里面集中处理所有异常处理逻辑
        protected void TryDo(MyAction doHandler, MyAction exceptHandler) {
            try {
                // 干点儿实际的事情
                doHandler();
            } catch (Exception ex) {
                // 简单的记录异常
                logger.Error(ex);
               
                // 其他一些处理
                // 。。。

                // 调用自定义的异常处理,这里没有回传 Exception 的具体信息。因为反正没有必要对用户显示了。。。
                if (exceptHandler != null)
                    exceptHandler();
            }
        }

        protected override void OnInit(EventArgs e) {
            // 初始化 logger. 正好这里 GetType() 可以取到子类的实际类型
            logger = LogManager.GetLogger(this.GetType());

            base.OnInit(e);
        }
    }
}
好了,先写到这里。这只是我的一个简单想法。目的在轻量级的实现异常或日志的集中管理。当然这个和完整的 AOP 概念是没法比的,不过话说回来,好像目前在 .NET 中还没有很完美的 AOP framework.

上一篇:巧用Photoshop通道去除人像照片面部油光 下一篇:Asp.Net中使用水晶报表
本栏目热门文章
·如何实现无刷新的DropdownList联动效果 2005-10-4
·使用HttpWebRequest向网站模拟上传数据 2005-10-4
·ASP.NET中文件上传下载方法集合 2006-5-28
·分享个极好的无刷新二级联动下拉列表,同样适用与firefox 2005-10-19
·ASP.NET2.0实现无刷新客户端回调 2005-11-13
·当DataSet中包含主/子表时,Update更新步骤 2005-10-6
·在Web DataGrid中当鼠标移到某行与离开时行的颜色发生改变( 2005-10-4
·ASP.NET中实现Flash与.NET的紧密集成 2005-11-21
·关于Asp.net页面Page_Load被执行两次的问题 2005-10-4
·用window.location.href实现刷新另个框架页面 2006-6-20
新近更新文章
·ASP.NET模拟其他用户进行关机 2006-12-7
·得到随机字符串算法 2006-12-7
·最简单的asp.net分页 2006-12-7
·Scott Mitchell 的ASP.NET 2.0数据教程之应用 2006-12-7
·深入聊聊Array的sort方法的使用技巧.详细点评protype. 2006-12-7
·用完HttpWebResponse时别忘了调用Close方法 2006-12-7
·SQL Server精简版支不支持ASP.NET? 2006-12-7
·对NDoc支持.net2.0的异常分析及解决 2006-12-7
·比较:HyperLink控件、LinkButton控件 之间的异同 2006-12-7
·ASP.NET 2.0高级数据处理之冲突检测 2006-12-7
首 页 | 软件发布 | 广告联系 | 下载帮助 | 意见反馈 | 网站地图
  CopyRight? 2002-2004 WWW.SXSKY.NET? All Rights Reserved
三湘时空 站长QQ:82675303 Email: