如何使用log4j.xml为日志文件创建文件夹

时间:2013-12-11 14:19:43

标签: java xml logging log4j

我刚刚创建了log4j.xml文件,如

<?xml version="1.0" encoding="UTF-8"?>
<log4j:configuration>
    <appender name="fileAppender" class="org.apache.log4j.RollingFileAppender">
        <param name="Threshold" value="ALL" />
        <param name="MaxFileSize" value="512KB" />
        <param name="MaxBackupIndex" value="10" />
        <param name="File" value="F:/Core_logs/application_log.log" />
        <layout class="org.apache.log4j.PatternLayout">
            <param name="ConversionPattern" value="%d{MMM-dd-yyyy HH:mm:ss:SSS} %-5p %m%n"/>
        </layout>
    </appender>

    <!--sets the priority log level for org.springframework -->
    <logger name="org.springframework">
        <level value="info" />
    </logger>
    <!--sets the default priority log level -->
    <root>
        <priority value="all"></priority>
        <appender-ref ref="fileAppender" />
    </root>
</log4j:configuration>

但我有例外,

java.io.FileNotFoundException: F:\Spring_Core_logs\pointel_Aop.log (The system cannot find the path specified)

如果我在特定位置手动创建了一个文件夹 Core_logs ,则可以正常工作并创建日志文件。

如果文件夹在特定位置不存在,如何创建文件夹?

2 个答案:

答案 0 :(得分:5)

修改

这里也可以帮助您/看起来像是最适合您的解决方案: Configuring Java FileHandler Logging to create directories if they do not exist

似乎log4j版本1.2.15就可以了。从Arun P Johny那里寻找答案,他从log4j源代码中发布了一段代码。我忽略了它,因为它不被接受为答案。

答案 1 :(得分:-1)

用于在日食中创建的Log4j.xml文件

<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE log4j:configuration SYSTEM "log4j.dtd">

<log4j:configuration xmlns:log4j="http://jakarta.apache.org/log4j/" debug="false">

<appender name="fileAppender" class="org.apache.log4j.FileAppender">

<param name="Threshold" value="INFO" />

<param name="Append" value="true" />

<param name="File" value="logfile.log"/>

<layout class="org.apache.log4j.PatternLayout">

<param name="ConversionPattern" value="%d %-5p [%c{1}] %m %n" />

</layout>

</appender>

<root>

<level value="INFO"/>

<appender-ref ref="fileAppender"/>

</root>

</log4j:configuration>"UTF-8"?>