打开APP
userphoto
未登录

开通VIP,畅享免费电子书等14项超值服

开通VIP
asp.net错误处理封装
原文链接:http://www.cnblogs.com/kangshifu/archive/2008/11/20/1337641.html

来源:http://www.study-code.com/dotnet/aspnet/67494.htm

 

* 文件名  :ErrorManager.cs
 * 功能描述:asp.net中统一的错误修理,与本类相配套需要增加一个错误信息显示页面,如error.aspx 
 *
 * 使用说明:1. 在Application_Start()中启动定时器(定时清空错误信息):ErrorManager.Instance.Start(),
 *              默认12小时运行一次,或用ErrorManager.Instance.SetTimerInterval()设置。
 *           2. 在Application_Error()中,当发生错误时,保存这个错误信息并转到error.aspx中显示这个错误
 *               string key = ErrorManager.Instance.AddError();
 *               Response.Redirect("error.aspx?key=" key);
 *           3. 在error.aspx中通过url传来的key,取得并显示错误信息:
 *               string err = ErrorManager.Instance.GetError(key)
 *              err中前19个字符是错误发生的时间,后面是错误信息。
 *           4. 为了捕捉Session超时的错误,而不是返回Session[key]是null的错误信息,本类增加了GetSession()
 *              和SetSession函数来统一管理Session,以后aspx中不能直接读取Session,而必须通过本类来读取。
 *
 *
 * 创建标识:
 *
 * 修改标识:
 * 修改描述:
 *
 * 修改标识:
 * 修改描述:
 *----------------------------------------------------------------*/
using System;
using System.Data;
using System.Configuration;
using System.Web;
using System.Web.Security;
using System.Web.UI;
using System.Web.UI.WebControls;
using System.Web.UI.WebControls.WebParts;
using System.Web.UI.HtmlControls;
using System.Collections;
/**//// <summary>
/// Summary description for Error
/// </summary>
public class ErrorManager
{
    private System.Timers.Timer m_timer;
    private Hashtable m_htErr;

    /**//// <summary>

/// 私有的构造函数
    /// </summary>
    private ErrorManager()
    {
        this.m_timer = new System.Timers.Timer();
        this.m_timer.Enabled = false;
        this.m_timer.Interval = 12 * 60 * 60 * 1000;    //默认12个小时执行一次
        this.m_timer.Elapsed = new System.Timers.ElapsedEventHandler(m_timer_Elapsed);
        this.m_htErr = new Hashtable();
    }

    /**//// <summary>
    /// 单例模式的接口
    /// </summary>
    public static readonly ErrorManager Instance = new ErrorManager();

    /**//// <summary>
    /// 设置定时器的频率,单位是毫秒
    /// </summary>
    /// <param name="Interval">毫秒</param>
    public void SetTimerInterval(int Interval)
    {
        this.m_timer.Interval = Interval;
    }

/**//// <summary>
    /// 定时器开始
    /// </summary>
    public void TimerStart()
    {
        this.m_timer.Enabled = true;
    }

    /**//// <summary>
    /// 定时器结束
    /// </summary>
    public void TimerStop()
    {
        this.m_timer.Enabled = false;
    }

    /**//// <summary>
    /// 发生了一个错误,把错误信息保存起来,并返回错误的id,便于页面中读取
    /// </summary>
    /// <returns>返回错误的id</returns>
    public string AddError()
    {
        string key = Guid.NewGuid().ToString();
        string msg = System.DateTime.Now.ToString("yyyy-MM-dd HH:mm:ss")
            HttpContext.Current.Server.GetLastError().GetBaseException().Message;
        this.m_htErr.Add(key, msg);

        HttpContext.Current.Server.ClearError();

        return key;
    }

    /**//// <summary>
    /// 返回指定Key的错误信息,前19个字符是错误发生的时间
    /// </summary>
    /// <param name="key">key,是一个guid</param>
    /// <returns>返回错误信息</returns>
    public string GetError(string key)
    {
        return this.m_htErr[key].ToString();
    }

