1

对于 dropwizard 模块,我正在尝试将 deltaspike 和 cdi 与码头独立服务器一起使用。

编辑(来自评论):“我的问题(忘记 dropwizard 这个词):我如何一起使用 deltaspike/weld/jetty,为什么 deltaspike 文档中的示例代码不起作用?”

根据文档,应该简单地通过添加一个 ServletListener 来完成,但我得到的只是一个 NPE,因为“Bar”没有被注入。

这是我使用的示例代码。

import org.apache.deltaspike.cdise.api.CdiContainer;
import org.apache.deltaspike.cdise.api.CdiContainerLoader;
import org.apache.deltaspike.cdise.servlet.CdiServletRequestListener;
import org.eclipse.jetty.server.Server;
import org.eclipse.jetty.servlet.ServletContextHandler;
import org.eclipse.jetty.servlet.ServletHolder;
import org.slf4j.bridge.SLF4JBridgeHandler;

import javax.inject.Inject;
import javax.servlet.ServletException;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import java.io.IOException;

public class BarServlet extends HttpServlet {

    static {
        SLF4JBridgeHandler.removeHandlersForRootLogger();
        SLF4JBridgeHandler.install();
    }

    public static void main(String... args) throws Exception {
        CdiContainer cdiContainer = CdiContainerLoader.getCdiContainer();
        cdiContainer.boot();
        cdiContainer.getContextControl().startContexts();

        Server server = new Server(1234);
        ServletContextHandler context = new ServletContextHandler(ServletContextHandler.SESSIONS);
        context.setContextPath("/");
        server.setHandler(context);

        context.addEventListener(new CdiServletRequestListener());
        context.addServlet(BarServlet.class, "/*");

        server.start();
    }

    public static class Bar {
        public String hello() {
            return "bar";
        }
    }

    @Inject
    private Bar bar;

    @Override
    protected void doGet(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {
        resp.getWriter().print(bar.hello());
    }
}
4

1 回答 1

0

我目前正在与:

  • JBoss Weld 3.0.1Final
  • Apache DeltaSpike 1.8.0
  • 码头 9.4.7.v20170914

这些版本是出于某种目的而选择的;Weld 3 是 CDI 2.0 实现。DeltaSpike 1.8.0 是 CDI 2 扩展。Jetty 的版本也很重要,因为该版本(及更高版本)具有 CDI 集成部分。

     <dependency>
        <groupId>org.eclipse.jetty</groupId>
        <artifactId>jetty-bom</artifactId>
        <version>9.4.7.v20170914</version>              
        <scope>import</scope>
        <type>pom</type>
     </dependency>          
     <dependency>
        <groupId>org.eclipse.jetty.cdi</groupId>
        <artifactId>cdi-servlet</artifactId>
        <version>9.4.7.v20170914</version>              
     </dependency>

正如您在第二个依赖项中看到的:cdi-servlet 将确保码头将启动 cdi 集成 servlet。您的主要课程可以简单地是:

  Server server = new Server(8080);

  WebAppContext context = new WebAppContext();
  context.setConfigurations(new Configuration[]{
     new AnnotationConfiguration(),
     new WebInfConfiguration(),
     new WebXmlConfiguration(),
     new MetaInfConfiguration(),
     new FragmentConfiguration(),
     new EnvConfiguration(),
     new PlusConfiguration(),
     new JettyWebXmlConfiguration()}
  );
  context.setContextPath("/");
  context.setResourceBase("src/main/webapp");
  context.setParentLoaderPriority(true);
  server.setHandler(context);

  server.start();

  // example...
  CDI.current().select(Servlet.class).forEach(s ->
     context.addServlet(s.getClass(), s.getClass().getSimpleName());
  });

  server.join();
于 2018-01-03T10:40:07.187 回答