java utillogging在属性文件中配置过滤器

标签 java maven filter java.util.logging filehandler

我有一个 Maven 项目,我在其中编写了一个 java.util.logging 过滤器,如下所示。

package com.xyz.filters;

import java.util.logging.Filter;
import java.util.logging.LogRecord;

class CustomFilter implements Filter {

 public boolean isLoggable(LogRecord record) {
    return record.getLoggerName().indexOf("com.package.name") != -1;
 }
}

我有一个属性文件,在其中配置了控制台和文件处理程序,除了删除文件中不需要的日志之外,还需要添加一个过滤器。 我添加了过滤器,如下所示:

java.util.logging.FileHandler.filter = com.xyz.filters.CustomFilter

但是没有应用过滤器。我在这里做错了什么。

更新:添加配置文件

    ############################################################
#   Default Logging Configuration File
#
# You can use a different file by specifying a filename
# with the java.util.logging.config.file system property.  
# For example java -Djava.util.logging.config.file=myfile
############################################################

############################################################
#   Global properties
#   NOTE: this configuration file use to get the handler list,
#   Properties(except level property) define for each handler
#   may be not available because LogRecords handover to log4j
#   appenders in runtime.
############################################################

# "handlers" specifies a comma separated list of log Handler 
# classes.  These handlers will be installed during VM startup.
# Note that these classes must be on the system classpath.
# By default we only configure a ConsoleHandler, which will only
# show messages at the INFO and above levels.
#handlers= java.util.logging.ConsoleHandler

# To also add the FileHandler, use the following line instead.
#handlers= java.util.logging.FileHandler
# Add org.wso2.carbon.bootstrap.logging.handlers.LogEventHandler to handlers if you need to push java logs to LOGEVENT appender

handlers=java.util.logging.FileHandler, java.util.logging.ConsoleHandler

# Default global logging level.
# This specifies which kinds of events are logged across
# all loggers.  For any given facility this global level
# can be overriden by a facility specific level
# Note that the ConsoleHandler also has a separate level
# setting to limit messages printed to the console.
.level= INFO

############################################################
# Handler specific properties.
# Describes specific configuration info for Handlers.
#

java.util.logging.FileHandler.level = FINE
java.util.logging.FileHandler.pattern = /path/to/custom.log
java.util.logging.FileHandler.limit = 50000
java.util.logging.FileHandler.count = 1
java.util.logging.FileHandler.formatter = java.util.logging.SimpleFormatter
java.util.logging.SimpleFormatter.format = [%1$tY-%1$tm-%1$td %1$tk:%1$tM:%1$tS,%1$tL]  %4$s {%2$s} - %5$s %6$s %n
java.util.logging.FileHandler.filter = om.xyz.filters.CustomFilter

java.util.logging.ConsoleHandler.level = INFO


############################################################
# Facility specific properties.
# Provides extra control for each logger.
############################################################

# For example, set the com.xyz.foo logger to only log SEVERE
# messages:
#com.xyz.foo.level = SEVERE
com.package.name.level = FINE

最佳答案

问题是缺少访问修饰符。

当未使用访问修饰符指定类时,它默认为 private-package,仅在包内可见。因此,FileHandler 将 .filter 属性读取为 null。当它更改为 public 时,过滤器被采用。更正后的代码可以在下面找到。

public class CustomFilter implements Filter {

 public boolean isLoggable(LogRecord record) {
    return record.getLoggerName().indexOf("com.package.name") != -1;
 }
}

关于java utillogging在属性文件中配置过滤器,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/45671014/

相关文章:

java - 如何将字符串传递给不同的方法

java - 如何在python中返回包含sqlalchemy中的对象的列表,类似于java中的List<OrderInfo>

java - 如何使用 Java 中的模式匹配器类从给定的字符串中查找匹配的两个或多个单词?

java - Maven全新安装问题: Failed to configure plugin parameters

javascript - 您如何正确检测浏览器对不透明度的支持?

python - Django 中不存在搜索

python - 根据条件删除 Pandas 组

java - 找到两个数组中最大的数字

java - 如何修复 Travis-ci 上的 Maven PermGen 内存不足错误?

java - Hadoop:使用 Cascading 2.5.1 和 Hadoop 2.2.0 进行文件复制