作者热门文章
- iOS/Objective-C 元类和类别
- objective-c - -1001 错误,当 NSURLSession 通过 httpproxy 和/etc/hosts
- java - 使用网络类获取 url 地址
- ios - 推送通知中不播放声音
我有一个用 jersey 开发的休息服务,我有一个 ContainerRequestFilters 用于打印请求,如下所示:
<init-param>
<param-name>com.sun.jersey.spi.container.ContainerRequestFilters</param-name>
<param-value>com.sun.jersey.api.container.filter.LoggingFilter</param-value>
</init-param>
并且我在使用 log4j 的 post 方法中有记录器。但是LoggingFilter打印的日志与log4j不同。 LogginFilter 有什么方法可以使用 log4j 的配置吗?
我在 log4j.xml 文件中试过这个:
<logger name="com.sun.jersey.api.container.filter.LoggingFilter">
<level value="info" />
<appender-ref ref="ROOT" />
<appender-ref ref="CONSOLE" />
</logger>
但它不起作用:(
最佳答案
处理此问题的一种方法是为 java 记录器编写一个过滤器,您只需使用 log4j 记录器或您喜欢的任何一种记录消息,并通过始终返回 false 来接收 java 日志记录。
Logger javaLogger = Logger.getLogger(YourClass.class.getName());
javaLogger.setFilter(new Filter() {
@Override
public boolean isLoggable(LogRecord record) {
log4jLogger.info(new Date(record.getMillis()) + " " + record.getLevel() + " " + record.getMessage());
return false;
}
});
this.jerseyClient.register(new LoggingFilter(javaLogger, true));
关于java - 带有 log4j 的 Jersey LoggingFilter,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/20550028/
我有一个用 jersey 开发的休息服务,我有一个 ContainerRequestFilters 用于打印请求,如下所示: com.sun.jersey.spi.container.Con
我正在使用 Jersey 2.3.1、Tomcat 7.0、maven。 我有一个简单的 Jersey servlet: @Path("/myresource") public class Jerse
我正在尝试在嵌入式 Jetty 设置中为 Jersey 配置 LoggingFilter。使用的胶水代码如下: ServletContainer servletContainer = new Serv
我是一名优秀的程序员,十分优秀!