首页 > 编程 > .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
}

菜鸟学堂:
发表评论 共有条评论
用户名: 密码:
验证码: 匿名发表