mqtt.js 无法连接/错误提示 WebSocket connection to ‘ws://xxxxx‘ failed:

检查点:

  1. 检查自己的页面是http还是https的,然后核对用的是mqtt/mqtts,或者是ws/wss
  2. 检查自己的地址是否对(尤其是BasePath),我一开始地址应该是ws://xxxxx/mqtt(BasePath是mqtt),结果我一直用ws://xxxxx。(有的BasePath是 mqtt/ws,连接地址应该就是 ws://xxxxx/mqtt/ws
  3. 注意端口号,我使用的mqtt服务ws和mqtt端口号不一样

如果以上两点都没问题的话,那么就和我当下的情况一样了
使用 mqtt://xxxxx/mqtt 怎么都连不上,就提示 WebSocket connection to 'ws://xxxxx' failed:

解决方法:
直接使用 ws://xxxxx/mqtt ,记得切换端口号,其他的都不改变,只是改了连接地址

  const connectUrl = `ws://xxxxx/mqtt`;	// 用这个就好了
  //  const connectUrl = `mqtt://xxxxx/mqtt`;	// 用这个报错了,用上面的就好了
  const clientId = `mqtt_${Math.random().toString(16).slice(3)}`;

  var client = mqtt.connect(connectUrl, {
    clientId,
    clean: true,
    connectTimeout: 4000,
    username: 'username',
    password: '123456',
    reconnectPeriod: 1000,
  })
  const topic = '/nodejs/mqtt'
  client.on('connect', () => {
    console.log('Connected')
    client.subscribe([topic], () => {
      console.log(`Subscribe to topic '${topic}'`)
    })
  })

如果不确定自己配置的对不对,可以用下面的地址测试

使用EMQX 提供的 免费公共 MQTT 服务器,该服务基于 EMQX 的 MQTT 物联网云平台 创建。
服务器接入信息如下:

Broker: broker.emqx.io
TCP Port: 1883
Websocket Port: 8083

const connectUrl = `ws://broker.emqx.io:8083/mqtt`;

client = mqtt.connect(connectUrl, {
  clean: true,
  connectTimeout: 4000,
  reconnectPeriod: 1000,
  clientId: 'emqx_test',
  username: 'emqx_test',
  password: 'emqx_test'
})

// 需要订阅的主题
const topic = 'test';

//成功连接后触发的回调
client.on('connect', () => {
  console.log('已经连接成功');
  // 这里可以订阅多个主题
  client.subscribe([topic], () => {
    console.log(`订阅了主题 ${topic}`)
  })
});

// 当客户端收到一个发布过来的消息时触发回调
client.on('message', function (message) {
  // 这里有可能拿到的数据格式是Uint8Array格式,所以可以直接用toString转成字符串
  // let data = JSON.parse(message.toString());
  console.log("返回的数据:", message)
});

// 连接断开后触发的回调
client.on("close", function () {
  console.log("已断开连接")
});

结果
mqtt.js 无法连接/错误提示 WebSocket connection to ‘ws://xxxxx‘ failed:_第1张图片

我个人遇到的一些情况:

  1. mqtt本质上也是用websocketmqtt的,所以使用的端口是ws(8083)或者wss(8084)的端口,并不是mqtt(1883)的端口。
  2. 一般情况下,MQTT的接口是ws://或者mqtt://后面跟/mqtt(只是一般情况下,具体情况需要和后端沟通)例如:ws://broker.emqx.io:8083/mqtt 或者 mqtt://broker.emqx.io:8083/mqtt
  3. 我目前前端使用的话没有通过1883端口链接成功过,无论是 ws://xxxxx 还是 mqtt://xxx。(有成功的同学,麻烦留个言或者私信我一下)
  4. 似乎用node的话,是可以使用1883端口的,但是没有测试。(有测试过的同学,麻烦留个言或者私信我一下)

你可能感兴趣的:(web前端,websocket,javascript,网络协议)