Jersey正在设置2个servlet



我正在尝试用Jersey设置我的项目,使其基本上有两个servlets:一个是供客户端应用程序访问的私有servlets,另一个是用作API的面向公共的servlets。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。Chrome网络监视器中显示的服务URL如下所示:

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

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

AuthenticationResource路径是否正确?它甚至需要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>

我最终并不需要应用程序子类。

最新更新