11

我在 Jetty 9.0.4 中运行 Jersey 2.2 Servlet 以服务 REST 请求。

大多数情况下,一切都很好,请求得到了服务,但我从未见过泽西课程的任何日志。而且我找不到任何说明我需要牺牲哪些鸡才能在 Jersey 2.2 上实现这一点的任何文档

所以我的第一个问题是 - 我需要做什么才能让 Jersey 生成一些日志。

当请求确实运行出错时(例如,因为无法解析 Json 请求正文),Jersey 将抛出一个 ContainerException,其中包含“无法从 START_OBJECT 令牌中反序列化 java.util.ArrayList 实例”等消息。此时它会记录传入的请求正文真的很可爱,这样我就可以检查 Json。我再一次在当前的文档中找不到任何概述这种野兽的东西,尽管我确信有一个。无论如何,在我解决上面的问题 1 之前,它都没有实际意义。

所以我的第二个问题是如何记录传入的请求正文(不中断请求)。

web.xml 中的 Jersey Servlet 配置如下所示:

<servlet >
    <servlet-name>Jersey Servlet</servlet-name>
    <servlet-class>org.glassfish.jersey.servlet.ServletContainer</servlet-class>
    <init-param>
        <param-name>javax.ws.rs.Application</param-name>
        <param-value>au.com.xandar.wirelesstiming.recorder.web.rest.JerseyApplication</param-value>
    </init-param>
    <init-param>
        <param-name>jersey.config.server.provider.classnames</param-name>
        <param-value>org.glassfish.jersey.filter.LoggingFilter</param-value>
    </init-param>
    <load-on-startup>1</load-on-startup>
</servlet>

我的 JerseyApplication 是:

public final class JerseyApplication extends ResourceConfig {

    public JerseyApplication() {
        super(
            //JacksonFeature.class   // Switching on Jackson
            // (My) JerseyLoggingFilter.class       // Log requests using Jersey ContainerRequestFilter 
            MyApplicationEventListener.class        // Log Requests using Jersey RequestEventListener
        );
        packages("au.com.xandar.wirelesstiming.recorder");

        // Enable LoggingFilter & output entity.
        // NB This does NOT generate any log.
        registerInstances(new LoggingFilter(Logger.getLogger(JerseyApplication.class.getName()), true));
    }
}
4

1 回答 1

12

泽西岛本身并没有记录太多。对于 2.x,我们正在开发一种开发模式,其中包括跟踪支持(请参阅Jersey 中的跟踪)、传入请求/传出响应的默认日志记录(包括实体主体和跟踪消息)。这个功能应该很快就出来了。

关于您的第二个问题 - 您可以注册LoggingFilter,它能够记录传入请求/传出响应(方法、标头、..)以及实体主体(配置时)。您可以通过以下方式配置它(第三个选项说明如何打开实体日志记录):

web.xml(将其添加到 JAX-RS servlet 定义中):

<init-param>
    <param-name>jersey.config.server.provider.classnames</param-name>
    <param-value>org.glassfish.jersey.filter.LoggingFilter</param-value>
</init-param>

Application扩大:

public class MyApplication extends Application {

    @Override
    public Set<Class<?>> getClasses() {
        return new HashSet<Class<?>>() {{
            // Add your resources.
            add(HelloWorldResource.class);

            // Add LoggingFilter.
            add(LoggingFilter.class);
        }};
    }
}

ResourceConfig实例(演示也在此处输出实体):

public class MyApplication extends ResourceConfig {

    public MyApplication() {
        // Resources - add your package name here to enable package scanning.
        packages(...);

        // Enable LoggingFilter & output entity.     
        registerInstances(new LoggingFilter(Logger.getLogger(MyApplication.class.getName()), true));
    }
}
于 2013-08-16T08:52:56.270 回答