转载:http://ju.outofmemory.cn/entry/141660
在开发某个类似报表的功能时,感觉用log4j直接按天滚动生成csv格式的文件很方便,于是研究了一下如何在日志滚动时自动插入表头的方法。
log4j的各种layout都派生自org.apache.log4j.Layout这个抽象类。Layout有一个getHeader()方法,默认返回null,因此只要实现一个你使用的*Layout的子类,重写getHeader方法就可以了。
比如我用的是org.apache.log4j.PatternLayout,所以我的实现类是这样子:
public class CSVLayout extends PatternLayout {
private static final String HEADER = "column1,column2,column3,column4";
@Override
public String getHeader() {
return HEADER + System.getProperty("line.separator");
}
}
同理还有getFooter()方法,可以在文件尾部追加一行内容。
如果你愿意把header放在log4j配置文件里,则可以这样实现:
public class HeaderLayout extends PatternLayout{
private String header;
public void setHeader(String header){
this.header = header;
}
public String getHeader(){
return header+System.getProperty("line.separator");
}
}
同时在配置文件里加上:
log4j.appender.foo.layout.Header=foo,bar,xxx,yyy
这样就可以实现log4j每产生一个新的日志文件都在第一行追加指定内容了。不过有一个不足就是:如果重启程序,则会在当天的文件中产生额外的header。