国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 編程 > .NET > 正文

ASP.NET技巧:錯誤處理封裝

2024-07-10 13:09:53
字體:
來源:轉載
供稿:網友

/*----------------------------------------------------------------
 * 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
}

菜鳥學堂:
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 平谷区| 许昌市| 卢氏县| 台湾省| 黄平县| 磴口县| 利川市| 武汉市| 湟源县| 江陵县| 高安市| 广宁县| 遂溪县| 仪征市| 赤水市| 阳原县| 泰安市| 蒙自县| 方正县| 石林| 鄱阳县| 云霄县| 黑河市| 金塔县| 邓州市| 台前县| 桂平市| 定结县| 广丰县| 开阳县| 留坝县| 横峰县| 灌南县| 柳州市| 东莞市| 西青区| 凉城县| 策勒县| 英德市| 望奎县| 罗城|