记录log日志文件的工具类

发表于:2007-06-22来源:作者:点击数: 标签:
一直用log4j做日志文件,可是发现它功能虽说很多,但是每个新的log都要添加配置文件信息,还有就是不会创建目录,郁闷之余自己写了一个做日志的工具类,log4j的基本功能都有了,另外添加了自动创建目录的功能和省去了很多配置文件和启动属性的麻烦,用了一段

   

一直用log4j做日志文件,可是发现它功能虽说很多,但是每个新的log都要添加配置文件信息,还有就是不会创建目录,郁闷之余自己写了一个做日志的工具类,log4j的基本功能都有了,另外添加了自动创建目录的功能和省去了很多配置文件和启动属性的麻烦,用了一段时间,感觉很不错。


import java.io.PrintWriter;
import java.io.FileWriter;
import java.io.IOException;
import java.io.File;
import java.util.Calendar;
import java.util.Date;

/**
 * Created by IntelliJ IDEA.
 * User: zhengzhg
 * Mail: snake_country@sina.com
 * Date: 2004-10-13
 * Time: 15:41:40
 * To change this template use File | Settings | File Templates.
 * 记录log日志文件的工具类
 */

public class LogTool {
    private PrintWriter logPrint;
    private String logFile = "";
    private String logName = "";

    /**
     * 配置没有头的log
    */
    public LogTool(){
        checkDate();
    }

    /**
     * 配置log文件名的头
    */
    public LogTool(String logName){
        this.logName = logName;
        checkDate();
    }

    /**
     * 得到log文件名
    */
    private String getLogFile(){
        String date = "";
        Calendar cd = Calendar.getInstance();
        int y = cd.get(Calendar.YEAR);
        int m = cd.get(Calendar.MONTH) + 1;
        int d = cd.get(Calendar.DAY_OF_MONTH);

        date = "./log/" + logName + y + "-";

        if(m < 10)
            date += 0;

        date += m + "-";

        if(d < 10)
            date += 0;

        date += d + ".log";

        return date;
    }

    /**
     * 配置log属性,如果没有新建log文件
    */
    private void newLog(){
        logFile = getLogFile();

        try{
            logPrint = new PrintWriter(new FileWriter(logFile, true), true);
        }catch(IOException e){
            (new File("./log")).mkdir();

            try{
                logPrint = new PrintWriter(new FileWriter(logFile, true), true);
            }catch(IOException ex){
                System.err.println("无法打开日志文件:" + logFile);
                logPrint = new PrintWriter(System.err);
            }
        }
    }

    /**
     * 检查日期如果改变新建log文件
    */
    private void checkDate(){
        if(logFile == null || logFile.trim().equals("") || !logFile.equals(getLogFile())){
            newLog();
        }
    }

    /**
     * 将文本信息写入日志文件,缺省为userdir/log
    */
    public void log(String msg) {
        checkDate();
        logPrint.println(new Date() + ": " + msg);
    }

    /**
     * 将文本信息与异常写入日志文件
    */
    public void log(Throwable e, String msg) {
        checkDate();
        logPrint.println(new Date() + ": " + msg);
        e.printStackTrace(logPrint);
    }
}

原文转自:http://www.ltesting.net