React中MQTT协议的使用

IT技术 reactjs mqtt mosquitto
2021-05-11 21:58:34

我有点新来react并试图了解如何使 MQTT 与之一起工作。

我尝试按照此处发布的代码示例进行操作:https : //www.npmjs.com/package/mqtt-react

但没有成功。出于某种原因,它只是什么都不做。

这是我的代码:

App.js 类:

import React, { Component } from 'react';
import './App.css';
import PostMqtt from './PostMessage.js';
import {Connector} from "mqtt-react";

class App extends Component {
    render() {
        return (
            <div className="App">
                <PostMqtt/>
            </div>
        );
    }
}

export default () => (
    <Connector mqttProps="ws://test.mosquitto.org/">
        <App />
    </Connector>
);

PostMessage.js 类:

import React from 'react';
import { subscribe } from 'mqtt-react';

export class PostMessage extends React.Component {

    sendMessage(e) {
        e.preventDefault();
        //MQTT client is passed on
        const { mqtt } = this.props;
        mqtt.publish('sensor', 'My Message');
    }

    render() {
        return (
            <button onClick={this.sendMessage.bind(this)}>
                Send Message
            </button>
        );
    }
}

export default subscribe({
    topic: 'sensor'
})(PostMessage)

任何想法出了什么问题?谢谢!

2个回答

经过长时间的研究,我找到了解决方案。

上面的连接器通过 Web 套接字支持 MQTT。默认的 mosquitto MQTT 端口是 1883,它直接进入 MQTT 代理而不是通过 websockets,这就是它没有连接的原因。

解决方案是使用端口 8080,它是“MQTT over WebSockets,未加密”(根据 mosquitto 文档)。

所以我所要做的就是将下一行从 更改为 并且它起作用了。

希望它帮助某人。

我还遇到了 websocket/mqtt 协议问题。我正在使用本教程运行自定义 mqtt 代理为了让消息代理与 React 一起工作,我找到了一篇描述如何将 mosca 绑定到 http 服务器的帖子。我丢失了链接,但这是我用来将两者结合起来的片段:

websocket-broker.js

var http     = require('http')
  , httpServ = http.createServer()
  , mosca    = require('mosca')
  , mqttServ = new mosca.Server({});

mqttServ.attachHttpServer(httpServ);

httpServ.listen(80);

然后开始我的经纪人,我只是做了一个简单的:

node websocket-broker.js

我希望这可以帮助将来遇到此问题的任何人!