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

}