自己写的简易版Java日志类分享_Java教程-查字典教程网
自己写的简易版Java日志类分享
自己写的简易版Java日志类分享
发布时间:2016-12-28 来源:查字典编辑
摘要:/****/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学习
    编程开发子分类