在Java程序中打log

这篇博客介绍了如何在不依赖log4j、slf4j等第三方库的情况下,利用Java自带的java.util.logging包进行日志记录。示例代码展示了如何在Java程序中实现日志打印,包括控制台输出和日志文件写入。
摘要由CSDN通过智能技术生成

rt.不使用log4j、slf等工具,仅用jdk提供的java.util.logging包打log。

代码如下:

/**
 * 项目名:ThinkingInJava
 * 文件名:LoggerUtil.java
 * 模块说明:
 * 修改历史:
 * 作者:ZhuangM
 * 创建日期:2015年12月9日-下午2:42:28
 */
package com.zhuangm.log;

import java.io.File;
import java.io.IOException;
import java.text.SimpleDateFormat;
import java.util.Date;
import java.util.logging.FileHandler;
import java.util.logging.Level;
import java.util.logging.Logger;
import java.util.logging.SimpleFormatter;

public class LoggerUtil {
    // 日志存放的文件夹
    private static String file_name = "D:\\logs";
    private static Logger logger;

    private LoggerUtil() {
    }

    public static Logger getLogger() {
        if (logger == null) {
            logger = Logger.getLogger("a");
            setLoggingProoerties(logger, Level.ALL);
        }
        return logger;
    }

    // 得到日志的路径以及日志的名称
    private static String getLogName() {
        StringBuffer logPath = new StringBuffer();
        logPath.append(file_name);
        File file = new File(logPath.toString());
        if (!file.exists()) {
            file.mkdir();
        }
        logPath.append("\\" + (new SimpleDateFormat("yyyy-MM-dd")).format((new Date())) + ".log");
        return logPath.toString();
    }

    // 配置Logger对象输出日志文件路径
    private static void setLoggingProoerties(Logger logger, Level level) {
        FileHandler fh;
        try {
            fh = new FileHandler(getLogName(), true);
            logger.addHandler(fh);
            logger.setLevel(level);
            fh.setFormatter(new SimpleFormatter());
        } catch (SecurityException se) {
            logger.log(Level.SEVERE, "安全性错误", se);
        } catch (IOException ioe) {
            logger.log(Level.SEVERE, "读取日志文件错误", ioe);
        }
    }
}

测试代码:

/**
 * 项目名:ThinkingInJava
 * 文件名:Test.java
 * 模块说明:
 * 修改历史:
 * 作者:ZhuangM
 * 创建日期:2015年12月9日-下午3:41:10
 */
package com.zhuangm.log;

import java.util.logging.Level;

public class Test {
    public static void main(String[] args) {
        LoggerUtil.getLogger().log(Level.INFO, "aaaaaaa");
        LoggerUtil.getLogger().log(Level.WARNING, "vvvvvvvv");
        LoggerUtil.getLogger().log(Level.CONFIG, "bbbbbb");

    }
}

控制台输出:

十二月 09, 2015 5:42:11 下午 com.zhuangm.log.Test main
信息: aaaaaaa
十二月 09, 2015 5:42:11 下午 com.zhuangm.log.Test main
警告: vvvvvvvv

log文件内输出:

十二月 09, 2015 5:42:11 下午 com.zhuangm.log.Test main
信息: aaaaaaa
十二月 09, 2015 5:42:11 下午 com.zhuangm.log.Test main
警告: vvvvvvvv
十二月 09, 2015 5:42:11 下午 com.zhuangm.log.Test main
配置: bbbbbb

end.

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值