/*------------------------------------------------ ----------------
* 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 description for Error
///
public class ErrorManager
{
private System.Timers.Timer m_timer;
private Hashtable m_htErr;
/**////
/// 私有的建構子
///
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();
}
/**////
/// 單例模式的接口
///
public static readonly ErrorManager Instance = new ErrorManager();
/**////
/// 設定定時器的頻率,單位是毫秒
///
/// 毫秒
public void SetTimerInterval(int Interval)
{
this.m_timer.Interval = Interval;
}
/**////
/// 定時器開始
///
public void TimerStart()
{
this.m_timer.Enabled = true;
}
/**////
/// 定時器結束
///
public void TimerStop()
{
this.m_timer.Enabled = false;
}
/**////
/// 發生了一個錯誤,把錯誤訊息保存起來,並回傳錯誤的id,以便於頁面中讀取
///
///
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;
}
/**////
/// 傳回指定Key的錯誤訊息,前19個字元是錯誤發生的時間
///
/// key,是一個guid
///
public string GetError(string key)
{
return this.m_htErr[key].ToString();
}
/**////
/// 定時在Hashtable中清理錯誤訊息
///
///
///
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操作的封裝
/**////
/// 取得指定鍵值的Session
///
/// 鍵值
///
public object GetSession(string key)
{
object val = HttpContext.Current.Session[key];
if (val == null)
throw new Exception("頁面逾時,請重新登入。");
return val;
}
/**////
/// 設定Session
///
/// 鍵值
/// 鍵內容
public void SetSession(string key, object val)
{
HttpContext.Current.Session[key] = val;
}
#endregion
}
http://www.cnblogs.com/81/archive/2006/08/16/478175.html