この質問はJavaアプリケーションでのロギングの実装に関連していますが、そこにあるサンプルコードでは質問が非常に長くなったため、これまでに学んだことに基づいて新しい質問を開始することにしました。
私がやろうとしていることを説明するために、JFrameを拡張する次のサンプルクラスがあります。
package swingloggingsscce;
import java.io.IOException;
import java.util.logging.FileHandler;
import java.util.logging.Level;
import java.util.logging.Logger;
import java.util.logging.SimpleFormatter;
public class SwingLoggingSSCCE extends javax.swing.JFrame {
public SwingLoggingSSCCE() {
initComponents();
}
private void initComponents() {
logButton = new javax.swing.JButton();
setDefaultCloseOperation(javax.swing.WindowConstants.EXIT_ON_CLOSE);
setTitle("Swing Logging SSCCE");
logButton.setFont(new java.awt.Font("Tahoma", 0, 24)); // NOI18N
logButton.setText("Do Log");
logButton.addActionListener(new java.awt.event.ActionListener() {
public void actionPerformed(java.awt.event.ActionEvent evt) {
logButtonActionPerformed(evt);
}
});
javax.swing.GroupLayout layout = new javax.swing.GroupLayout(getContentPane());
getContentPane().setLayout(layout);
layout.setHorizontalGroup(
layout.createParallelGroup(javax.swing.GroupLayout.Alignment.LEADING)
.addGroup(layout.createSequentialGroup()
.addGap(147, 147, 147)
.addComponent(logButton)
.addContainerGap(146, Short.MAX_VALUE))
);
layout.setVerticalGroup(
layout.createParallelGroup(javax.swing.GroupLayout.Alignment.LEADING)
.addGroup(layout.createSequentialGroup()
.addGap(120, 120, 120)
.addComponent(logButton)
.addContainerGap(143, Short.MAX_VALUE))
);
pack();
}
private void logButtonActionPerformed(java.awt.event.ActionEvent evt) {
Logger.getLogger(SwingLoggingSSCCE.class.getName()).log(Level.INFO, "SwingLoggingFrame.logButtonActionPerformed()");
}
public static void main(String args[]) throws IOException {
SwingLoggingSSCCE.initLogger();
new SwingLoggingSSCCE().setVisible(true);
}
private static void initLogger() throws IOException {
SwingLoggingSSCCE.HANDLER = new FileHandler(SwingLoggingSSCCE.LOG_FILE_NAME);
SwingLoggingSSCCE.HANDLER.setFormatter(new SimpleFormatter());
Logger logger = Logger.getLogger("");
logger.setLevel(Level.INFO);
logger.addHandler(SwingLoggingSSCCE.HANDLER);
}
private javax.swing.JButton logButton;
private static final String LOG_FILE_NAME = "swingloggingsscce.log";
private static FileHandler HANDLER = null;
}
これは期待どおりに機能し、次の「swingloggingsscce.log」ファイルを生成します。
Sep 09, 2012 8:37:43 PM swingloggingsscce.SwingLoggingSSCCE logButtonActionPerformed
INFO: SwingLoggingFrame.logButtonActionPerformed()
現在、メインアプリケーションで同じことを機能させようとしています。これは次のクラスmain()
です:
/*
* This file is part of BBCT.
*
* Copyright 2012 codeguru <codeguru@users.sourceforge.net>
*
* BBCT is free software: you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by
* the Free Software Foundation, either version 3 of the License, or
* (at your option) any later version.
*
* BBCT is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU General Public License for more details.
*
* You should have received a copy of the GNU General Public License
* along with this program. If not, see <http://www.gnu.org/licenses/>.
*/
package bbct;
import bbct.data.BaseballCardIO;
import bbct.data.BaseballCardJDBCIO;
import bbct.exceptions.BBCTIOException;
import bbct.gui.BBCTFrame;
import bbct.gui.GUIResources;
import java.io.IOException;
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;
import javax.swing.JOptionPane;
/**
* This is the driver class for the Baseball Card Tracker program.
*
* @author codeguru <codeguru@users.sourceforge.net>
*/
public class Baseball {
private static final String LOG_FILE_NAME = "log/bbct.log";
/**
* Starts the Baseball Card Tracker by creating and showing the initial
* window.
*
* @param args the command line arguments
*/
public static void main(String[] args) {
try {
Baseball.initLogger();
// ****************** Added this line ******************
Logger.getLogger(Baseball.class.getName()).log(Level.INFO, "Fixing to create a BaseballCardIO object.");
BaseballCardIO bcio = new BaseballCardJDBCIO(GUIResources.DB_URL);
Logger.getLogger(Baseball.class.getName()).log(Level.INFO, "Fixing to show a new frame.");
new BBCTFrame(bcio).setVisible(true);
} catch (BBCTIOException | IOException ex) {
Logger.getLogger(Baseball.class.getName()).log(Level.SEVERE, "Unable to initialize storage.", ex);
JOptionPane.showMessageDialog(null, ex.getMessage(), "Initialization Error", JOptionPane.ERROR_MESSAGE);
}
}
private static void initLogger() throws IOException {
boolean append = true;
Handler handler = new FileHandler(Baseball.LOG_FILE_NAME, append);
handler.setFormatter(new SimpleFormatter());
Logger logger = Logger.getLogger("");
logger.setLevel(Level.INFO);
logger.addHandler(handler);
}
private static final String LOG_FILE_NAME = "log/bbct.log";
}
完全なアプリケーションには24のクラスがあるため、残りのコードは含めません。問題は、BBCTアプリケーションが「log / bbct.log」ファイルを作成するのに、アプリケーションを実行した後、ファイルが空になることです。Baseball
クラスのコードがとどのように違うのかわかりませんSwingLoggingSSCCE
。明らかに何かが違う、そうでなければそれはうまくいくだろう。コードを見るには、新鮮な目が必要だと思います。それまでの間、私は自分でそれを理解しようとします。
よろしくお願いします。
編集:
SwingLoggingSSCCE
コンソールにログ情報も表示されることを忘れましたが、表示されbbct.Baseball
ません。
更新:
さて、私は問題を少し絞り込みました。BaseballCardIO
オブジェクトを作成する前に、Logger.log()への呼び出しを追加しました。これはログファイルに表示されますが、bcio
作成された後のファイルには表示されません。そこから調査を続ける必要があると思います。
**別の更新:**
次のコンストラクターが私のロギングの問題の原因のようです。
public BaseballCardJDBCIO(String url) throws BBCTIOException {
try {
Logger logger = Logger.getLogger(BaseballCardJDBCIO.class.getName());
logger.log(Level.INFO, "Creating BaseballCardJDBCIO object");
logger.log(Level.INFO, "Getting database connection.");
this.conn = DriverManager.getConnection(url);
logger.log(Level.INFO, "Creating table");
this.createTable();
} catch (SQLException ex) {
// TODO: Need a more user-friendly error message.
throw new BBCTIOException(ex);
}
}
の呼び出し後、すべてのロギングが停止しDriverManager.getConnection(url);
ます。いくつかのさらなる調査は、JDBCがjava.util.loggingを使用することを示しています。おそらく、すべてのJDBCログデータは必要ありません。ただし、JDBCは、アプリケーションに追加する必要のあるロギングを妨害しているようです。これはJDBCの「機能」ですか?