在Glassfish上调用Jersey 2 REST端点时出现404



这是我的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>
这是我的简单web服务:
@Path("partner")
public class PartnerAPI {
    @Path("/mt")
    @GET
    @Produces(MediaType.TEXT_PLAIN)
    public String sendMT() {
        return "Sent";
    }
}

当我这样调用它时:

http://localhost:8080/myprojectname/partner/mt

我得到404错误没有发现,我做错了什么?

更新

这是maven

<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>
另一个选择是创建一个基本类来配置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类所在的包名更新字符串。

然后将@ApplicationPath中的值添加到您的URL中。
链接如下所示:http://localhost:8080/myprojectname/test/partner/mt

更多信息:Jersey docs: Chapter 4。部署RESTful Web服务

最新更新