5

在搜索了关于java.util.logging 包的在Java 应用程序中实现日志记录在 Swing 应用程序中使用 java.util.logging 包的问题的答案后,我已经找到了问题并想在这里分享我的解决方案。我将其作为一个新问题发布(希望)对实际问题做出简明陈述(这在我之前的问题中并不完全清楚,因为我问的是错误的问题)以及(希望)给出明确的答案。

下面的代码说明了这个问题:

package jdbcloggingsscce;

import java.io.IOException;
import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.SQLException;
import java.util.logging.FileHandler;
import java.util.logging.Handler;
import java.util.logging.Level;
import java.util.logging.Logger;
import java.util.logging.SimpleFormatter;

public class JDBCLoggingSSCCE {
    public static void main(String[] args) throws IOException, SQLException {
        JDBCLoggingSSCCE.initLogger();
        Logger logger = Logger.getLogger(JDBCLoggingSSCCE.class.getName());
        logger.log(Level.INFO, "Starting JDBCLoggingSSCCE");

        Connection conn = DriverManager.getConnection(DB_URL);
        logger.log(Level.INFO, "JDBC Connection created");
    }

    private static void initLogger() throws IOException {
        Handler handler = new FileHandler(JDBCLoggingSSCCE.LOG_FILE_NAME);
        handler.setFormatter(new SimpleFormatter());

        Logger logger = Logger.getLogger("");
        logger.setLevel(Level.ALL);
        logger.addHandler(handler);
    }
    private static final String LOG_FILE_NAME = "jdbcloggingsscce.log";
    private static final String DB_URL = "jdbc:hsqldb:file:db/jdbcloggingsscce.db";
}

此示例使用HyperSQL 数据库引擎 (HSQLDB)的 JDBC 驱动程序。问题是记录了第一条日志消息(“Starting JDBCLoggingSSCCE”),但没有记录第二条消息(“JDBC Connection created”)。

4

1 回答 1

6

解决方案是将名为“hsqldb.reconfig_logging”的系统属性设置为 false。设置此属性的一种方法是将以下代码行添加到initLogger()方法的末尾:

System.setProperty("hsqldb.reconfig_logging", "false");

我相信,只要在调用DriverManager.getConnection(DB_URL). 设置此“hsqldb.reconfig_logging”属性会告诉 HSQLDB JDBC 驱动程序不要从 java.util.logging 包重新配置 Logger。结果是登录应用程序的其余部分按需要继续。当然,HSQLDB 本身也包括日志消息,但处理这些是另一个问答。

于 2012-09-10T14:39:57.673 回答