1

我想知道是否可以将请求从 servlet 分派到 Jersey(JAX-RS 实现)资源类。我正在尝试这样做,但它似乎不起作用,并且根据我的日志记录,从未达到球衣资源。

代码示例如下。由于某种原因,我试图做的事情是不可能的吗?

请注意,当我通过地址栏直接在网络浏览器中访问泽西资源时,它可以正常工作。

另请注意,“RequestDispatcher.forward()”按预期工作。只是“包含”没有。

小服务程序

//The Jersey dispatcher url-filter is set to '/api/*'
String servletID = "/api/items";
RequestDispatcher dispatcher = getServletContext().getRequestDispatcher(servletID);
dispatcher.include(request, response);    

泽西岛资源

@GET @Path("/items")
@Produces ({MediaType.TEXT_XML})
public JAXBElement<Items> getItems(@PathParam("project") String project) throws       IOException, JAXBException {

    log.debug("reached getItems");

    //Omitted code that returns 'Items' object wrapped in JAXBElement

}

web.xml 的相关部分

<servlet>
    <servlet-name>jerseyDispatcher</servlet-name>
    <servlet-class>org.glassfish.jersey.servlet.ServletContainer</servlet-class>
    <init-param>
        <param-name>jersey.config.server.provider.packages</param-name>
        <param-value>uk.co.web.api.resource</param-value>
    </init-param>
</servlet>

<servlet-mapping>
    <servlet-name>jerseyDispatcher</servlet-name>
    <url-pattern>/api/*</url-pattern>
</servlet-mapping>
4

2 回答 2

0

您可以转发请求。

HttpServletRequest httpServletRequest = (HttpServletRequest) servletRequest;
RequestDispatcher requestDispatcher = null;
requestDispatcher = httpServletRequest.getRequestDispatcher("/items");
dispatcher.forward(request, response);
return;

但是请注意,如果您收到 GET 请求并尝试转发到 POST 资源,它将引发 405 错误。

编辑:

让我了解您要实现的目标,如果您需要将内容写入响应输出流,您可以使用 jersey 资源过滤器。

 public class YourResourceFilter implements ResourceFilter
    {
    public ContainerRequestFilter getRequestFilter()
        {
            return new ContainerRequestFilter()
            {
                @Override
                public ContainerRequest filter(ContainerRequest containerRequest)
                {
//Pre- editing the request
                return containerRequest;
                }
            };
        }

    @Override
        public ContainerResponseFilter getResponseFilter()
        {
            return new ContainerResponseFilter()
            {
                @Override
                public ContainerResponse filter(ContainerRequest containerRequest, ContainerResponse containerResponse)
                {
// after the request has been completed by your jersey resource
                    return containerResponse;
                }
            };
        }

    }
于 2014-01-16T07:55:39.923 回答
0

我通过在 web.xml 中将 Jersey 配置为过滤器而不是 servlet 来让它工作,有点像(Jersey 2.13)。然后,您可以告诉容器也将过滤器应用于包含的请求:

<filter-mapping>
    <filter-name>Jersey Web Application</filter-name>
    <url-pattern>/api/*</url-pattern>
    <dispatcher>FORWARD</dispatcher>
    <dispatcher>INCLUDE</dispatcher>
    <dispatcher>REQUEST</dispatcher>
</filter-mapping>

RequestDispatcher.include 然后也将适用于由 Jersey 处理的请求。不过,有一个警告。Jersey 调用 response.getOutputStream,因此所有输出必须通过所述输出流执行 - 这排除了使用 response.getWriter 的 JSP 页面。因此,除非您弄清楚如何解决该问题,否则不要在 JSP 页面中包含 Jersey 资源,反之亦然,包括评估 JSP 的结果作为 REST 响应的一部分。

于 2014-10-06T12:39:54.180 回答