java中filehandler_配置Java FileHandler日志记录以创建目录(如果不存在)

本文介绍如何在Java中使用FileHandler进行日志记录,特别是当指定的日志文件目录不存在时,如何自动创建该目录。通过示例代码展示了在FileHandler中设置文件并检查或创建父目录的过程,以及扩展RollingFileAppender以添加更多功能的方法。
摘要由CSDN通过智能技术生成

似乎log4j版本1.2.15这样做.

这是代码的代码片段

public

synchronized

void setFile(String fileName, boolean append, boolean bufferedIO, int bufferSize)

throws IOException {

LogLog.debug("setFile called: "+fileName+", "+append);

// It does not make sense to have immediate flush and bufferedIO.

if(bufferedIO) {

setImmediateFlush(false);

}

reset();

FileOutputStream ostream = null;

try {

//

// attempt to create file

//

ostream = new FileOutputStream(fileName, append);

} catch(FileNotFoundException ex) {

//

// if parent directory does not exist then

// attempt to create it and try to create file

// see bug 9150

//

String parentName = new File(fileName).getParent();

if (parentName != null) {

File parentDir = new File(parentName);

if(!parentDir.exists() && parentDir.mkdirs()) {

ostream = new FileOutputStream(fileName, append);

} else {

throw ex;

}

} else {

throw ex;

}

}

Writer fw = createWriter(ostream);

if(bufferedIO) {

fw = new BufferedWriter(fw, bufferSize);

}

this.setQWForFiles(fw);

this.fileName = fileName;

this.fileAppend = append;

this.bufferedIO = bufferedIO;

this.bufferSize = bufferSize;

writeHeader();

LogLog.debug("setFile ended");

}

这段代码来自FileAppender,RollingFileAppender扩展FileAppender.

这里不检查我们是否拥有创建父文件夹的权限,但如果父文件夹不存在,则会尝试创建父文件夹.

EDITED

如果您想要一些额外的功能,您可以随时扩展RollingFileAppender并覆盖setFile()方法.

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值