我正在尝试使用 Jersey 设置我的项目,使其基本上具有 2 个 servlet:一个供客户端应用程序访问的私有 servlet,以及一个充当 API 的面向公众的。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 路径是否正确?它甚至需要路径注释吗?
私有 servlet 使用 javax.ws.rs.core.Application 是否正确?
我是否使用 Application 子类 (ApiApplication) 正确设置了自定义 servlet?