我正在使用Java Spark(网络框架),并且正在遵循本教程:http://sparkjava.com/tutorials/jetty-request-log以启用日志记录。

但是,以下类给我一个错误:

constructor AbstractNCSARequestLog in class AbstractNCSARequestLog cannot be applied to given types;
                return new AbstractNCSARequestLog() {
                       ^
  required: Writer
  found: no arguments


有问题的课程:

    public class RequestLogFactory {

    private Logger logger;

    public RequestLogFactory(Logger logger) {
        this.logger = logger;
    }

    AbstractNCSARequestLog create() {
        return new AbstractNCSARequestLog() {
            @Override
            protected boolean isEnabled() {
                return true;
            }

            @Override
            public void write(String s) throws IOException {
                logger.info(s);
            }
        };
    }
}

最佳答案

如果要使用老式的NCSA请求日志格式,请使用
Slf4jRequestLog代替AbstractNCSARequestLog(现已弃用)。

如果要使用现代的RequestLog技术,请将CustomRequestLogSlf4jRequestLogWriter一起使用。 (额外的好处是可以自定义requestlog格式)

无论使用哪种方法,都需要将slf4j路由到log4j(通过在类路径中包含slf4j-log4j12-<ver>.jar

然后,您现在可以在命名记录器上捕获请求日志(记录器名称可在Slf4jRequestLogWriter中配置)

例:

Slf4jRequestLogWriter slf4jWriter = new Slf4jRequestLogWriter();
// The name of the logger to write request logs to
slf4jWriter.setLoggerName("my.requestlog");
CustomRequestLog requestLog = new CustomRequestLog(slf4jWriter, CustomRequestLog.NCSA_FORMAT);
server.setRequestLog(requestLog);

10-01 18:36