0

0

解决Tomcat过滤器初始化参数为Null:Log4j 2.x迁移后的配置解析

碧海醫心

碧海醫心

发布时间:2025-08-27 23:41:01

|

480人浏览过

|

来源于php中文网

原创

解决Tomcat过滤器初始化参数为Null:Log4j 2.x迁移后的配置解析

本文旨在解决Tomcat过滤器在从Log4j 1.x迁移到Log4j 2.x后,无法正确获取web.xml中配置的初始化参数问题。核心在于Log4j 2.x配置文件的语法错误导致应用启动异常,进而影响了Servlet过滤器参数的加载。通过提供正确的Log4j 2.x XML配置示例,并详细解释其结构和最佳实践,帮助开发者顺利完成日志框架升级,确保应用功能正常运行。

问题描述

在将java web应用程序的日志框架从log4j 1.x升级到log4j 2.x(例如,从log4j-1.2.15.jar迁移到log4j v2.17.1)后,部署在tomcat 9上的应用程序遇到了一个异常行为。尽管web.xml中为自定义servlet过滤器(例如com.demo.custom.filter.newsession)配置了初始化参数(init-param),但在过滤器init()方法中通过filterconfig.getinitparameter()获取这些参数时,却返回了null值。

例如,以下web.xml配置:


    newsession
    newsession
    newsession
    com.demo.custom.filter.NewSession
    
        DomainName
        .testlab.com
    
    
        DomConfigFile
        /opt/tomcat/webapp/demoapp/WEB-INF/classes/NAM_log4j.xml
    
    
        customPropFile
        /opt/tomcat/webapp/demoapp/WEB-INF/classes/custom_resources.properties
    


    newsession
    /idff/sso

在过滤器NewSession的init方法中,尝试获取参数:

public void init(FilterConfig fConfig) throws ServletException {
    try{
        domainName = fConfig.getInitParameter("DomainName");
        domConfigFile=fConfig.getInitParameter("DomConfigFile");
        custom_resources=fConfig.getInitParameter("customPropFile");
    }catch(Exception e){
        myLogger.error(e.getMessage());
    }
    // ... 后续对null值的处理
    if(domConfigFile==null){
        myLogger.error("domConfigFile got null from web.xml, setting hardcoded value");
        // ...
    }
    if(custom_resources==null){
        myLogger.error("custom_resources got null from web.xml, setting hardcoded value");
        // ...
    }
}

日志中会打印出类似以下错误信息:

ERROR com.demo.custom.filter.NewSession - domConfigFile got null from web.xml, setting hardcoded value
ERROR com.demo.custom.filter.NewSession - custom_resources got null from web.xml, setting hardcoded value
main ERROR Error processing element category ([Configuration: null]): CLASS_NOT_FOUND
main ERROR Unknown object "root" of type org.apache.logging.log4j.core.config.LoggerConfig is ignored: try nesting it inside one of: ["Appenders", "Loggers", "Properties", "Scripts", "CustomLevels"]

这些错误表明,虽然过滤器本身被加载,但其初始化参数未能正确传递。更重要的是,日志中还出现了Log4j 2.x配置相关的错误,暗示问题的根源可能在于Log4j 2.x的配置不当。

根本原因分析

表面上看,问题是过滤器参数获取失败,但结合Log4j 2.x的错误日志,可以推断出更深层次的原因:Log4j 2.x的配置文件存在语法错误或使用了Log4j 1.x的配置元素,导致Log4j 2.x初始化失败,进而影响了整个应用程序的启动流程,包括Servlet容器对web.xml中过滤器参数的正确解析和传递。

具体的错误提示Error processing element category ([Configuration: null]): CLASS_NOT_FOUND和Unknown object "root" of type org.apache.logging.log4j.core.config.LoggerConfig is ignored: try nesting it inside one of: ["Appenders", "Loggers", "Properties", "Scripts", "CustomLevels"]清晰地指出了以下两点:

Endel.io
Endel.io

Endel是一款可以创造个性化舒缓声音的应用程序,可帮助您集中注意力、放松身心和入睡。

