程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
 程式師世界 >> 編程語言 >> .NET網頁編程 >> .NET實例教程 >> asp.net錯誤處理封裝

asp.net錯誤處理封裝

編輯:.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)
    {
      &nbs
p; 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;
    }
 &nb
sp;  #endregion
}
http://www.cnblogs.com/81/archive/2006/08/16/478175.Html

  1. 上一頁:
  2. 下一頁:
Copyright © 程式師世界 All Rights Reserved