Отображение сервлета Джерси /* вызывает ошибку 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?

Ответ 1

С Jersey 1.x вы должны будете ставить статический контент с одного и того же пути, если переключитесь с сервлета Джерси на фильтр. Отбросьте 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>

И ваш POM должен включать:

<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/*" ), а затем статический контент будет работать без фильтра.

Ответ 2

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