    /**//// <summary>
    /// 定时在Hashtable中清理错误信息
    /// </summary>
    /// <param name="sender"></param>
    /// <param name="e"></param>
    private void m_timer_Elapsed(object sender, System.Timers.ElapsedEventArgs e)
    {
        ArrayList list = new ArrayList();
        lock (this.m_htErr)
        {
            DateTime now = DateTime.Now;
            TimeSpan ts;
            foreach (string key in this.m_htErr.Keys)
            {
                //前19个字符是错误发生的日期,yyyy-MM-dd HH:mm:ss
                string time = this.m_htErr[key].ToString().Substring(0, 19);   
                ts = now - Convert.ToDateTime(time);
                if (ts.TotalMinutes > 20)   //把20分钟前的错误信息从hashtable中清除
                    list.Add(key);
            }

            foreach (string key in list)
            {
                this.m_htErr.Remove(key);
            }
        }

    }

* 文件名  :ErrorManager.cs
 * 功能描述:asp.net中统一的错误修理,与本类相配套需要增加一个错误信息显示页面,如error.aspx 
 *
 * 使用说明:1. 在Application_Start()中启动定时器(定时清空错误信息):ErrorManager.Instance.Start(),
 *              默认12小时运行一次,或用ErrorManager.Instance.SetTimerInterval()设置。
 *           2. 在Application_Error()中,当发生错误时,保存这个错误信息并转到error.aspx中显示这个错误
 *               string key = ErrorManager.Instance.AddError();
 *               Response.Redirect("error.aspx?key=" key);
 *           3. 在error.aspx中通过url传来的key,取得并显示错误信息:
 *               string err = ErrorManager.Instance.GetError(key)
 *              err中前19个字符是错误发生的时间,后面是错误信息。
 *           4. 为了捕捉Session超时的错误,而不是返回Session[key]是null的错误信息,本类增加了GetSession()
 *              和SetSession函数来统一管理Session,以后aspx中不能直接读取Session,而必须通过本类来读取。
 *
 *
 * 创建标识:
 *
 * 修改标识:
 * 修改描述:
 *
 * 修改标识:
 * 修改描述:
 *----------------------------------------------------------------*/
using System;
using System.Data;
using System.Configuration;
using System.Web;
using System.Web.Security;
using System.Web.UI;
using System.Web.UI.WebControls;
using System.Web.UI.WebControls.WebParts;
using System.Web.UI.HtmlControls;
using System.Collections;
/**//// <summary>
/// Summary description for Error
/// </summary>
public class ErrorManager
{
    private System.Timers.Timer m_timer;
    private Hashtable m_htErr;

    /**//// <summary>

/// 私有的构造函数
    /// </summary>
    private ErrorManager()
    {
        this.m_timer = new System.Timers.Timer();
        this.m_timer.Enabled = false;
        this.m_timer.Interval = 12 * 60 * 60 * 1000;    //默认12个小时执行一次
        this.m_timer.Elapsed = new System.Timers.ElapsedEventHandler(m_timer_Elapsed);
        this.m_htErr = new Hashtable();
    }


    /**//// <summary>
    /// 单例模式的接口
    /// </summary>
    public static readonly ErrorManager Instance = new ErrorManager();

    /**//// <summary>
    /// 设置定时器的频率,单位是毫秒
    /// </summary>
    /// <param name="Interval">毫秒</param>
    public void SetTimerInterval(int Interval)
    {
        this.m_timer.Interval = Interval;
    }

/**//// <summary>
    /// 定时器开始
    /// </summary>
    public void TimerStart()
    {
        this.m_timer.Enabled = true;
    }

    /**//// <summary>
    /// 定时器结束
    /// </summary>
    public void TimerStop()
    {
        this.m_timer.Enabled = false;
    }

    /**//// <summary>
    /// 发生了一个错误,把错误信息保存起来,并返回错误的id,便于页面中读取
    /// </summary>
    /// <returns>返回错误的id</returns>
    public string AddError()
    {
        string key = Guid.NewGuid().ToString();
        string msg = System.DateTime.Now.ToString("yyyy-MM-dd HH:mm:ss")
            HttpContext.Current.Server.GetLastError().GetBaseException().Message;
        this.m_htErr.Add(key, msg);

转载于:https://www.cnblogs.com/kangshifu/archive/2008/11/20/1337641.html

来源:https://www.icode9.com/content-1-374051.html
本站仅提供存储服务,所有内容均由用户发布,如发现有害或侵权内容,请点击举报
打开APP,阅读全文并永久保存 查看更多类似文章
猜你喜欢
类似文章
【热】打开小程序,算一算2024你的财运
aspx页面生成静态的HTML页面的三种方法
ASP.NET十分有用的页面间传值方法
Asp.net 菜单控件简洁版
【Aspx应用开发平台教程】架构篇:解析微系统构件-数据权限的实现 在园中,讲数据权限的文章很多,但大部分文章都是浅尝即止,只讲到数据库设计就没了,往往最关键的部分,如何在项目中实现,讲得很少。今天,
C# 实现虚拟打印机 HP Color LaserJet 4500 (1)
Silverlight 2.5D RPG游戏技巧与特效处理:(十三)资源动态下载组件
更多类似文章 >>
生活服务
热点新闻
分享 收藏 导长图 关注 下载文章
绑定账号成功
后续可登录账号畅享VIP特权!
如果VIP功能使用有故障,
可点击这里联系客服!

联系客服