• asp.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)
        
    {
            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(019);    
                    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操作的封装
    }
  • 相关阅读:
    Monolith and Microservice
    Lombok介绍、使用方法和总结
    Druid对应mysql-connector版本
    maven导入springboot项目
    区块链是什么?超级详细,看了无师自通!
    08.区块链的应用有什么?区块链将带来什么变革?
    06.工作量证明共识机制
    07 挖矿是什么意思?矿工都做了什么?
    05.比特币区块链的数据结构
    04.UTXO:未使用的交易输出,比特币核心概念之一
  • 原文地址:https://www.cnblogs.com/81/p/478175.html
Copyright © 2020-2023  润新知