asp.net 自定义异常处理

15 篇文章 0 订阅
 

★ 自定义异常处理

//自定义异常处理类
using System;
using System.Diagnostics;

namespace MyAppException
{
/// <summary>
/// 从系统异常类ApplicationException继承的应用程序异常处理类。
/// 自动将异常内容记录到Windows NT/2000的应用程序日志
/// </summary>
public class AppException:System.ApplicationException
{
 public AppException()
 {
 if (ApplicationConfiguration.EventLogEnabled)
 LogEvent("出现一个未知错误。");
 }

 public AppException(string message)
 {
 LogEvent(message);
 }

 public AppException(string message,Exception innerException)
 {
 LogEvent(message);
 if (innerException != null)
 {
 LogEvent(innerException.Message);
 }
 }

//日志记录类
using System;
using System.Configuration;
using System.Diagnostics;
using System.IO;
using System.Text;
using System.Threading;

namespace MyEventLog
{
/// <summary>
/// 事件日志记录类,提供事件日志记录支持
/// <remarks>
/// 定义了4个日志记录方法 (error, warning, info, trace)
/// </remarks>
/// </summary>
public class ApplicationLog
{
 /// <summary>
 /// 将错误信息记录到Win2000/NT事件日志中
 /// <param name="message">需要记录的文本信息</param>
 /// </summary>
 public static void WriteError(String message)
 {

 WriteLog(TraceLevel.Error, message);
 }

 /// <summary>
 /// 将警告信息记录到Win2000/NT事件日志中
 /// <param name="message">需要记录的文本信息</param>
 /// </summary>
 public static void WriteWarning(String message)
 {

 WriteLog(TraceLevel.Warning, message);
 }

 /// <summary>
 /// 将提示信息记录到Win2000/NT事件日志中
 /// <param name="message">需要记录的文本信息</param>
 /// </summary>
 public static void WriteInfo(String message)
 {
 WriteLog(TraceLevel.Info, message);
 }
 /// <summary>
 /// 将跟踪信息记录到Win2000/NT事件日志中
 /// <param name="message">需要记录的文本信息</param>
 /// </summary>
 public static void WriteTrace(String message)
 {

 WriteLog(TraceLevel.Verbose, message);
 }

 /// <summary>
 /// 格式化记录到事件日志的文本信息格式
 /// <param name="ex">需要格式化的异常对象</param>
 /// <param name="catchInfo">异常信息标题字符串.</param>
 /// <retvalue>
 /// <para>格式后的异常信息字符串,包括异常内容和跟踪堆栈.</para>
 /// </retvalue>
 /// </summary>
 public static String FormatException(Exception ex, String catchInfo)
 {
 StringBuilder strBuilder = new StringBuilder();
 if (catchInfo != String.Empty)
 {
 strBuilder.Append(catchInfo).Append("\r\n");
 }
 strBuilder.Append(ex.Message).Append("\r\n").Append(ex.StackTrace);
 return strBuilder.ToString();
 }

 /// <summary>
 /// 实际事件日志写入方法
 /// <param name="level">要记录信息的级别(error,warning,info,trace).</param>
 /// <param name="messageText">要记录的文本.</param>
 /// </summary>
 private static void WriteLog(TraceLevel level, String messageText)
 {

 try
 {
 EventLogEntryType LogEntryType;
 switch (level)
 {
 case TraceLevel.Error:
 LogEntryType = EventLogEntryType.Error;
 break;
 case TraceLevel.Warning:
 LogEntryType = EventLogEntryType.Warning;
 break;
 case TraceLevel.Info:
 LogEntryType = EventLogEntryType.Information;
 break;
 case TraceLevel.Verbose:
 LogEntryType = EventLogEntryType.SuccessAudit;
 break;
 default:
 LogEntryType = EventLogEntryType.SuccessAudit;
 break;
 }

 EventLog eventLog = new EventLog("Application", ApplicationConfiguration.EventLogMachineName, ApplicationConfiguration.EventLogSourceName );
 //写入事件日志
 eventLog.WriteEntry(messageText, LogEntryType);

 }
 catch {} //忽略任何异常
 }
} //class ApplicationLog
}


 
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值