Tomcat webapp で少しログを記録するために log4j を使用したいと考えています。たとえば、ユーザーの情報が要求されたときにアクティビティをログに記録する必要があるデータ アクセス クラスがあります。ファイル ハンドラーとコンソール ハンドラーをルートロガーに追加し、コンソールで正しいログ メッセージを完全に表示できますが、残念ながら、指定されたファイルにはありません。
私のコードは次のとおりです。
imports...
public class UserDao {
private final Logger logger = Logger.getRootLogger();
public UserDao() {
FileAppender fa = new FileAppender();
fa.setLayout(new PatternLayout("%d{yyyy-MM-dd HH:mm:ss.SSSS} %p %t %c \u2013 %m%n"));
fa.setName("UserDaoFileAppender");
fa.setFile("UserDao.log");
fa.setThreshold(Level.INFO);
fa.setAppend(true);
fa.activateOptions();
logger.addAppender(fa);
ConsoleAppender ca = new ConsoleAppender();
ca.setLayout(new PatternLayout("%d{yyyy-MM-dd HH:mm:ss.SSSS} %p %t %c \u2013 %m%n"));
ca.setThreshold(Level.WARN);
ca.activateOptions();
logger.addAppender(ca);
logger.warn("Test warning");
logger.error("Test error");
logger.info("Test info");
logger.debug("test debug");
}
// Rest of the class.
}
アペンダー構成を設定するプロパティファイルの方法を使用しようとしましたが、機能させることができませんでした。ここで何人かの人々が提案しているように、私はそれを WEB-INF/classes フォルダーと src-root の両方に入れてみました。