>Java >java지도 시간 >404 오류를 피하면서 Jersey의 범용 URL 매핑으로 정적 콘텐츠를 제공하는 방법은 무엇입니까?

404 오류를 피하면서 Jersey의 범용 URL 매핑으로 정적 콘텐츠를 제공하는 방법은 무엇입니까?

Patricia Arquette
Patricia Arquette원래의
2024-10-29 01:45:30613검색

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

Jersey의 범용 URL 매핑으로 정적 콘텐츠 제공

Jersey는 매핑에서 /* URL 패턴을 광범위하게 사용하므로 다음과 같은 경우 404 오류가 발생할 수 있습니다. HTML 파일과 같은 정적 리소스에 액세스합니다. 이 문제는 매핑이 웹 컨테이너의 정적 콘텐츠 기본 처리와 충돌하기 때문에 발생합니다.

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 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.