我想知道是否有可能通过属性文件在log4j.xml中设置一个属性。例如log4j.xml:
<?xml version="1.0" encoding="iso-8859-1"?>
<!DOCTYPE log4j:configuration SYSTEM "log4j.dtd">
<log4j:configuration>
<appender name="CONSOLE" class="org.apache.log4j.ConsoleAppender">
<param name="target" value="System.out" />
<layout class="org.apache.log4j.PatternLayout">
<param name="ConversionPattern" value="%d{ISO8601} %-5p [%c{1}] - %l - %m%n "/>
</layout>
</appender>
<appender name="FILE" class="org.apache.log4j.FileAppender">
<param name="File" value="\D:\ReadText_File\log4jlogss.txt"/>
<param name="Append" value="true"/>
<layout class="org.apache.log4j.PatternLayout">
<param name="ConversionPattern" value="%d{ISO8601} %-5p [%c{1}]- %l - %m%n"/>
</layout>
</appender>
<logger name="org.apache">
<level value="WARN"/>
</logger>
<root>
<level value="DEBUG"/>
<appender-ref ref="FILE"/>
<appender-ref ref="CONSOLE"/>
</root>
</log4j:configuration>
我想使用属性文件指定文件的路径,有什么想法吗?
2条答案
按热度按时间1mrurvl11#
关于log4j,当前版本不支持这种类型配置-嵌入属性文件的XML配置。
有关详细信息,您可以查看log4j的源代码。XML解析详细信息位于类DOMConfigurator中。configure
8nuwlpux2#
您可以将Log4j
Lookups
与PropertySubstitution
一起使用:请参阅http://logging.apache.org/log4j/2.x/manual/configuration.html#PropertySubstitution和http://logging.apache.org/log4j/2.x/manual/lookups.html
下面是一个关于StackOverflow的示例:Log4J2 property substitution - default(为了简短起见,据我所知,您可以使用System属性
-Dkey=value
)您也可以尝试使用
${bundle:com.package.Messages:MyKey}
语法来使用属性文件(使用log4j 2.0-rc 1或更高版本),请参见https://stackoverflow.com/a/19303208/1149528。