在JavaScript中,要获取MQTT发布的主题,你通常需要使用一个MQTT客户端库来连接到MQTT代理(broker),并订阅你感兴趣的主题。当消息到达时,客户端会触发一个回调函数,该函数将包含消息的主题和消息内容。
以下是一个使用mqtt.js
(一个流行的Node.js MQTT客户端库)的示例,展示了如何连接到MQTT代理、订阅主题,并在接收到消息时获取主题和消息内容:
-
首先,你需要安装
mqtt.js
库。如果你还没有安装Node.js和npm,请先安装它们。然后,在你的项目目录中运行以下命令来安装mqtt
库:npm install mqtt
-
接下来,创建一个JavaScript文件(例如
mqttClient.js
),并在其中编写以下代码:const mqtt = require('mqtt');// 连接到MQTT代理(替换为你的MQTT代理URL和端口) const client = mqtt.connect('mqtt://your-mqtt-broker-url:port');// 当客户端连接到代理时 client.on('connect', () => {console.log('Connected to MQTT broker');// 订阅一个或多个主题(替换为你感兴趣的主题)client.subscribe('your/topic', (err) => {if (!err) {console.log('Subscribed to topic: your/topic');} else {console.error('Failed to subscribe to topic:', err);}}); });// 当接收到消息时 client.on('message', (topic, message) => {// 在这里,你可以获取到主题和消息内容console.log('Received message on topic:', topic);console.log('Message content:', message.toString()); });// 处理连接错误 client.on('error', (err) => {console.error('MQTT client error:', err); });// 当客户端断开连接时 client.on('close', () => {console.log('Disconnected from MQTT broker'); });
-
替换
mqtt://your-mqtt-broker-url:port
为你的MQTT代理的实际URL和端口号,替换'your/topic'
为你感兴趣的主题。 -
运行你的JavaScript文件:
node mqttClient.js
-
当有消息发布到你订阅的主题时,你应该会在控制台中看到打印出的主题和消息内容。
请注意,mqtt.js
是一个Node.js库,因此这个示例代码只能在Node.js环境中运行。如果你需要在浏览器中使用MQTT,你可能需要使用一个支持WebSocket的MQTT客户端库,如Paho.MQTT.js
。不过,浏览器中的MQTT客户端通常不能直接连接到MQTT代理的TCP端口,而需要通过WebSocket代理(如EMQX提供的WebSocket支持)或MQTT over WebSocket服务。