Jersey /* 静的リソースの 404 エラーを引き起こすサーブレット マッピング
問題:
Jersey 2.0 では、 Jersey の URL パターンを /* にマッピングすると、すべての静的リソース (/index.html など) で 404 エラーが発生します。
解決策:
Jersey 1 を使用します。 x では、サーブレットの代わりにフィルターを使用することで、同じパスから静的コンテンツを提供できます。提供されたサーブレット XML を次のものに置き換えます:
<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>
Jersey 2.x の編集:
次の XML 構成を使用します:
<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>
Jersey 2.x の Gradle 依存関係:
<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>
注:
他のファイル タイプを処理するには、フィルター設定の staticContentRegex パラメーターをカスタマイズします (例: .css、.jsp)。
以上がフィルター構成を使用して Jersey 2.0 で静的リソースを提供するにはどうすればよいですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。