下载
  1. category元素: 这是Log4j 1.x配置中用于定义Logger的元素。Log4j 2.x不再使用category,而是使用Logger元素。当Log4j 2.x尝试解析包含category的配置文件时,会因为不识别该元素而报错。
  2. root元素放置错误: 在Log4j 2.x的XML配置中,Root Logger必须嵌套在元素内部,而不是直接作为的子元素。错误信息明确指出"root" ... is ignored: try nesting it inside one of: ["Appenders", "Loggers", ...]。

这些Log4j配置错误可能导致日志系统无法正常初始化,甚至可能中断Tomcat的Web应用部署过程,从而影响到其他组件(如Servlet过滤器)的正常初始化。当Log4j 1.x的JAR包被移除后,Log4j 2.x成为唯一的日志实现,其配置的正确性变得至关重要。

解决方案

解决此问题的关键在于提供一个符合Log4j 2.x规范的、结构正确的XML配置文件。通过修正Log4j 2.x的配置文件,确保其能够正确解析和初始化,从而使应用程序能够顺利启动,并让Tomcat正确加载并传递过滤器初始化参数。

以下是一个修正后的Log4j 2.x配置示例(假设文件名为log4j2.xml或TEST_log4j.xml,并放置在classpath中):

 
    
        
            
        
        
            
                %d{MM/dd HH:mm:ss} %-5p %30.30c %x - %m%n
            
            
                
            
            
        
        
            
                %d{MM/dd HH:mm:ss} %-5p %30.30c %x - %m%n
            
            
                
            
            
        
    
    
        
            
        
        
            
        
        
            
        
    

关键修正点说明

  1. 根元素: 这是Log4j 2.x配置文件的根元素。status="WARN"用于控制Log4j内部日志的输出级别。
  2. 元素: 定义了所有可用的Appender,如Console(输出到控制台)和RollingFile(滚动文件Appender)。
    • PatternLayout中的pattern定义了日志输出格式。注意,Log4j 2.x中换行符通常使用%n而不是\n,虽然两者在多数情况下都有效。
    • RollingFile的filePattern应包含一个索引占位符(如%i)和文件扩展名,以确保滚动日志文件的命名规范。
    • Policies定义了日志文件滚动的策略,例如SizeBasedTriggeringPolicy基于文件大小触发滚动。
    • DefaultRolloverStrategy定义了滚动文件的最大数量。
  3. 元素: 包含所有自定义Logger和Root Logger的定义。
    • 元素: 用于定义特定包或类的日志级别和Appender引用。
      • name属性指定Logger的名称(通常是包名或类名)。
      • level属性设置该Logger的日志级别(如TRACE, DEBUG, INFO, WARN, ERROR, FATAL)。
      • additivity="false"是一个重要属性,表示该Logger的日志不会传递给父级Logger(包括Root Logger),从而避免重复输出。如果希望日志同时被父级Logger处理,则设置为true或省略(默认为true)。
      • 用于将Logger与之前定义的Appender关联起来。
    • 元素: 定义了应用程序的根Logger。
      • level属性设置了所有未明确配置的Logger的默认日志级别。
      • 将根Logger的输出指向名为STDOUT的Console Appender。

通过以上修正,Log4j 2.x配置将符合其规范,能够正确初始化日志系统。一旦日志系统正常工作,Tomcat在部署Web应用时将不再因Log4j配置错误而中断,从而确保过滤器能够正确获取其初始化参数。

