无法为 log4j 设置 LevelRangeFilter
我正在使用此属性文件在 Spring 中设置 log4j:
log4j.appender.EMAIL=org.apache.log4j.net.SMTPAppender
log4j.appender.EMAIL.filter=org.apache.log4j.varia.LevelRangeFilter
log4j.appender.EMAIL.filter.levelMin=FATAL
但是得到:
log4j:WARN Failed to set property [filter] to value "org.apache.log4j.varia.LevelRangeFilter".
有什么想法吗?
I am using this property file to setup log4j in Spring:
log4j.appender.EMAIL=org.apache.log4j.net.SMTPAppender
log4j.appender.EMAIL.filter=org.apache.log4j.varia.LevelRangeFilter
log4j.appender.EMAIL.filter.levelMin=FATAL
but getting:
log4j:WARN Failed to set property [filter] to value "org.apache.log4j.varia.LevelRangeFilter".
Any ideas?
如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。
绑定邮箱获取回复消息
由于您还没有绑定你的真实邮箱,如果其他用户或者作者回复了您的评论,将不能在第一时间通知您!
发布评论
评论(3)
来自 PropertyConfigurator 的文档:
我建议您使用 XML 文件来设置它。
From the docs for PropertyConfigurator:
I suggest you use an XML file to set it up instead.
您不需要为此使用过滤器。
log4j.appender.EMAIL.Threshold=致命
You don't need a filter for this.
log4j.appender.EMAIL.Threshold=FATAL
假设您将 apache log4j extras 添加到您的项目中。 尝试在过滤器后添加数字,如下所示:
log4j.appender.EMAIL.filter.1=org.apache.log4j.varia.LevelRangeFilter
不确定是否/在哪里记录了此内容,但我在某处看到了这个一试就成功了。
如果你没有 apache log4j extras 并且你正在使用 maven,只需从 mvnrepository 获取代码片段并将其添加到你的 pom.xml 中,然后重建 maven (mvn eclipse:eclipse)。
Presuming you added the apache log4j extras to your project. Try adding a numeric after filter, like this:
log4j.appender.EMAIL.filter.1=org.apache.log4j.varia.LevelRangeFilter
Not sure if/where this is documented but I saw this somewhere gave it a shot and it worked.
If you don't have apache log4j extras and you're using maven just get the snippet from mvnrepository and add it to your pom.xml then rebuild maven (mvn eclipse:eclipse).