嵌入式Jetty9 + Websockets。 onWebSocketText说我没有连接

时间:2013-04-26 12:04:40

标签: websocket jetty

我在我的应用程序中使用Jetty 9.0.2.v20130417(在Java 1.7下)

Servlet:

import org.eclipse.jetty.websocket.api.UpgradeRequest;
import org.eclipse.jetty.websocket.api.UpgradeResponse;
import org.eclipse.jetty.websocket.servlet.WebSocketCreator;
import org.eclipse.jetty.websocket.servlet.WebSocketServlet;
import org.eclipse.jetty.websocket.servlet.WebSocketServletFactory;

public class WSServletHandler extends WebSocketServlet
{

    private static final long serialVersionUID = 6600543852415589642L;

    public static class WSCustomCreator implements WebSocketCreator
    {
        @Override
        public Object createWebSocket(UpgradeRequest req, UpgradeResponse resp)
        {
            return new WSSocketHandler();
        }
    }

    @Override
    public void configure(WebSocketServletFactory factory)
    {
        factory.setCreator(new WSCustomCreator());
    }
}

Websocket Handler:

import org.eclipse.jetty.websocket.api.Session;
import org.eclipse.jetty.websocket.api.WebSocketAdapter;
import org.eclipse.jetty.websocket.api.WebSocketException;


public class WSSocketHandler extends WebSocketAdapter
{
    public WSSocketHandler()
    {
        System.out.println("+++ Websocket class constructor");
    }

    public void onWebSocketConnect(Session sess)
    {
        System.out.println("+++ Websocket Connect from " + sess.getRemoteAddress().getAddress());   
    }

    @Override
    public void onWebSocketError(Throwable e)
    {
        System.out.println("+++ Websocket Error " + e.getMessage());
        e.printStackTrace();        
    }

    @Override
    public void onWebSocketClose(int statusCode, String reason)
    {
        System.out.println("+++ Websocket close " + statusCode + " , " + reason);
    }

    public void onWebSocketException(WebSocketException e)
    {
        System.out.println("+++ Websocket Exception " + e.getMessage());
        e.printStackTrace();
    }

    @Override
    public void onWebSocketBinary(byte[] payload, int offset, int len)
    {
        System.out.println("+++ ignoring binary message");
    }

    @Override
    public void onWebSocketText(String message)
    {
        System.out.println("+++ MESSAGE: " + message);

        if (isNotConnected())
        {
            System.out.println("+++ not connected");
            return;
        }

        try {
            getRemote().sendString("lallo");
        } catch (Exception e) {
            // TODO Auto-generated catch block
            e.printStackTrace();
        }
    }

}

我可以从javascript连接到Jetty服务器,我可以从js发送消息到jetty。我在onWebSocketText函数中看到了这条消息。 问题:isNotConnected()始终为true,因此没有任何内容返回浏览器。 我在浏览器中没有Jetty或Javascript中的任何错误。

Jetty Logs:http://pastebin.com/Qq2EynFJ

我的想法已经用完......我很确定我会错过一些必要的东西,但是: 我在java下有一个类似的测试,它有完全相同的jetty和java版本。唯一的区别是上面的代码是更大的应用程序的一部分,而短测试是一个独立的程序。

提前致谢

3 个答案:

答案 0 :(得分:0)

不确定您在哪里定义isNotConnected方法,但您可以根据您的示例执行此类操作。

public void onWebSocketConnect(Session sess){
        System.out.println("+++ Websocket Connect from " + sess.getRemoteAddress().getAddress());  
        this.session=sess;
}

 public void onWebSocketText(String message){
    if(this.session.isOpen()){
    }
}

答案 1 :(得分:0)

杜阿是对的。

如果我摆脱onWebSocketConnect,一切正常。

当使用onWebSocketConnect时,你必须在某处保存Session(正如Joakim在第一个答案中所示)。之后,你必须使用this.sess。 例如 this.sess.getRemote()。sendString 要么 this.sess.isOpen()

感谢您的帮助:)

答案 2 :(得分:0)

尝试在方法

中调用onWebSocketConnect的父实现
public void onWebSocketConnect(Session session){
     // your code here
     super.onWebSocketConnect(session);   
}