Java EE中的log4j postgres

FAj*_*jir 6 java postgresql log4j jdbc java-ee

经过多次搜索,我终于认为我的问题的解决方案是问你.

所以我的问题是在我的Web应用程序利用率上创建日志的方式.

我找到了log4j java库,但我不明白它是如何工作的..

我必须在哪里创建配置文件?

在哪里以及如何参考?

我可以创建一个连接到postgres的类和insertin log我的三个参数吗?

这是我在网上发现的:

./src/log4j/log4j.properties

log4j.rootCategory = FATAL, CONSOLE
# definition de l'appender console
log4j.appender.CONSOLE=org.apache.log4j.ConsoleAppender
log4j.appender.CONSOLE.layout=org.apache.log4j.PatternLayout
log4j.appender.CONSOLE.layout.ConversionPattern = %d [%t] %-5p %c - %m%n

# definition de l'appender JDBC
log4j.appender.JDBC=org.apache.log4j.jdbcplus.JDBCAppender
log4j.appender.JDBC.layout=org.apache.log4j.PatternLayout
# appender pour base postgresql
log4j.appender.JDBC.dbclass=org.postgresql.Driver
# parametres de la base
log4j.appender.JDBC.url=jdbc:postgresql://127.0.0.1:5432/baseSQL
log4j.appender.JDBC.username=user
log4j.appender.JDBC.password=password
# requete sql qui decoupe le message suivant les barres verticales et fait l'insert dans la table
log4j.appender.JDBC.sql=INSERT INTO logs (id, user, info1, info2, timestamp) VALUES (nextval('sequence_logs'), split_part('@MSG@','|',1), split_part('@MSG@','|',2), split_part('@MSG@','|',3), '@TIMESTAMP@')

#declaration des loggers de l'application
log4j.logger.paquetage.de.mon.appli=FATAL, CONSOLE
log4j.logger.loggerDB=INFO,JDBC
# definition de non additivite des loggers
log4j.additivity.loggerDB=false
Run Code Online (Sandbox Code Playgroud)

SRC/log4j的/ LogsInfos.java

package log4j;

import org.apache.log4j.Logger;

public final class LogsInfos {

    /** Declaration du Logger DB. */
    private static Logger loggerDB = Logger.getLogger("loggerDB");

    /**
     * Enregistre le log.
     * @param param parametres du log
     */
    public static void enregistreLog(String user, String action, String sujet) {
//      Date date=new Date();
        if (loggerDB.isInfoEnabled()) {
            // creation du message final
            final String log = new StringBuffer(user).append(action).append(sujet).toString();
            // envoi du log au logger base
            loggerDB.info(log);
        }
    }
}
Run Code Online (Sandbox Code Playgroud)

在我的包中打电话

LogsInfos.enregistreLog((String)session.getAttribute("cn"),"Suppression",personne.getCn());
Run Code Online (Sandbox Code Playgroud)

我可以使用我选择的对象吗?

这段代码是解决方案吗?如果是,我必须调用配置文件?

编辑:这是执行时的控制台错误消息:

log4j:ERROR Could not instantiate class [org.apache.log4j.jdbcplus.JDBCAppender].
java.lang.ClassNotFoundException: org.apache.log4j.jdbcplus.JDBCAppender
...
log4j:ERROR Could not instantiate appender named "JDBC".
log4j:WARN No appenders could be found for logger (loggerDB).
log4j:WARN Please initialize the log4j system properly.
log4j:WARN See http://logging.apache.org/log4j/1.2/faq.html#noconfig for more info.
Run Code Online (Sandbox Code Playgroud)

Ant*_*oly 3

您的类路径中缺少 jdbcappender.jar。我想您正在寻找这个。或者您可以使用官方的 JDBCAppender,但我不确定它是否足够强大以满足您的需求。

我必须在哪里创建配置文件?

大多数人在应用程序根目录中创建它,但我确信您的应用程序可以正常读取。

在哪里以及如何进行参考?

你真的不需要,如果配置文件和库都在类路径中,你所需要的只是一个 Logger 实例。

我可以创建一个连接到 postgres 并插入记录我的三个参数的类吗?

是的。你走在正确的轨道上。只需将所需的 jar 放入类路径中并确保您的log4j.appender.JDBC.sql线路正常工作即可。您将使用 Logger 类方法,它将为您处理所有事情。

干杯,