Maison  >  Article  >  Java  >  Pourquoi le mappage du modèle d'URL de Jersey sur /* provoque-t-il des erreurs 404 pour les ressources statiques dans Jersey 2.0 ?

Pourquoi le mappage du modèle d'URL de Jersey sur /* provoque-t-il des erreurs 404 pour les ressources statiques dans Jersey 2.0 ?

Susan Sarandon
Susan Sarandonoriginal
2024-10-27 08:38:02625parcourir

Why does mapping Jersey's URL pattern to /* cause 404 errors for static resources in Jersey 2.0?

Jersey /* Le mappage de servlet déclenchant des erreurs 404 pour les ressources statiques

Si le modèle d'URL de Jersey est mappé à /* dans Jersey version 2.0, il peut conduire à des erreurs 404 pour toutes les ressources statiques comme index.html. Voici la configuration web.xml à l'origine de ce problème :

<code class="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></code>

Solution pour Jersey 1.x

Dans Jersey 1.x, vous pouvez basculer depuis le servlet Jersey au filtre pour activer la diffusion de contenu statique :

<code class="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></code>

Solution pour Jersey 2.x

Dans Jersey 2.x, utilisez la configuration de filtre suivante :

<code class="xml"><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></code>

Assurez-vous que votre POM inclut :

<code class="xml"><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></code>

Personnalisez l'expression régulière dans le paramètre d'initialisation si vous servez différents types de fichiers statiques (par exemple, CSS, JSP).

Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

Déclaration:
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn