株式会社イーブ|未経験・転職の方も就職可能。Javaプログラマー育成のエキスパート

HOMEJAVA技術者育成システム開発求人情報個人情報保護

第 69 回 ~ ロギングその9 ~

トップページ > Java技術者育成 > Javaワンポイント > 第 69 回 ~ ロギングその9 ~

引き続き「ロギング」をテーマにしていきます。


前回はロギングフォーマットのカスタマイズを学びました。
今回はログメッセージのカスタマイズを学びます。


過去のサンプルではメッセージの出力にLoggerクラスのinfoメソッド等を使用してきました。
しかし、infoメソッド等では、単純な文字列しか表示できませんでした。
今回使用するlogメソッドではメッセージにパラメータを埋め込むことができます。
Stringクラスのformatメソッドをイメージするとわかりやすいでしょう。


以下のサンプルコードでは、パラメータを使用したログを出力します。
非常に簡易的ですが、データベースへの登録処理のログを想定しています。
プログラムを実行すると同じフォルダにログファイルが作成されます。(J2SE1.4以上対応)



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 LogTest {


    public static void main(String[] args) throws Exception {
        insertLog(Level.INFO, "Eeb太郎", "従業員表", "EeB花子");
    }


    public static void insertLog(Level level, String user, String table, String record) throws IOException {


        FileHandler fileHandler = null;
        String pattern = "LogTest%g.log";// 出力ファイルの名前付けのパターン
        boolean append = true;// 追記モードを指定する


        try {


            // Logger取得
            Logger logger = Logger.getLogger(LogTest.class.getName());


            // ロギングされないなら終了
            if (!logger.isLoggable(level)) {
                return;
            }


            // 追記モードでFileHandler作成
            fileHandler = new FileHandler(pattern, append);


            // ログフォーマット変更
            fileHandler.setFormatter(new SimpleFormatter());


            // LoggerにHandler追加
            logger.addHandler(fileHandler);


            // ログ出力
            logger.log(level, "{0}が{1}に{2}を登録しました。", new Object[] { user, table, record });


        } finally {
            if (fileHandler != null) {
                fileHandler.close();
            }
        }
    }
}



メッセージにパラメータが反映されているのが確認できますね。
またlogメソッドを使用する場合、動的にログレベルも変更できることも覚えておきましょう。


[Javaワンポイント]内の前後の記事
第 70 回 ~ ロギングその10 ~
→ 第 69 回 ~ ロギングその9 ~
第 68 回 ~ ロギングその8 ~


■更新日時での前後の記事
9月17日 お天気
→ 第 69 回 ~ ロギングその9 ~
9月16日 お天気