【问题标题】:Log console output to a log file Java logger将控制台输出记录到日志文件 Java logger
【发布时间】:2016-10-01 18:38:36
【问题描述】:

我正在尝试使用 Java Logger 类将我的所有控制台输出写入日志文件。

public static Logger logger = Logger.getLogger("Log");  
public static FileHandler fh; 
public static ConsoleHandler handler = new ConsoleHandler();
public static DateFormat dateFormat = new SimpleDateFormat("yyyy_MM_dd_HH_mm_ss");
public static Calendar cal = Calendar.getInstance();

/**
 * Launch the application.
 * @param args
 * @throws IOException
 */

/* -- START MAIN -- */
public static void main(String[] args) throws IOException {
    Settings.settingsRead();

    try {  
        // This block configure the logger with handler and formatter  
        fh = new FileHandler("logs/hudedit_log_" + dateFormat.format(cal.getTime()) + ".log");  
        logger.setLevel(Level.ALL);
        handler.setFormatter(new SimpleFormatter());
        logger.addHandler(handler);
        logger.info("hello world");
        logger.addHandler(fh);
        SimpleFormatter formatter = new SimpleFormatter();  
        fh.setFormatter(formatter);  

        logger.info("Test");  

    } catch (SecurityException e) {  
        e.printStackTrace();  
    } catch (IOException e) {  
        e.printStackTrace();  
    } 

我如何做到这一点,以便将输出到控制台的所有内容高效地写入文件,而不是将 logger.info("无论我想输出的东西”);无处不在?

【问题讨论】:

    标签: java file logging console output


    【解决方案1】:

    我认为你应该使用 Log4j。

    http://logging.apache.org/log4j/2.x/

    这个套路很复杂。

    【讨论】: