• 公用类库(2) 日志类LogUtil


      这个日志类是基于企业库来封装的,首先贴上配置文件的代码。

    View Code
    <?xml version="1.0" encoding="utf-8"?>
    <configuration>
      <configSections>
        <section name="loggingConfiguration" type="Microsoft.Practices.EnterpriseLibrary.Logging.Configuration.LoggingSettings, Microsoft.Practices.EnterpriseLibrary.Logging, Version=5.0.414.0, Culture=neutral, PublicKeyToken=31bf3856ad364e35" requirePermission="true" />
      </configSections>
      <loggingConfiguration name="Logging Application Block" tracingEnabled="true"
        defaultCategory="General" logWarningsWhenNoCategoriesMatch="true">
        <listeners>
          <add name="EventLog Listener" type="Microsoft.Practices.EnterpriseLibrary.Logging.TraceListeners.FormattedEventLogTraceListener, Microsoft.Practices.EnterpriseLibrary.Logging"
            listenerDataType="Microsoft.Practices.EnterpriseLibrary.Logging.Configuration.FormattedEventLogTraceListenerData, Microsoft.Practices.EnterpriseLibrary.Logging"
            source="Enterprise Library Logging" formatter="Text Formatter"
            log="Application" machineName="" traceOutputOptions="None" filter="All" />
          <add name="Rolling File Listener" type="Microsoft.Practices.EnterpriseLibrary.Logging.TraceListeners.RollingFlatFileTraceListener, Microsoft.Practices.EnterpriseLibrary.Logging"
            listenerDataType="Microsoft.Practices.EnterpriseLibrary.Logging.Configuration.RollingFlatFileTraceListenerData, Microsoft.Practices.EnterpriseLibrary.Logging"
            fileName=".\RollingFlatFile.log" footer="----------------------------------------"
            formatter="Text Formatter" header="----------------------------------------"
            rollFileExistsBehavior="Increment" rollInterval="Midnight" rollSizeKB="1024"
            timeStampPattern="yyyy-MM-dd" maxArchivedFiles="3" traceOutputOptions="None"
            filter="All" />
        </listeners>
        <formatters>
          <add type="Microsoft.Practices.EnterpriseLibrary.Logging.Formatters.TextFormatter, Microsoft.Practices.EnterpriseLibrary.Logging"
            template="Timestamp: {timestamp(local)}{newline}Message: {message}{newline}Category: {category}{newline}Priority: {priority}{newline}EventId: {eventid}{newline}ActivityId: {property(ActivityId)}{newline}Severity: {severity}{newline}Title:{title}{newline}"
            name="Brief Format Text" />
          <add type="Microsoft.Practices.EnterpriseLibrary.Logging.Formatters.TextFormatter, Microsoft.Practices.EnterpriseLibrary.Logging"
            template="Timestamp: {timestamp(local)}{newline}Message: {message}{newline}Category: {category}{newline}Priority: {priority}{newline}EventId: {eventid}{newline}Severity: {severity}{newline}Title: {title}{newline}Activity ID: {property(ActivityId)}{newline}Machine: {localMachine}{newline}App Domain: {localAppDomain}{newline}ProcessId: {localProcessId}{newline}Process Name: {localProcessName}{newline}Thread Name: {threadName}{newline}Win32 ThreadId:{win32ThreadId}{newline}Extended Properties: {dictionary({key} - {value}{newline})}"
            name="Text Formatter" />
        </formatters>
        <logFilters>
          <add type="Microsoft.Practices.EnterpriseLibrary.Logging.Filters.PriorityFilter, Microsoft.Practices.EnterpriseLibrary.Logging"
            minimumPriority="2" maximumPriority="99" name="Priority Filter" />
          <add type="Microsoft.Practices.EnterpriseLibrary.Logging.Filters.LogEnabledFilter, Microsoft.Practices.EnterpriseLibrary.Logging"
            enabled="true" name="LogEnabled Filter" />
          <add type="Microsoft.Practices.EnterpriseLibrary.Logging.Filters.CategoryFilter, Microsoft.Practices.EnterpriseLibrary.Logging"
            categoryFilterMode="AllowAllExceptDenied" name="Category Filter" />
        </logFilters>
        <categorySources>
          <add switchValue="All" name="General">
            <listeners>
              <add name="EventLog Listener" />
              <add name="Rolling File Listener" />
            </listeners>
          </add>
          <add switchValue="All" name="ExceptionHandling">
            <listeners>
              <add name="EventLog Listener" />
              <add name="Rolling File Listener" />
            </listeners>
          </add>
        </categorySources>
        <specialSources>
          <allEvents switchValue="All" name="All Events" />
          <notProcessed switchValue="All" name="Unprocessed Category" />
          <errors switchValue="All" name="Logging Errors &amp; Warnings">
            <listeners>
              <add name="EventLog Listener" />
            </listeners>
          </errors>
        </specialSources>
      </loggingConfiguration>
    </configuration>

      日志类使用了单例模式,并且对外公开了两个方法,代码如下:

    namespace Tmac.Utilities
    {
        /// <summary>
        /// 日志操作类
        /// </summary>
        public sealed class LogUtil
        {
            //单例模式
            private static readonly LogUtil logUtil = new LogUtil();
            private LogUtil() { }
    
            public static LogUtil Instance
            {
                get
                {
                    return logUtil;
                }
            }
    
            public static void WriteLog(TraceEventType traceEventType, string msg)
            {
                try
                {
                    LogEntry log = new LogEntry();
                    log.TimeStamp = DateTime.Now;
                    log.Severity = traceEventType;
                    log.Message = msg;
                    Logger.Write(log);
                }
                catch (Exception ex)
                { }
            }
    
            public static void WriteLog(TraceEventType traceEventType, string msg,string category)
            {
                try
                {
                    LogEntry log = new LogEntry();
                    log.TimeStamp = DateTime.Now;
                    log.Severity = traceEventType;
                    log.Message = msg;
                    log.Categories = new string[] { category};//指定策略,不指定默认为General
                    Logger.Write(log);
                }
                catch (Exception ex)
                { }
            }
        }
    }
  • 相关阅读:
    docker 实现redis集群搭建
    ArrayList && LinkList
    ServletRequest、 HttpServletRequest、Request的联系与区别
    JSONObject例子
    使用SAXReader对XML进行操作
    JSON与XML的区别比较
    依赖注入(DI)和控制反转(IOC)
    Java 面试题:百度前200页都在这里了
    Java语言规范
    python+pandas+openpyxl下载xls illegalCharacterError
  • 原文地址:https://www.cnblogs.com/mcgrady/p/2970028.html
Copyright © 2020-2023  润新知