0

我尝试使用 jetty web socket 并且遇到了一些麻烦,可能你知道如何解决它们。

有 SocketServlet(来自示例):

public class SocketServlet extends WebSocketServlet {

  @Override
  public void configure(WebSocketServletFactory factory) {
      factory.register(MyEchoSocket.class);
  }
}

和 EchoSocket

@WebSocket
public class MyEchoSocket {

   @OnWebSocketConnect
   public void onConnect(Session session){
       System.out.println("Connect");
   }
}

web.xml(部分)

<servlet>
    <servlet-name>SocketServlet</servlet-name>
    <servlet-class>ru.servlets.SocketServlet</servlet-class>
</servlet>
<servlet-mapping>
    <servlet-name>SocketServlet</servlet-name>
    <url-pattern>/hello/*</url-pattern>
</servlet-mapping>

当我用 maven 构建和运行它时,我有 NPE:

2013-07-18 23:20:29.488:WARN:oejs.ServletHandler:/hello java.lang.NullPointerException at org.eclipse.jetty.websocket.server.WebSocketServerFactory.upgrade(WebSocketServerFactory.java:415) at org.eclipse。 jetty.websocket.server.WebSocketServerFactory.acceptWebSocket(WebSocketServerFactory.java:178) at org.eclipse.jetty.websocket.servlet.WebSocketServlet.service(WebSocketServlet.java:160) at javax.servlet.http.HttpServlet.service(HttpServlet. java:848) at org.eclipse.jetty.servlet.ServletHolder.handle(ServletHolder.java:669) at org.eclipse.jetty.servlet.ServletHandler.doHandle(ServletHandler.java:457) at org.eclipse.jetty.server .handler.ScopedHandler.handle(ScopedHandler.java:137) 在 org.eclipse.jetty.security.SecurityHandler.handle(SecurityHandler.java:557) 在 org.eclipse.jetty.server.session.SessionHandler。doHandle(SessionHandler.java:231) at org.eclipse.jetty.server.handler.ContextHandler.doHandle(ContextHandler.java:1075) at org.eclipse.jetty.servlet.ServletHandler.doScope(ServletHandler.java:384) at org .eclipse.jetty.server.session.SessionHandler.doScope(SessionHandler.java:193) 在 org.eclipse.jetty.server.handler.ContextHandler.doScope(ContextHandler.java:1009) 在 org.eclipse.jetty.server.handler .ScopedHandler.handle(ScopedHandler.java:135) 在 org.eclipse.jetty.server.handler.ContextHandlerCollection.handle(ContextHandlerCollection.java:255) 在 org.eclipse.jetty.server.handler.HandlerCollection.handle(HandlerCollection.java :154) 在 org.eclipse.jetty.server.Server.handle(Server.java:368) 在 org.eclipse.jetty 的 org.eclipse.jetty.server.handler.HandlerWrapper.handle(HandlerWrapper.java:116)。服务器。AbstractHttpConnection.handleRequest(AbstractHttpConnection.java:489) at org.eclipse.jetty.server.AbstractHttpConnection.headerComplete(AbstractHttpConnection.java:942) at org.eclipse.jetty.server.AbstractHttpConnection$RequestHandler.headerComplete(AbstractHttpConnection.java:1004)在 org.eclipse.jetty.http.HttpParser.parseNext(HttpParser.java:640) 在 org.eclipse.jetty.http.HttpParser.parseAvailable(HttpParser.java:235) 在 org.eclipse.jetty.server.AsyncHttpConnection.handle (AsyncHttpConnection.java:82) 在 org.eclipse.jetty.io.nio.SelectChannelEndPoint.handle(SelectChannelEndPoint.java:628) 在 org.eclipse.jetty.io.nio.SelectChannelEndPoint$1.run(SelectChannelEndPoint.java:52)在 org.eclipse.jetty.util.thread.QueuedThreadPool $3 处的 org.eclipse.jetty.util.thread.QueuedThreadPool.runJob(QueuedThreadPool.java:608)。在 java.lang.Thread.run(Thread.java:724) 处运行(QueuedThreadPool.java:543)

我使用码头版本 9.0.4.v20130625 jettyPlugin.version 8.1.10.v20130312 java 1.7.25

感谢您的回答!

4

1 回答 1

0

我有同样的问题,这只是由 HttpConnection 中的一个静态方法引起的,它会生成一个 threadLocale。它使用了 initValue() 方法,但我不知道为什么这个方法在短时间内几乎不会返回 null。
我们可以发现所有这些都是在tomcat下发生的。

当我更改为在码头运行它时,它运行良好。

所以我们可以意识到jetty的websocket模块不是独立的,而是基于jetty server的。我们最好实现一个websocketServlet。

于 2013-08-08T05:58:04.217 回答