在Java中处理日志记录

在JDK1.4中提供了一个日志记录包:java.util.logging,它可以对程序中的日志记录进行相当复杂的控制。例如:通过它可以指定日志的级别和日志的位置(控制台、文件、套接字、内存缓冲区),也可以创建子记录器,通过它可以用程序控制的方式来指定想记录的内容,也可以使用配置文件来指定,而不需要去改动程序。和Log4j相比,它更简单更轻量级,在对日志输出的要求不是很复杂时,它无疑是更好的选择。


首先我们获得一个LogManager类的一个实例:


LogManager lMgr = LogManager.getLogManager();


然后我们创建记录器,并且把它添加到当前的管理器:


String thisName = “Logpkg”;


Logger log = Logger.getLogger(thisName);


lMgr.addLogger(log);


如果我们没有指定日志文件存放的位置,则按照jre/lib目录下logging.properties文件中指定的内容,默认是ConsoleHandler意味着日志信息在控制台显示。


在程序中我们可以按照级别发布日志信息,共有7个级别:SERVER(最高值),WARNING,INFO,CONFIG,FINE,FINER,FINEST(最低值),和OFF(不记录)。


log.server(“error”);


我们可以设置记录器的记录级别,以忽略低于WARNING级别的消息,只有用server和warning记录的信息才能输出。


log.setLevel(Level.WARNING);


log.info(“This message is info”);//这条信息会被忽略,不会被输出


log.warning(“This message is warning”);//这条信息会输出