/*----------------------------------------------------------------
* 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
}
新聞熱點
疑難解答
圖片精選