手机
当前位置:查字典教程网 >编程开发 >Java >自己写的简易版Java日志类分享
自己写的简易版Java日志类分享
摘要:/****/importjava.io.File;importjava.io.FileWriter;importjava.io.IOExce...

/** * */ import java.io.File; import java.io.FileWriter; import java.io.IOException; import java.text.SimpleDateFormat; import java.util.Date; /** * @author magic282 * */ public class Logger { private static String logFilePath; private static boolean isInitialized = false; private static FileWriter logWriter = null; private static boolean printLogWhenLog = true; private static boolean InitLogger() { String logDirectoryPath = System.getProperty("user.dir") + java.io.File.separatorChar + "log"; if (!new File(logDirectoryPath).exists()) { new File(logDirectoryPath).mkdir(); } Date logfileDate = new Date(); SimpleDateFormat dateFormat = new SimpleDateFormat( "yyyy-MM-dd-HH-mm-ss"); logFilePath = logDirectoryPath + java.io.File.separatorChar + dateFormat.format(logfileDate) + ".log"; try { logWriter = new FileWriter(logFilePath, true); isInitialized = true; } catch (IOException e) { // TODO Auto-generated catch block System.err.println("Unable to create log file."); System.err.println("Initilization fail."); e.printStackTrace(); return false; } return true; } public static void Log(String message) { if (!isInitialized) { InitLogger(); } Date logfileDate = new Date(); SimpleDateFormat dateFormat = new SimpleDateFormat( "yyyy-MM-dd-HH-mm-ss"); String callingClassName = new Exception().getStackTrace()[1] .getClassName(); synchronized (logWriter) { String log = String.format("[%s] @ [%s]: %sn", callingClassName, dateFormat.format(logfileDate), message); if (printLogWhenLog) { System.out.printf("[log]:%s", log); } try { logWriter.write(log); logWriter.flush(); } catch (IOException e) { // TODO Auto-generated catch block System.err.println("Write log to file %s error."); e.printStackTrace(); } } } public static void Log(Exception exception) { if (!isInitialized) { InitLogger(); } Date logfileDate = new Date(); SimpleDateFormat dateFormat = new SimpleDateFormat( "yyyy-MM-dd-HH-mm-ss"); String callingClassName = new Exception().getStackTrace()[1] .getClassName(); synchronized (logWriter) { String log = String.format("[%s] @ [%s]: %sn", callingClassName, dateFormat.format(logfileDate), exception.toString()); if (printLogWhenLog) { System.out.printf("[log]:%s", log); } try { logWriter.write(log); logWriter.flush(); } catch (IOException e) { // TODO Auto-generated catch block System.err.println("Write log to file %s error."); e.printStackTrace(); } } } }

【自己写的简易版Java日志类分享】相关文章:

java基于包结构的请求路由实现实例分享

Java排序实现的心得分享

Java读取Excel文件内容的简单实例

史上最全的java随机数生成算法分享

简单学习Java抽象类要点及实例

通过代理类实现java连接数据库(使用dao层操作数据)实例分享

自己写的java日志类和方法代码分享

Java多线程yield心得分享

深入Java对象的地址的使用分析

java中文转全拼工具类分享

精品推荐
分类导航