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