无法让ESP8266连接到Heroku上的WebSocket服务器

问题描述

我有一个运行正常的websocket服务器在heroku上运行,并带有基本代码

var WebSocketServer = require("ws").Server
var http = require("http")
var express = require("express")
var app = express()
var port = process.env.PORT || 5000

app.use(express.static(__dirname + "/"))

var server = http.createServer(app)
server.listen(port)

console.log("http server listening on %d",port)

var wss = new WebSocketServer({server: server})
console.log("websocket server created")

wss.on("connection",function(ws) {
  var id = setInterval(function() {
    ws.send(JSON.stringify(new Date()),function() {  })
  },1000)

  console.log("websocket connection open")

  ws.on("close",function() {
    console.log("websocket connection close")
    clearInterval(id)
  })
})

在ESP8266上有以下代码

#include <Arduino.h>
#include "WebSocketClient.h"
#include "ESP8266WiFi.h"

WebSocketClient ws(true);

void setup() {
  Serial.begin(115200);
  WiFi.begin("SSID","PASSWORD");

  Serial.print("Connecting");
  while (WiFi.status() != WL_CONNECTED) {
    delay(500);
    Serial.print(".");
  }
}

void loop() {
  if (!ws.isConnected()) {
    ws.connect("iot-home-project.herokuapp.com","/",80);
    Serial.println("Not connected!");
  } else {
    ws.send("hello");

    String msg;
    if (ws.getMessage(msg)) {
      Serial.println(msg);
    }
  }
  delay(500);
}

根据我使用https://www.websocket.org/echo.html做的测试,websocket服务器很好 但是ESP8266只是在串行监视器上打印Not Connected。 我注意到的事情:

  • 每次ESP8266尝试连接时,网络服务器都会先显示socket open,然后立即显示socket close

解决方法

暂无找到可以解决该程序问题的有效方法,小编努力寻找整理中!

如果你已经找到好的解决方法,欢迎将解决方案带上本链接一起发送给小编。

小编邮箱:dio#foxmail.com (将#修改为@)