在JDK中提供了一个日志记录包javautillogging它可以对程序中的日志记录进行相当复杂的控制例如通过它可以指定日志的级别和日志的位置(控制台文件套接字内存缓沖区)也可以创建子记录器通过它可以用程序控制的方式来指定想记录的内容也可以使用配置文件来指定而不需要去改动程序和Logj相比它更简单更轻量级在对日志输出的要求不是很复杂时它无疑是更好的选择 首先我们获得一个LogManager类的一个实例 LogManager lMgr = LogManagergetLogManager(); 然后我们创建记录器并且把它添加到当前的管理器 String thisName = Logpkg; Logger log = LoggergetLogger(thisName); lMgraddLogger(log); 如果我们没有指定日志文件存放的位置则按照jre/lib目录下loggingproperties文件中指定的内容默认是ConsoleHandler意味着日志信息在控制台显示 在程序中我们可以按照级别发布日志信息共有个级别SERVER(最高值)WARNINGINFOCONFIGFINEFINERFINEST(最低值)和OFF(不记录) logserver(error); 我们可以设置记录器的记录级别以忽略低于WARNING级别的消息只有用server和warning记录的信息才能输出 logsetLevel(LevelWARNING); (This message is info);//这条信息会被忽略不会被输出 logwarning(This message is warning);//这条信息会输出 Logger的名字可以是简单的文字也可以是逗号分隔的复合名字一个逗号左边名字相同但是逗号右边具有附加名字的记录器是原型记录器的子记录器例如一个叫Logpkg的记录器和一个叫LogpkgTest的记录器记录器和它的子记录器可以是不同的级别在整个程序中可以只记录SERVER信息对于一个可疑的部分则可以记录其他更多的事件 如果想要同时把日志输出到文件和控制台可以创建一个FileHandler并把它添加到记录器 fh = new FileHandler(runtimelog); logaddHandler(fh); 如果没有特别指定文件格式默认的是XML 通过配置文件来控制日志记录 FileInputStream fi = new FileInputStream(new File(loggingproperties)); lMgrreadConfiguration(fi); 这样做的好处是不需要改变或重新编译程序就可以改变日志记录的状态 配置文件的格式 handlers = javautilloggingFileHandlerjavautilloggingConsoleHandler Level = INFO javautilloggingConsoleHandlerpattern = runtimelog javautilloggingConsoleHandlerlimit = javautillogginunt = javautilloggingConsoleHandlerformatter = javautilloggingXMLFormatter javautilloggingConsoleHandlerlevel = WARNING javautilloggingConsoleHandlerformatter = javautilloggingSimpleFormatter |