最佳实践与注意事项

  1. 移除所有Log4j 1.x JAR包: 在迁移到Log4j 2.x后,务必从应用程序的WEB-INF/lib目录和Tomcat的lib目录中彻底移除所有Log4j 1.x相关的JAR包(如log4j-1.2.x.jar、log4j-extras.jar等),以避免类路径冲突。
  2. 引入正确的Log4j 2.x依赖: 确保项目中引入了Log4j 2.x的核心依赖,至少包括log4j-api-2.x.x.jar和log4j-core-2.x.x.jar。如果使用了SLF4J等门面,还需要引入相应的桥接器(如log4j-slf4j-impl-2.x.x.jar)。
  3. 配置文件命名与位置: Log4j 2.x默认会按特定顺序查找配置文件,例如log4j2.xml、log4j2.json、log4j2.properties。通常将log4j2.xml放置在WEB-INF/classes目录下,使其位于应用程序的classpath中。
  4. 理解Log4j 1.x与2.x配置差异: Log4j 2.x引入了许多新的概念和配置语法(如插件架构、Async Loggers、Configuration、Appenders、Loggers等),与Log4j 1.x有显著不同。在迁移时,不能简单地复制Log4j 1.x的配置文件,而需要根据Log4j 2.x的文档重新编写。
  5. 调试Log4j配置: 可以在标签中添加status="DEBUG"或status="TRACE"属性,让Log4j在启动时输出自身的配置解析信息,这对于调试配置错误非常有帮助。

总结

当Tomcat过滤器在Log4j 2.x迁移后无法获取web.xml中的初始化参数时,应首先检查Log4j 2.x的配置文件。这类问题往往不是过滤器本身的配置错误,而是日志框架初始化失败导致的连锁反应。通过仔细检查并修正Log4j 2.x XML配置中的语法错误和Log4j 1.x遗留元素,确保日志系统能够正常启动,即可解决此类问题,保证Web应用程序的稳定运行。

相关专题

更多
java
java

Java是一个通用术语,用于表示Java软件及其组件,包括“Java运行时环境 (JRE)”、“Java虚拟机 (JVM)”以及“插件”。php中文网还为大家带了Java相关下载资源、相关课程以及相关文章等内容,供大家免费下载使用。

804

2023.06.15

java正则表达式语法
java正则表达式语法

java正则表达式语法是一种模式匹配工具,它非常有用,可以在处理文本和字符串时快速地查找、替换、验证和提取特定的模式和数据。本专题提供java正则表达式语法的相关文章、下载和专题,供大家免费下载体验。

723

2023.07.05

java自学难吗
java自学难吗

Java自学并不难。Java语言相对于其他一些编程语言而言,有着较为简洁和易读的语法,本专题为大家提供java自学难吗相关的文章,大家可以免费体验。

727

2023.07.31

java配置jdk环境变量
java配置jdk环境变量

Java是一种广泛使用的高级编程语言,用于开发各种类型的应用程序。为了能够在计算机上正确运行和编译Java代码,需要正确配置Java Development Kit(JDK)环境变量。php中文网给大家带来了相关的教程以及文章,欢迎大家前来阅读学习。

395

2023.08.01

java保留两位小数
java保留两位小数

Java是一种广泛应用于编程领域的高级编程语言。在Java中,保留两位小数是指在进行数值计算或输出时,限制小数部分只有两位有效数字,并将多余的位数进行四舍五入或截取。php中文网给大家带来了相关的教程以及文章,欢迎大家前来阅读学习。

398

2023.08.02

java基本数据类型
java基本数据类型

java基本数据类型有:1、byte;2、short;3、int;4、long;5、float;6、double;7、char;8、boolean。本专题为大家提供java基本数据类型的相关的文章、下载、课程内容,供大家免费下载体验。

445

2023.08.02

java有什么用
java有什么用

java可以开发应用程序、移动应用、Web应用、企业级应用、嵌入式系统等方面。本专题为大家提供java有什么用的相关的文章、下载、课程内容,供大家免费下载体验。

428

2023.08.02

java在线网站
java在线网站

Java在线网站是指提供Java编程学习、实践和交流平台的网络服务。近年来,随着Java语言在软件开发领域的广泛应用,越来越多的人对Java编程感兴趣,并希望能够通过在线网站来学习和提高自己的Java编程技能。php中文网给大家带来了相关的视频、教程以及文章,欢迎大家前来学习阅读和下载。

16861

2023.08.03

vlookup函数使用大全
vlookup函数使用大全

本专题整合了vlookup函数相关 教程,阅读专题下面的文章了解更多详细内容。

28

2025.12.30

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
Kotlin 教程
Kotlin 教程

共23课时 | 2.1万人学习

C# 教程
C# 教程

共94课时 | 5.7万人学习

Java 教程
Java 教程

共578课时 | 39.8万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号