gpt4 book ai didi

c# - Log4Net 以编程方式检查 IsEnabledFor 以获取 Appender 过滤器

转载 作者:行者123 更新时间:2023-11-30 17:13:02 26 4
gpt4 key购买 nike

我如何以编程方式检查 IsEnabledFortrue对于某个附加过滤器。

这是我的配置:

<log4net>
<root>
<level value="ALL" />
<appender-ref ref="appender" />
</root>

<appender name="appender" type="log4net.Appender.FileAppender">
<filter type="log4net.Filter.LevelRangeFilter">
<levelMin value="ERROR" />
<levelMax value="FATAL" />
</filter>
</appender>

<log4net>

好的,如果我设置 <root>水平说ERROR我做了一个 IsEnabledFor (调试)它返回 true但如果我设置 <root>级别为 ALL并在不考虑过滤器的情况下向 appender 添加过滤器。

我如何让它包含 appender 过滤器或者是否有其他查询方法?

最佳答案

我可能是错的,但我不明白如何轻松地做到这一点。你可以做的是这样的:

var hierarchy = LogManager.GetRepository() as Hierarchy;
if(hierarchy != null)
{
var appenders = hierarchy.GetAppenders();
foreach( IAppender appender in appenders)
{
var appenderSkeleton = a as AppenderSkeleton
if (appenderSkeleton != null)
{
IFilter filterHead = appenderSkeleton.FilterHead;
// now analyse the filter chain
}
}
}

我没有测试这段代码,但它应该或多或少可以工作。您通过这种方式获得的是所有派生自 AppenderSkeleton 的附加程序的任何已配置过滤器链的头部。过滤器链的头部实现了 IFilter(和所有过滤器一样),它包含一个方法和一个属性:

FilterDecision Decide(LoggingEvent loggingEvent);   
IFilter Next { get; set; }

现在您可以使用您感兴趣的日志级别创建 LoggingEvent 的实例,并使用 Next 属性遍历过滤器链并测试每个过滤器通过调用 FilterDecision

这会告诉您 appender 是否会接受或拒绝日志记录事件,但您需要注意 appender 也可能会根据其他条件(例如消息内容)进行过滤,因此它不会完全是“IsEnabledFor”实现.

关于c# - Log4Net 以编程方式检查 IsEnabledFor 以获取 Appender 过滤器,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/10124896/

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com