java - 自定义log4j配置文件路径后,只能使用文件夹形式(war exploded模式)部署,使用war方式部署会出现错误,原因在哪里???
巴扎黑
巴扎黑 2017-04-17 11:09:49
[Java讨论组]

我在web.xml中设置了一个自定义的log4jConfigLocation位置

 <!--Log4J配置-->
<context-param>
<param-name>webAppRootKey</param-name>
<param-value>DPCM.root</param-value>
</context-param>

<context-param>
    <param-name>log4jConfigLocation</param-name>
    <param-value>classpath:conf/log/log4j.xml</param-value>
</context-param>

<context-param>
    <param-name>log4jRefreshInterval</param-name>
    <param-value>60000</param-value>
</context-param>

<listener>
    <listener-class>org.springframework.web.util.Log4jConfigListener</listener-class>
</listener>

在Intellij IDEA 中运行 使用war exploded 模式 也就是 使用文件夹方式部署,可以正常启动, 而使用war方式部署,会得到错误提示

log4j:WARN No appenders could be found for logger (org.springframework.web.context.ContextLoader).
log4j:WARN Please initialize the log4j system properly.
log4j:WARN See http://logging.apache.org/log4j/1.2/faq.html#noconfig for more info.
巴扎黑
巴扎黑

全部回复(1)
怪我咯

估计应该是这个地方的问题:

<context-param>
    <param-name>log4jConfigLocation</param-name>
    <param-value>classpath:conf/log/log4j.xml</param-value>
</context-param>

配置中是加载classpath中conf/log/log4j.xml路径的log4j文件,以文件夹的形式部署,能找到classpath对应路径的文件,以war方式部署无法找到。所以建议看看打包后的war中是否包含指定classpath路径文件

热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送
PHP中文网APP
随时随地碎片化学习
PHP中文网抖音号
发现有趣的

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