用户注册



邮箱:

密码:

用户登录


邮箱:

密码:
记住登录一个月忘记密码?

发表随想


还能输入:200字
云代码 - java代码库

java 日志工具类(记录日志)

2012-11-23 作者: 程序猿style举报

[java]代码库

import java.io.File;
import java.io.FileWriter;
import java.io.IOException;
import java.io.InputStream;
import java.io.PrintWriter;
import java.util.Properties;

/**
 * 日志工具类 使用了单例模式,保证只有一个实例。 为了更方便的配置日志文件名,使用属性文件配置。 也可以在程序中指定日志文件名。
 */
public class LogWriter {
	// 日志的配置文件
	public static final String LOG_CONFIGFILE_NAME = "log.properties";
	// 日志文件名在配置文件中的标签
	public static final String LOGFILE_TAG_NAME = "logfile";

	// 默认的日志文件的路径和文件名称
	private final String DEFAULT_LOG_FILE_NAME = "./logtext.log";
	// 该类的唯一的实例
	private static LogWriter logWriter;
	// 文件输出流
	private PrintWriter writer;
	// 日志文件名
	private String logFileName;

	/**
	 * 默认构造函数
	 */
	private LogWriter() throws LogException {
		this.init();
	}

	private LogWriter(String fileName) throws LogException {
		this.logFileName = fileName;
		this.init();
	}

	/**
	 * 获取LogWriter的唯一实例。
	 * 
	 * @return
	 * @throws LogException
	 */
	public synchronized static LogWriter getLogWriter() throws LogException {
		if (logWriter == null) {
			logWriter = new LogWriter();
		}
		return logWriter;
	}

	public synchronized static LogWriter getLogWriter(String logFileName)
			throws LogException {
		if (logWriter == null) {
			logWriter = new LogWriter(logFileName);
		}
		return logWriter;
	}

	/**
	 * 往日志文件中写一条日志信息 为了防止多线程同时操作(写)日志文件,造成文件”死锁”。使用synchronized关键字
	 * 
	 * @param logMsg
	 *            日志消息
	 */
	public synchronized void log(String logMsg) {
		this.writer.println(new java.util.Date() + ": " + logMsg);
	}

	/**
	 * 往日志文件中写一条异常信息 使用synchronized关键字。
	 * 
	 * @param ex
	 *            待写入的异常
	 */
	public synchronized void log(Exception ex) {
		writer.println(new java.util.Date() + ": ");
		ex.printStackTrace(writer);
	}

	/**
	 * 初始化LogWriter
	 * 
	 * @throws LogException
	 */
	private void init() throws LogException {
		// 如果用户没有在参数中指定日志文件名,则从配置文件中获取。
		if (this.logFileName == null) {
			this.logFileName = this.getLogFileNameFromConfigFile();
			// 如果配置文件不存在或者也没有指定日志文件名,则用默认的日志文件名。
			if (this.logFileName == null) {
				this.logFileName = DEFAULT_LOG_FILE_NAME;
			}
		}
		File logFile = new File(this.logFileName);
		try {
			// 其中的FileWriter()中的第二个参数的含义是:是否在文件中追加内容
			// PrintWriter()中的第二个参数的含义是:自动将数据flush到文件中
			writer = new PrintWriter(new FileWriter(logFile, true), true);
			System.out.println("日志文件的位置:" + logFile.getAbsolutePath());
		} catch (IOException ex) {
			String errmsg = "无法打开日志文件:" + logFile.getAbsolutePath();
			// System.out.println(errmsg);
			throw new LogException(errmsg, ex);
		}
	}

	/**
	 * 从配置文件中取日志文件名
	 * 
	 * @return
	 */
	private String getLogFileNameFromConfigFile() {
		try {
			Properties pro = new Properties();
			// 在类的当前位置,查找属性配置文件log.properties
			InputStream fin = getClass().getResourceAsStream(
					LOG_CONFIGFILE_NAME);
			if (fin != null) {
				pro.load(fin);// 载入配置文件
				fin.close();
				return pro.getProperty(LOGFILE_TAG_NAME);
			} else {
				System.err.println("无法打开属性配置文件: log.properties");
			}
		} catch (IOException ex) {
			System.err.println("无法打开属性配置文件: log.properties");
		}
		return null;
	}

	// 关闭LogWriter
	public void close() {
		logWriter = null;
		if (writer != null) {
			writer.close();
		}
	}

	public static void main(String[] args) {
		LogWriter logger = null;
		try {
			String fileName = "C:/temp/temp0/logger.log";
			logger = LogWriter.getLogWriter(fileName);
			logger.log("First log!");
			logger.log("第二个日志信息");
			logger.log("Third log");
			logger.log("第四个日志信息");
			logger.close();
		} catch (LogException e) {
			e.printStackTrace();
		}
	}
}


网友评论    (发表评论)

共1 条评论 1/1页

发表评论:

评论须知:

  • 1、评论每次加2分,每天上限为30;
  • 2、请文明用语,共同创建干净的技术交流环境;
  • 3、若被发现提交非法信息,评论将会被删除,并且给予扣分处理,严重者给予封号处理;
  • 4、请勿发布广告信息或其他无关评论,否则将会删除评论并扣分,严重者给予封号处理。


扫码下载

加载中,请稍后...

输入口令后可复制整站源码

加载中,请稍后...