网络编程 | 站长之家 | 网页制作 | 图形图象 | 操作系统 | 冲浪宝典 | 软件教学 | 网络办公 | 邮件系统 | 网络安全 | 认证考试 | 系统进程
Firefox | IE | Maxthon | 迅雷 | 电驴 | BitComet | FlashGet | QQ | QQ空间 | Vista | 输入法 | Ghost | Word | Excel | wps | Powerpoint
asp | .net | php | jsp | Sql | c# | Ajax | xml | Dreamweaver | FrontPages | Javascript | css | photoshop | fireworks | Flash | Cad | Discuz!
当前位置 > 网站建设学院 > 网络编程 > ASP.NET技巧
Tag:注入,存储过程,分页,安全,优化,xmlhttp,fso,jmail,application,session,防盗链,stream,无组件,组件,md5,乱码,缓存,加密,验证码,算法,cookies,ubb,正则表达式,水印,索引,日志,压缩,base64,url重写,上传,控件,Web.config,JDBC,函数,内存,PDF,迁移,结构,破解,编译,配置,进程,分词,IIS,Apache,Tomcat,phpmyadmin,Gzip,触发器,socket
网络编程:ASP教程,ASP.NET教程,PHP教程,JSP教程,C#教程,数据库,XML教程,Ajax,Java,Perl,Shell,VB教程,Delphi,C/C++教程,软件工程,J2EE/J2ME,移动开发
本月文章推荐
.Web应用程序ASP.NET开发电子商务.
.ASP.NET网络编程中经常用到的27个.
.怎样从ASP.NET 2.0中读取连接字符.
..NET中Socket编程的简单示例.
.数据库连接字在Web.config里的用.
.为XPath自定义函数(因为XPath1..
.ASP.NET Whidbey中实现Provider.
.MSBuild, NAnt, NUnit, MSTest所.
.DataGrid与SQL Server 2000数据绑.
.ASP.NET2.0实现网站的自动升级 .
.如何在web.config中建立公用的的.
.asp.net开发web项目-vss集成环境.
.asp.net 2.0里动态访问meta标记.
.一个通过web.Mail发送邮件的类 .
.实现asp.net只对个别控件实时访问.
.Asp.net url分页的用户控件 .
.用Asp.net屏蔽F5、Ctrl+N、Alt+F4.
.SQL Artisan多表查询和统计.
.发布一个自己写的PrintPreviewCo.
.ASP.NET中利用cookies保持客户端.

在 ASP.NET 中用匿名委托简单模拟 AOP 做异常和日志处理

发表日期:2006-11-16


这两天写 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.
http://www.cnblogs.com/RChen/archive/2006/11/16/aspnet_exception_handling.html

上一篇:ASP.NET 2.0发送电子邮件中存在的问题 人气:4082
下一篇:Asp.Net中使用水晶报表 人气:6565
浏览全部ASP.NET的内容 Dreamweaver插件下载 网页广告代码 祝你圣诞节快乐 2009年新年快乐