我正在尝试用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>
我最终并不需要应用程序子类。