在 Glassfish 上调用 Jersey 2 REST 端点时出现 404
404 when calling Jersey 2 REST endpoint on Glassfish
这是我的web.xml
<servlet>
<servlet-name>Simulator HTTP API</servlet-name>
<servlet-class>org.glassfish.jersey.servlet.ServletContainer</servlet-class>
<load-on-startup>1</load-on-startup>
</servlet>
<servlet-mapping>
<servlet-name>Simulator HTTP API</servlet-name>
<url-pattern>/*</url-pattern>
</servlet-mapping>
</web-app>
这是我的简单网络服务:
@Path("partner")
public class PartnerAPI {
@Path("/mt")
@GET
@Produces(MediaType.TEXT_PLAIN)
public String sendMT() {
return "Sent";
}
}
当我这样称呼它时:
http://localhost:8080/myprojectname/partner/mt
我发现 404 错误 mot,我做错了什么?
更新
这是我的专家
<dependency>
<groupId>org.glassfish.jersey.core</groupId>
<artifactId>jersey-server</artifactId>
<version>2.22.1</version>
</dependency>
<dependency>
<groupId>org.glassfish.jersey.core</groupId>
<artifactId>jersey-common</artifactId>
<version>2.22.1</version>
</dependency>
<dependency>
<groupId>org.glassfish.jersey.core</groupId>
<artifactId>jersey-client</artifactId>
<version>2.22.1</version>
</dependency>
<dependency>
<groupId>org.glassfish.jersey.containers</groupId>
<artifactId>jersey-container-servlet</artifactId>
<version>2.22.1</version>
</dependency>
您在 Jersey 2 中有不同的部署选项:
如果您想通过 web.xml
执行此操作,您必须在指定应扫描哪些包的位置添加一个 init-param
:
<servlet>
<servlet-name>Simulator HTTP API</servlet-name>
<servlet-class>org.glassfish.jersey.servlet.ServletContainer</servlet-class>
<init-param>
<param-name>jersey.config.server.provider.packages</param-name>
<param-value>insert.packagename.where.your.class.is.here</param-value>
</init-param>
</servlet>
另一种选择是创建一个基本的 class 来配置您的 REST 应用程序。
这看起来像这样:
import javax.ws.rs.ApplicationPath;
import org.glassfish.jersey.server.ResourceConfig;
@ApplicationPath("/test")
public class YourApplication extends ResourceConfig {
public YourApplication() {
this.packages("insert.packagename.where.your.class.is.here");
}
}
确保使用 PartnerAPI
class 所在的包名称更新字符串。
然后将 @ApplicationPath
中的值添加到您的 URL。
link 看起来像这样:http://localhost:8080/myprojectname/test/partner/mt
更多信息:Jersey docs: Chapter 4. Deploying a RESTful Web Service
这是我的web.xml
<servlet>
<servlet-name>Simulator HTTP API</servlet-name>
<servlet-class>org.glassfish.jersey.servlet.ServletContainer</servlet-class>
<load-on-startup>1</load-on-startup>
</servlet>
<servlet-mapping>
<servlet-name>Simulator HTTP API</servlet-name>
<url-pattern>/*</url-pattern>
</servlet-mapping>
</web-app>
这是我的简单网络服务:
@Path("partner")
public class PartnerAPI {
@Path("/mt")
@GET
@Produces(MediaType.TEXT_PLAIN)
public String sendMT() {
return "Sent";
}
}
当我这样称呼它时:
http://localhost:8080/myprojectname/partner/mt
我发现 404 错误 mot,我做错了什么?
更新
这是我的专家
<dependency>
<groupId>org.glassfish.jersey.core</groupId>
<artifactId>jersey-server</artifactId>
<version>2.22.1</version>
</dependency>
<dependency>
<groupId>org.glassfish.jersey.core</groupId>
<artifactId>jersey-common</artifactId>
<version>2.22.1</version>
</dependency>
<dependency>
<groupId>org.glassfish.jersey.core</groupId>
<artifactId>jersey-client</artifactId>
<version>2.22.1</version>
</dependency>
<dependency>
<groupId>org.glassfish.jersey.containers</groupId>
<artifactId>jersey-container-servlet</artifactId>
<version>2.22.1</version>
</dependency>
您在 Jersey 2 中有不同的部署选项:
如果您想通过 web.xml
执行此操作,您必须在指定应扫描哪些包的位置添加一个 init-param
:
<servlet>
<servlet-name>Simulator HTTP API</servlet-name>
<servlet-class>org.glassfish.jersey.servlet.ServletContainer</servlet-class>
<init-param>
<param-name>jersey.config.server.provider.packages</param-name>
<param-value>insert.packagename.where.your.class.is.here</param-value>
</init-param>
</servlet>
另一种选择是创建一个基本的 class 来配置您的 REST 应用程序。
这看起来像这样:
import javax.ws.rs.ApplicationPath;
import org.glassfish.jersey.server.ResourceConfig;
@ApplicationPath("/test")
public class YourApplication extends ResourceConfig {
public YourApplication() {
this.packages("insert.packagename.where.your.class.is.here");
}
}
确保使用 PartnerAPI
class 所在的包名称更新字符串。
然后将 @ApplicationPath
中的值添加到您的 URL。
link 看起来像这样:http://localhost:8080/myprojectname/test/partner/mt
更多信息:Jersey docs: Chapter 4. Deploying a RESTful Web Service