泽西设置 2 个 servlet

Jersey Setting up 2 servlets

我正在尝试使用 Jersey 设置我的项目,使其基本上具有 2 个 servlet:一个供客户端应用程序访问的私有 servlet,以及一个 public 面向 API 的 servlet。 api 调用是私有调用的子集。 (如果这是相关的,我的客户端是带有 RestyGWT 的 GWT)。我的资源全部存储在:

com.path.to.server.resources.internal
com.path.to.server.resources.api

私有 servlet 应该包含这两个包,而 api 应该只使用 api 包。

我希望我的内部电话看起来像这样:

https://localhost:8445/resources/authentication/login

我的 api 调用看起来像这样:

https://localhost:8445/api/users/getuser

我的 web.xml 看起来像这样:

<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_3_0.xsd" xsi:schemaLocation="http://java.sun.com/xml/ns/javaee http://java.sun.com/xml/ns/javaee/web-app_3_0.xsd" id="WebApp_ID" version="3.0">

    <!-- Servlets -->
    <servlet>
        <servlet-name>javax.ws.rs.core.Application</servlet-name>
        <init-param>
            <param-name>com.sun.jersey.config.property.packages</param-name>
            <param-value>com.path.to.server.resources.exceptionmappers;com.path.to.server.resources.api;com.path.to.server.resources.internal</param-value>
        </init-param>
    </servlet>

    <servlet>
        <servlet-name>com.path.to.server.ApiApplication</servlet-name>
    </servlet>

    <servlet-mapping>
        <servlet-name>javax.ws.rs.core.Application</servlet-name>
        <url-pattern>/resources/*</url-pattern>
    </servlet-mapping>

    <servlet-mapping>
        <servlet-name>com.path.to.server.ApiApplication</servlet-name>
        <url-pattern>/api</url-pattern>
    </servlet-mapping>

</web-app>

我有这样的 ApiApplication 设置:

public class ApiApplication extends ResourceConfig
{
    public ApiApplication()
    {
        System.out.println("SETTING UP API");
        packages("com.path.to.server.resources.exceptionmappers;com.path.to.server.resources.api");
    }
}

现在我已经完成了所有这些设置,我正在尝试使用我的服务。我正在使用如下所示的 DirectRestService:

@Path("resources/authentication")
public interface AuthenticationService extends BaseService
{
    @POST
    @Path("/login/{loginType}")
    @Produces(MediaType.APPLICATION_JSON)
    Session login(@HeaderParam("Authorization") String authorization, @PathParam("loginType") UserTypes loginType);

    @POST
    @Path("/findActiveSession")
    @Produces(MediaType.APPLICATION_JSON)
    Session findActiveSession();
}

实现的服务器资源如下所示:

@Path("authentication")
public class AuthenticationResource extends BaseResource implements AuthenticationService
{
    public Session login(String authorization, UserTypes loginType)
    {
        // Code to do stuff
    }

    public Session findActiveSession()
    {
        // Code to do stuff
    }
}

当我访问 https:// localhost:8445 时,我的客户端调用了 findActiveSession() 方法,但我收到了 404。服务 URL 如 Chrome 的网络监视器所示:

https://localhost:8445/resources/authentication/findActiveSession

关于哪些东西需要什么路径,这一切都非常令人困惑。我不确定的事情:

AuthenticationResource Path 是否正确?它甚至需要 Path 注释吗?

私有 servlet 使用 javax.ws.rs.core.Application 是否正确?

我是否使用 Application 子类 (ApiApplication) 正确设置了自定义 servlet?

我终于想出了一个有效的解决方案。我不知道它是否完全正确,但它给了我想要的结果:

我的web.xml

<web-app id="WebApp_ID" version="3.0" [...]>
    <!-- Servlet for direct client/server calls -->
    <servlet>
        <servlet-name>InternalApplication</servlet-name>
        <servlet-class>org.glassfish.jersey.servlet.ServletContainer</servlet-class>
        <init-param>
            <param-name>jersey.config.server.provider.packages</param-name>
            <param-value>
                path.to.server.resources.exceptionmappers,path.to.server.resources.api,path.to.server.resources.internal
            </param-value>
        </init-param>
    </servlet>

    <!-- Servlet for API calls -->
    <servlet>
        <servlet-name>ApiApplication</servlet-name>
        <servlet-class>org.glassfish.jersey.servlet.ServletContainer</servlet-class>
        <init-param>
            <param-name>jersey.config.server.provider.packages</param-name>
            <param-value>
                path.to.server.resources.exceptionmappers,path.to.server.resources.api
            </param-value>
        </init-param>
    </servlet>

    <servlet-mapping>
        <servlet-name>InternalApplication</servlet-name>
        <url-pattern>/resources/*</url-pattern>
    </servlet-mapping>

    <servlet-mapping>
        <servlet-name>ApiApplication</servlet-name>
        <url-pattern>/api/*</url-pattern>
    </servlet-mapping>
</web-app>

我最终不需要 Application 子类。