我正在使用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
技术,请将CustomRequestLog
与Slf4jRequestLogWriter
一起使用。 (额外的好处是可以自定义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);