java - 覆盖 log4j.properties

标签 java properties jar log4j propertyconfigurator

我的 java 应用程序引用了一个使用 log4j 日志记录的第 3 方 jar 文件。问题是这个 jar 包含它自己的 log4j.properties 文件,这会导致我的机器上出现访问被拒绝的异常,但我无法控制 jar 文件来更改其内容。

我已经尝试在我的应用程序的类路径中添加我自己的 log4j.properties 文件,但它似乎没有效果。如果我尝试使用 PropertyConfigurator 以编程方式导入我自己的设置,log4j 似乎首先加载 jar 文件的属性文件(导致异常)。

我如何短路 log4j 以忽略第 3 方 jar 文件的 log4j.properties 文件并使用我自己的文件?

最佳答案

有几种方法可以覆盖 log4j.properties,其中之一是:

  • 使用log4j.xml 请看扩展名

另一种方法是:

  • log4j.defaultInitOverride 系统属性设置为任何其他值 那么“false”将导致 log4j 跳过默认的初始化过程(这个过程)。
  • 将资源字符串变量设置为 log4j.configuration 系统属性的值。指定默认初始化文件的首选方法是通过 log4j.configuration 系统属性。如果未定义系统属性 log4j.configuration,则将字符串变量 resource 设置为其默认值“log4j.properties”。
  • 尝试将资源变量转换为 URL。
  • 如果资源变量无法转换为 URL,例如由于 MalformedURLException,则通过调用 org.apache.log4j.helpers.Loader.getResource(resource, Logger.class) 从类路径中搜索资源返回一个 URL。请注意,字符串“log4j.properties”构成了格式错误的 URL。有关搜索位置的列表,请参阅 Loader.getResource(java.lang.String)。
  • 如果找不到 URL,则中止默认初始化。否则,从 URL 配置 log4j。 PropertyConfigurator 将用于解析 URL 以配置 log4j,除非 URL 以“.xml”扩展名结尾,在这种情况下将使用 DOMConfigurator。您可以选择指定自定义配置器。 log4j.configuratorClass 系统属性的值被视为自定义配置器的完全限定类名。您指定的自定义配置器必须实现配置器接口(interface)。

引用:http://logging.apache.org/log4j/1.2/manual.html

关于java - 覆盖 log4j.properties,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/4258849/

相关文章:

java - 扩展静态工厂方法模式

java - 在我的应用程序中显示表查询

java - Add.jsp 和 Update.jsp 或仅一个

c# - 如何编写一个动态搜索 TreeView 的树节点的方法?

c# - 在类之间传递参数 - 使用公共(public)属性或将属性类作为参数传递?

java - 如何从eclipse中调用jar包中的主类?

java - 具有依赖项的可运行 jar

java - ASCII 表中缺少字符 - Java

java - 是否有任何 Java Web 应用程序可以动态地允许发布 .properties 文件的内容并让我修改它?

Java WindowBuilder -> 导出为 .jar(可运行或 Applet)