c# 自定义log4net过滤器

有时候为了实现自己想要的多个日志文件记录不同的内容,可能需要自定义log4net过滤器,比如我这里需要记录三个文件,这三个文件的内容又不能重复,多次尝试未果。

为了不更改任何现有日志代码的情况下,于是自定了过滤器。

复制代码
<log4net>
        <root name="Default">
      <level value="All" />
            <appender-ref ref="FileAppender"/>
        </root>
    <logger name="SubmitStudentCode">
      <level value="SubmitStudentCode" />
      <appender-ref ref="FileAppender.SubmitStudentCode" />
    </logger>
    <logger name="UserAction">
      <level value="UserAction" />
      <appender-ref ref="FileAppender.UserAction" />
    </logger>
    <appender name="FileAppender" type="log4net.Appender.RollingFileAppender">
            <param name="File" value="Log/"/>
            <param name="AppendToFile" value="true"/>
            <param name="MaxSizeRollBackups" value="10"/>
            <param name="StaticLogFileName" value="false"/>
            <param name="DatePattern" value="yyyy-MM-dd&quot;.log&quot;"/>
            <param name="RollingStyle" value="Date"/>
            <layout type="log4net.Layout.PatternLayout">
                <param name="Header" value="----------------------------------------[Header]--------------------------------------&#xA;&#13;&#10;&#13;&#10;"/>
                <param name="Footer" value="----------------------------------------[Footer]--------------------------------------&#xA;&#13;&#10;&#13;&#10;"/>
                <param name="ConversionPattern" value="%d [%t] %-5p %c [%x] - %m%n%n"/>
            </layout>
      <filter type="FirsteElite.Model.Model.Log.OrFilter">
        <filter type="log4net.Filter.LevelMatchFilter">
          <levelToMatch value="INFO" />
        </filter>
        <filter type="log4net.Filter.LevelRangeFilter">
          <levelMin value="WARN" />
          <levelMax value="FATAL" />
        </filter>
      </filter>
      <filter type="log4net.Filter.DenyAllFilter" />
        </appender>
    <appender name="FileAppender.SubmitStudentCode" type="log4net.Appender.RollingFileAppender">
      <param name="File" value="Log/" />
      <param name="AppendToFile" value="true"/>
      <param name="MaxSizeRollBackups" value="10"/>
      <param name="StaticLogFileName" value="false"/>
      <param name="DatePattern" value="yyyy-MM-dd&quot;_SubmitStudentCode.log&quot;"/>
      <param name="RollingStyle" value="Date"/>
      <layout type="log4net.Layout.PatternLayout">
        <param name="ConversionPattern" value="%d&#9;%m%n"/>
      </layout>
      <filter type="log4net.Filter.LoggerMatchFilter">
        <param name="LoggerToMatch" value="SubmitStudentCode" />
      </filter>
      <filter type="log4net.Filter.DenyAllFilter" />
    </appender>
    <appender name="FileAppender.UserAction" type="log4net.Appender.RollingFileAppender">
      <param name="File" value="Log/"/>
      <param name="AppendToFile" value="true"/>
      <param name="MaxSizeRollBackups" value="10"/>
      <param name="StaticLogFileName" value="false"/>
      <param name="DatePattern" value="yyyy-MM-dd&quot;_UserAction.log&quot;"/>
      <param name="RollingStyle" value="Date"/>
      <layout type="log4net.Layout.PatternLayout">
        <param name="ConversionPattern" value="%d&#9;%m%n"/>
      </layout>
      <filter type="log4net.Filter.LoggerMatchFilter">
        <param name="LoggerToMatch" value="UserAction" />
      </filter>
      <filter type="log4net.Filter.DenyAllFilter" />
    </appender>

  </log4net>
复制代码
复制代码
using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using log4net.Filter;
using log4net.Core;

namespace FirsteElite.Model.Model.Log
{
    public class AndFilter : FilterSkeleton
    {
        private bool acceptOnMatch;
        private readonly IList<IFilter> filters = new List<IFilter>();

        public override FilterDecision Decide(LoggingEvent loggingEvent)
        {
            if (loggingEvent == null)
                throw new ArgumentNullException("loggingEvent");

            foreach (IFilter filter in filters)
            {
                if (filter.Decide(loggingEvent) != FilterDecision.Accept)
                    return FilterDecision.Neutral; // one of the filter has failed
            }

            return FilterDecision.Accept;
        }

        public IFilter Filter
        {
            set { filters.Add(value); }
        }

        public bool AcceptOnMatch
        {
            get { return acceptOnMatch; }
            set { acceptOnMatch = value; }
        }
    }
}
复制代码
复制代码
using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using log4net.Filter;
using log4net.Core;

namespace FirsteElite.Model.Model.Log
{
    public class OrFilter : FilterSkeleton
    {
        private bool acceptOnMatch;
        private readonly IList<IFilter> filters = new List<IFilter>();

        public override FilterDecision Decide(LoggingEvent loggingEvent)
        {
            if (loggingEvent == null)
                throw new ArgumentNullException("loggingEvent");

            foreach (IFilter filter in filters)
            {
                if (filter.Decide(loggingEvent) == FilterDecision.Accept)
                    return FilterDecision.Accept;
            }

            return FilterDecision.Deny;
        }

        public IFilter Filter
        {
            set { filters.Add(value); }
        }

        public bool AcceptOnMatch
        {
            get { return acceptOnMatch; }
            set { acceptOnMatch = value; }
        }
    }
}
复制代码

 

复制代码
public static class UserActionLogger
        {
            static ILog userActionLogger = log4net.LogManager.GetLogger("UserAction");

            public static void log(string msg)
            {
                userActionLogger.Logger.Log(null, new log4net.Core.Level(50001, "UserAction"), msg, null);
            }
        }
复制代码

 

posted on   空明流光  阅读(1235)  评论(0编辑  收藏  举报

编辑推荐:
· SQL Server 2025 AI相关能力初探
· Linux系列:如何用 C#调用 C方法造成内存泄露
· AI与.NET技术实操系列(二):开始使用ML.NET
· 记一次.NET内存居高不下排查解决与启示
· 探究高空视频全景AR技术的实现原理
阅读排行:
· 阿里最新开源QwQ-32B,效果媲美deepseek-r1满血版,部署成本又又又降低了!
· 单线程的Redis速度为什么快?
· SQL Server 2025 AI相关能力初探
· AI编程工具终极对决:字节Trae VS Cursor,谁才是开发者新宠?
· 展开说说关于C#中ORM框架的用法!

导航

< 2025年3月 >
23 24 25 26 27 28 1
2 3 4 5 6 7 8
9 10 11 12 13 14 15
16 17 18 19 20 21 22
23 24 25 26 27 28 29
30 31 1 2 3 4 5
点击右上角即可分享
微信分享提示