Отображение сервлета Jersey /* вызывает ошибку 404 для статических ресурсов
Если я сопоставлю шаблон URL Джерси с /* в версии 2.0, это вызовет 404 для всех статических ресурсов (например, /index.html). Мой 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?
2 ответа
С Jersey 1.x вы сможете передавать статический контент по тому же пути, если переключитесь с сервлета Jersey на фильтр. Удалите указанный вами 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>
РЕДАКТИРОВАТЬ: В Джерси 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>
И ваше ПОМ должно включать в себя:
<dependency>
<groupId>org.glassfish.jersey.core</groupId>
<artifactId>jersey-server</artifactId>
<version>2.0-m07-1</version>
<type>jar</type>
<scope>compile</scope>
</dependency>
<dependency>
<groupId>org.glassfish.jersey.containers</groupId>
<artifactId>jersey-container-servlet-core</artifactId>
<version>2.0-m07-1</version>
<type>jar</type>
<scope>compile</scope>
</dependency>
Вам нужно будет настроить регулярное выражение в init-param, если вы хотите использовать css, jsp и т. Д.
Другим хорошим вариантом является использование версионного пути для ваших сервисов ("/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>
Как и в этом примере, https://github.com/jersey/jersey/blob/2.17/examples/bookstore-webapp/src/main/webapp/WEB-INF/web.xml
Примечание: убедитесь, что вы меняете <servlet>
Конфигурация к <filter>
конфигурации. Джерси ServletContainer
это одновременно HttpServlet
и Filter
, так что вы можете настроить его как в вашем файле web.xml. Для того, чтобы использовать forwardOn404
свойство, Джерси должен быть настроен как фильтр.