404 エラーを回避しながら、Jersey のユニバーサル URL マッピングを使用して静的コンテンツを提供する方法

Patricia Arquette
リリース: 2024-10-29 01:45:30
オリジナル
573 人が閲覧しました

How to Serve Static Content with Jersey's Universal URL Mapping While Avoiding 404 Errors?

Jersey のユニバーサル URL マッピングを使用した静的コンテンツの提供

Jersey ではマッピングで /* URL パターンが広く使用されており、次の場合に 404 エラーが発生することがあります。 HTML ファイルなどの静的リソースへのアクセス。この問題は、マッピングが Web コンテナ内の静的コンテンツのデフォルトの処理と競合するという事実に起因します。

Jersey 1.x での競合の解決

提供するにはJersey 1.x で /* マッピングを使用しているときに静的コンテンツを使用する場合は、Jersey サーブレットからフィルターに切り替えることをお勧めします。これは、web.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 は WebPageContentRegex パターン (この場合は /.*html) に基づいてリクエストをフィルタリングできるようになり、静的リソースが

Jersey 2.x での競合の解決

Jersey 2.x の解決策は 1.x の解決策と似ていますが、若干の変更が加えられています。物件名変更のため。次の web.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>
ログイン後にコピー

さらに、POM ファイルには次の依存関係が含まれている必要があります:

<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 パラメータをカスタマイズできます。

フィルターを使用する代わりに、「/v1/*」などのサービスのバージョン管理されたパスを定義することで、フィルターを必要とせずに静的コンテンツを提供できるようにする別のアプローチがあります。

以上が404 エラーを回避しながら、Jersey のユニバーサル URL マッピングを使用して静的コンテンツを提供する方法の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

ソース:php.cn
このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
著者別の最新記事
人気のチュートリアル
詳細>
最新のダウンロード
詳細>
ウェブエフェクト
公式サイト
サイト素材
フロントエンドテンプレート