OpeningHandshakeException for Meteor Backend for Android app



我刚刚学习并通过简单的meteor create hellometeor命令实现了我的第一个Meteor应用程序,然后使用ngrok使localhost:3000端口上线。

然后我使用 delight-im/Android-DDP 库按照以下代码连接到直接wsurl:

// create a new instance, where mMeteor is a global var.
mMeteor = new Meteor(this, "ws://180a3c0e.ngrok.io", new InMemoryDatabase()); // "ws://180a3c0e.ngrok.io" is the temp. url after tunneling `localhost:3000`
// register the callback that will handle events and receive messages
mMeteor.addCallback(this); // as the activity implements MeteorCallback
// establish the connection
mMeteor.connect();

但是每次我尝试运行此代码时,我都会收到以下错误,对于像我这样的新手来说,在过去的 6 小时的谷歌搜索和阅读中,对于像我这样的 Meteor 类似平台的新手来说,我没有找到任何建议或直接的解决方案:

W/System.err: java.lang.Exception: com.neovisionaries.ws.client.OpeningHandshakeException: The status code of the opening handshake response is not '101 Switching Protocols'. The status line is: HTTP/1.0 502 Bad Gateway
W/System.err:     at im.delight.android.ddp.Meteor$1.onError(Meteor.java:195)
W/System.err:     at com.neovisionaries.ws.client.ListenerManager.callOnError(ListenerManager.java:432)
W/System.err:     at com.neovisionaries.ws.client.ConnectThread.handleError(ConnectThread.java:50)
W/System.err:     at com.neovisionaries.ws.client.ConnectThread.run(ConnectThread.java:41)
W/System.err: Caused by: com.neovisionaries.ws.client.OpeningHandshakeException: The status code of the opening handshake response is not '101 Switching Protocols'. The status line is: HTTP/1.0 502 Bad Gateway
W/System.err:     at com.neovisionaries.ws.client.HandshakeReader.validateStatusLine(HandshakeReader.java:232)
W/System.err:     at com.neovisionaries.ws.client.HandshakeReader.readHandshake(HandshakeReader.java:54)
W/System.err:     at com.neovisionaries.ws.client.WebSocket.readHandshake(WebSocket.java:3113)
W/System.err:     at com.neovisionaries.ws.client.WebSocket.shakeHands(WebSocket.java:2992)
W/System.err:     at com.neovisionaries.ws.client.WebSocket.connect(WebSocket.java:2034)
W/System.err:     at com.neovisionaries.ws.client.ConnectThread.run(ConnectThread.java:37)

可能是我在 Meteor 服务器端错过了一个非常常见的东西,因为除了启动项目之外,我没有在其中编写一行代码。
请在这方面启发我。
蒂亚。

我应该因为不知道 Meteor 在 url 上有它的 websocket 连接而ws://.../websocket钉十字架。

我刚刚在上一个 URL 的末尾添加了/websocket,一切都运行得同样顺利。

最新更新