Отображение сервлета 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 свойство, Джерси должен быть настроен как фильтр.

Другие вопросы по тегам