[英]Jersey /* servlet mapping causes 404 error for static resources
如果我在 2.0 版本中将 Jersey 的 url-pattern 映射到 /* 它会导致所有静态资源(例如 /index.html)的 404。 我的 web.xml 有:
<servlet>
<servlet-name>JerseyApp</servlet-name>
<servlet-class>org.glassfish.jersey.servlet.ServletContainer</servlet-class>
<init-param>
<param-name>javax.ws.rs.Application</param-name>
<param-value>org.frog.jump.JerseyApp</param-value>
</init-param>
<load-on-startup>1</load-on-startup>
</servlet>
<servlet-mapping>
<servlet-name>JerseyApp</servlet-name>
<url-pattern>/*</url-pattern>
</servlet-mapping>
如何使用相同的 url 模式提供静态内容?
使用 Jersey 1.x,如果您从 Jersey servlet 切换到过滤器,您应该能够从同一路径提供静态内容。 删除您指定的 servlet XML 并将其切换为:
<filter>
<filter-name>Jersey Filter</filter-name>
<filter-class>com.sun.jersey.spi.container.servlet.ServletContainer</filter-class>
<init-param>
<param-name>javax.ws.rs.Application</param-name>
<param-value>org.frog.jump.JerseyApp</param-value>
</init-param>
<init-param>
<param-name>com.sun.jersey.config.property.WebPageContentRegex</param-name>
<param-value>/.*html</param-value>
</init-param>
</filter>
<filter-mapping>
<filter-name>Jersey Filter</filter-name>
<url-pattern>/*</url-pattern>
</filter-mapping>
编辑:在 Jersey 2.x 中,您应该可以做同样的事情,但属性的名称已更改。 尝试类似:
<filter>
<filter-name>Jersey Filter</filter-name>
<filter-class>org.glassfish.jersey.servlet.ServletContainer</filter-class>
<init-param>
<param-name>jersey.config.server.provider.packages</param-name>
<param-value>org.example</param-value>
</init-param>
<init-param>
<param-name>jersey.config.servlet.filter.staticContentRegex</param-name>
<param-value>/.*html</param-value>
</init-param>
</filter>
<filter-mapping>
<filter-name>Jersey Filter</filter-name>
<url-pattern>/*</url-pattern>
</filter-mapping>
你的 POM 应该包括:
<dependency>
<groupId>org.glassfish.jersey.core</groupId>
<artifactId>jersey-server</artifactId>
<version>${jersey2.version}</version>
<type>jar</type>
<scope>compile</scope>
</dependency>
<dependency>
<groupId>org.glassfish.jersey.containers</groupId>
<artifactId>jersey-container-servlet-core</artifactId>
<version>${jersey2.version}</version>
<type>jar</type>
<scope>compile</scope>
</dependency>
<!-- see. https://eclipse-ee4j.github.io/jersey/ for latest version -->
如果要提供 css、jsp 等,则必须在 init-param 中自定义正则表达式。
另一个不错的选择是为您的服务使用版本化路径(“/v1/*”),然后静态内容将在没有过滤器的情况下工作。
你应该添加 forwardOn404 过滤器来解决这个问题
<filter>
<filter-name>org.glassfish.jersey.examples.bookstore.webapp.MyApplication</filter-name>
<filter-class>org.glassfish.jersey.servlet.ServletContainer</filter-class>
<init-param>
<param-name>javax.ws.rs.Application</param-name>
<param-value>org.glassfish.jersey.examples.bookstore.webapp.MyApplication</param-value>
</init-param>
<!-- pass to next filter if Jersey/App returns 404 -->
<init-param>
<param-name>jersey.config.servlet.filter.forwardOn404</param-name>
<param-value>true</param-value>
</init-param>
</filter>
注意:确保将
<servlet>
配置更改为<filter>
配置。 JerseyServletContainer
既是HttpServlet
又是Filter
,因此您可以在 web.xml 中将其配置为任一。 为了使用forwardOn404
属性, Jersey 需要配置为 filter 。
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.