逆水行船

别人的天堂,是我的异乡;无端的繁华,倍添我的惆怅

 

DNN学习笔记-代码学习:ExceptionLogController

using System;

using WebApplication1.Exceptions;

namespace WebApplication1
{
 /// <summary>
 /// 设置Log的信息并且把它存储到LoggingProvider对象中。
 /// 是不适在Error筛选器中,选拔Log存储起来,而不对其进行处理?
 /// </summary>
 public class ExceptionLogController : LogController
 {
  /// <summary>
  /// 异常类型。
  /// </summary>
  public enum ExceptionLogType
  {
   GENERAL_EXCEPTION,
   MODULE_LOAD_EXCEPTION,
   PAGE_LOAD_EXCEPTION,
   SCHEDULER_EXCEPTION
  }
  public ExceptionLogController()
  {
   //
   // TODO: 在此处添加构造函数逻辑
   //
  }

  /// <summary>
  /// 设置Log信息。
  /// </summary>
  /// <param name="objException"></param>
  public void AddLog(Exception objException)
  {
   AddLog(objException, ExceptionLogType.GENERAL_EXCEPTION);
  }

  /// <summary>
  /// 根据Log类型,设置Log信息。
  /// </summary>
  /// <param name="objBasePortalException"></param>
  public void AddLog(BasePortalException objBasePortalException)
  {
   switch (objBasePortalException.GetType().Name)
   {
    case "ModuleLoadException":
     AddLog(objBasePortalException, ExceptionLogType.MODULE_LOAD_EXCEPTION);
     break;
    case "PageLoadException":
     AddLog(objBasePortalException, ExceptionLogType.PAGE_LOAD_EXCEPTION);
     break;
    case "SchedulerException":
     AddLog(objBasePortalException, ExceptionLogType.SCHEDULER_EXCEPTION);
     break;
    default:
     AddLog(objBasePortalException, ExceptionLogType.GENERAL_EXCEPTION);
     break;
   }
  }

  /// <summary>
  /// 设置Log信息,并保存到LoggingProvider中
  /// </summary>
  /// <param name="objException"></param>
  /// <param name="LogType"></param>
  public void AddLog(Exception objException, ExceptionLogType LogType)
  {
   // 本类继承自LogController,为什么还需要创建一个LogController对象。
   // 即使不声明LogController对象,照样可以调用AddLog方法啊?
   LogController objLogController = new LogController();
   LogInfo objLogInfo = new LogInfo();
   objLogInfo.LogTypeKey = LogType.ToString();

   // 向LogInfo对象的LogProperties中添加LogDetailInfo对象。在这里就是通过LogProperties扩展LogInfo的例子
   if (LogType == ExceptionLogType.MODULE_LOAD_EXCEPTION)
   {
    ModuleLoadException objModuleLoadException = ( ModuleLoadException)objException;
    objLogInfo.LogProperties.Add(new LogDetailInfo("ModuleId", objModuleLoadException.ModuleId.ToString()));
    objLogInfo.LogProperties.Add(new LogDetailInfo("ModuleDefId", objModuleLoadException.ModuleDefId.ToString()));
    objLogInfo.LogProperties.Add(new LogDetailInfo("FriendlyName", objModuleLoadException.FriendlyName));
    objLogInfo.LogProperties.Add(new LogDetailInfo("ModuleControlSource", objModuleLoadException.ModuleControlSource));
   }

   BasePortalException objBasePortalException = new BasePortalException(objException.ToString(), objException);
   objLogInfo.LogProperties.Add(new LogDetailInfo("AssemblyVersion", objBasePortalException.AssemblyVersion));
   objLogInfo.LogProperties.Add(new LogDetailInfo("Method", objBasePortalException.Method));
   objLogInfo.LogProperties.Add(new LogDetailInfo("FileName", objBasePortalException.FileName));
   objLogInfo.LogProperties.Add(new LogDetailInfo("FileLineNumber", objBasePortalException.FileLineNumber.ToString()));
   objLogInfo.LogProperties.Add(new LogDetailInfo("FileColumnNumber", objBasePortalException.FileColumnNumber.ToString()));
    objLogInfo.LogProperties.Add(new LogDetailInfo("PortalID", objBasePortalException.PortalID.ToString()));
   objLogInfo.LogProperties.Add(new LogDetailInfo("PortalName", objBasePortalException.PortalName));
   objLogInfo.LogProperties.Add(new LogDetailInfo("UserID", objBasePortalException.UserID.ToString()));
   objLogInfo.LogProperties.Add(new LogDetailInfo("UserName", objBasePortalException.UserName));
   objLogInfo.LogProperties.Add(new LogDetailInfo("ActiveTabID", objBasePortalException.ActiveTabID.ToString()));
   objLogInfo.LogProperties.Add(new LogDetailInfo("ActiveTabName", objBasePortalException.ActiveTabName));
   objLogInfo.LogProperties.Add(new LogDetailInfo("AbsoluteURL", objBasePortalException.AbsoluteURL));
   objLogInfo.LogProperties.Add(new LogDetailInfo("AbsoluteURLReferrer", objBasePortalException.AbsoluteURLReferrer));
   objLogInfo.LogProperties.Add(new LogDetailInfo("ExceptionGUID", objBasePortalException.ExceptionGUID));
   objLogInfo.LogProperties.Add(new LogDetailInfo("DefaultDataProvider", objBasePortalException.DefaultDataProvider));
   objLogInfo.LogProperties.Add(new LogDetailInfo("InnerException", objBasePortalException.InnerException.Message));
   objLogInfo.LogProperties.Add(new LogDetailInfo("Message", objBasePortalException.Message));
   objLogInfo.LogProperties.Add(new LogDetailInfo("StackTrace", objBasePortalException.StackTrace));
   objLogInfo.LogProperties.Add(new LogDetailInfo("Source", objBasePortalException.Source));

   objLogInfo.LogPortalID = objBasePortalException.PortalID;

   // 将Log对象存储到(LogController确定的)LoggingProvider对象中
   objLogController.AddLog(objLogInfo);
  }
 }
}

posted on   荣-  阅读(316)  评论(0编辑  收藏  举报

编辑推荐:
· .NET Core 中如何实现缓存的预热?
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
· 基于Microsoft.Extensions.AI核心库实现RAG应用
· Linux系列:如何用heaptrack跟踪.NET程序的非托管内存泄露
阅读排行:
· TypeScript + Deepseek 打造卜卦网站:技术与玄学的结合
· 阿里巴巴 QwQ-32B真的超越了 DeepSeek R-1吗?
· 【译】Visual Studio 中新的强大生产力特性
· 10年+ .NET Coder 心语 ── 封装的思维:从隐藏、稳定开始理解其本质意义
· 【设计模式】告别冗长if-else语句:使用策略模式优化代码结构

导航

统计

点击右上角即可分享
微信分享提示