asp.net错误处理封装


/*----------------------------------------------------------------

  * Copyright (C)

  * 版权所有。

  *

  * 文件名 :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);
      }
    }
  
  }

Session操作的封装#region Session操作的封装

  /**//// <summary>
  /// 取得指定键值的Session
  /// </summary>
  /// <param name="key">键值</param>
  /// <returns>键内容值</returns>
  public object GetSession(string key)
  {
    object val = HttpContext.Current.Session[key];
    if (val == null)
      throw new Exception("页面超时,请重新登录。");
  
    return val;
  }
  
  /**//// <summary>
  /// 设置Session
  /// </summary>
  /// <param name="key">键值</param>
  /// <param name="val">键内容</param>
  public void SetSession(string key, object val)
  {
    HttpContext.Current.Session[key] = val;
  }
  #endregion
}

本文作者:
« 
» 
快速导航

Copyright © 2016 phpStudy | 豫ICP备2021030365号-3