目前我在我的OSGi服务注册表中注册HttpServlets。这些由另一个组件处理,并即时添加到Jetty服务器。这非常有效,我需要完整的程序,例如在使用Vaadin或只是一个具有某些特定功能的普通HttpServlet时。
但是,我想重新使用这种方法来注册使用JAX-RS的Servlet(在我的情况下是当前的Jersey实现)。我的想法是简单地重用我的HttpServlet并添加JAX-RS注释。
当然,这不是开箱即用的,因为OSGi服务代理不会传递注释,而其他组件或服务器需要支持这一点。因此,我决定扩展HttpServlet的抽象类来处理服务并将其传递给Jersey ServletContainer。然后应该使用Application配置ServletContainer,包括原始的HttpServlets对象作为单例。
它似乎不起作用,我不明白为什么。错误是:
18:26:02.190 WARN o.g.jersey.internal.inject.Providers - 在SERVER运行时中注册的提供者path.to.MyServlet不实现适用于SERVER运行时的任何提供者接口。由于约束配置问题,将忽略提供程序path.to.MyServlet。
MyServlet:
@Path("/")
public class MyServlet extends AbstractServlet {
@GET @Path("/{path}")
public Response root(@PathParam("path") String path) {
// ...
}
}
AbstractServlet:
public abstract class AbstractServlet extends HttpServlet {
private ServletContainer servletContainer = null;
public AbstractServlet() {
this.servletContainer = new ServletContainer(ResourceConfig.forApplication(new ApplicationAdapter(this)));
}
@Override
public void destroy() {
this.servletContainer.destroy();
}
@Override
public void service(ServletRequest request, ServletResponse response) throws ServletException,IOException {
this.servletContainer.service(request, response);
}
@Override
public void service(HttpServletRequest request, HttpServletResponse response) throws ServletException,IOException {
this.servletContainer.service(request, response);
}
// ... (delegate all methods from HttpServlet to ServletContainer)
@ApplicationPath("/")
private class ApplicationAdapter extends Application {
private final Object object;
public ApplicationAdapter(final Object object) {
this.object = object;
}
@Override
public Set<Object> getSingletons() {
return new HashSet<Object>(Arrays.asList(this.object));
}
}
}
答案 0 :(得分:1)
如果您正在考虑在OSGi上执行jax-rs,那么您应该查看Aries JAX-RS whiteboard。
即将发布的JAX-RS Whiteboard OSGi spec的参考impl将成为OSGi R7发布的一部分。规格和参考动作应在几周内发布。
文档和示例仍然有点稀疏,但肯定值得注意。