我有以下web.xml文件:
<?xml version="1.0" encoding="UTF-8"?>
<web-app xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns="http://java.sun.com/xml/ns/javaee" xmlns:web="http://java.sun.com/xml/ns/javaee/web-app_2_5.xsd" xsi:schemaLocation="http://java.sun.com/xml/ns/javaee http://java.sun.com/xml/ns/javaee/web-app_2_5.xsd" id="WebApp_ID" version="2.5">
<display-name>jersey sample</display-name>
<servlet>
<servlet-name>Jersey</servlet-name>
<servlet-class>org.glassfish.jersey.servlet.ServletContainer</servlet-class>
<init-param>
<param-name>jersey.config.server.provider.packages</param-name>
<param-value>org.myproject</param-value>
</init-param>
<load-on-startup>1</load-on-startup>
</servlet>
<servlet-mapping>
<servlet-name>Jersey</servlet-name>
<url-pattern>/*</url-pattern>
</servlet-mapping>
</web-app>
它可以正常工作,如果我转到localhost:8080 / myproject / api / ping,则可以得到预期的响应。
但是,如果我将“url-pattern”更改为“/ api / *”,则对相同URL的请求将返回404。
您知道为什么会发生这种情况吗?
这是我的其余配置。
build.gradle:
group 'myproject'
version '0.0'
apply plugin: 'java'
apply plugin: 'war'
apply plugin: 'jetty'
sourceCompatibility = 1.8
repositories {
mavenCentral()
}
dependencies {
compile 'org.glassfish.jersey.containers:jersey-container-servlet:2.14'
testCompile 'org.testng:testng:5.14.2'
}
test {
...
}
我的代码:
package org.myproject;
import javax.ws.rs.GET;
import javax.ws.rs.Path;
import javax.ws.rs.Produces;
import javax.ws.rs.core.MediaType;
@Path("/api")
public class Api {
@GET
@Path("/ping")
@Produces(MediaType.TEXT_PLAIN)
public String ping() {
return "Pong!";
}
}
我使用以下命令运行该应用程序:
./gradlew clean jettyRunWar
最佳答案
url-pattern是servlet(在本例中为Jersey servlet)的前缀或基础。这就是servlet容器如何知道将请求发送到哪个servlet的方式。
因此,使用/api/*
告诉servlet容器,Jersey应用程序的基础是/api
。这个基础实际上只对servlet容器重要。 Jersey处理/映射完所有内容。
因此,对/api/ping
的请求首先被截断了/api
,因为它只是应用程序基础。然后Jersey尝试将/ping
定位为根资源类,这意味着它应该是@Path("ping")
的类注释。由于找不到它,您得到404。
因此,如果您将/api/*
与当前代码一起添加,则请求应为/api/api/ping
通常,您不希望在资源类上使用应用程序基本名称。您应该只在资源类上添加@Path("ping")
,并将/api/*
保留在映射中。只需从@Path
中取出ping()
批注