MQTT协议 Websocket JS客户端

MQTT协议支持HTML5的Websocket客户端连接,只需要JS代码就能实现方便实时的通信,下面是实现步骤

1、引入JS文件

 

 

2、使用代码

下面为核心代码的截取

//建立客户端实例​​​​​​​
//有些服务器设置了路径如ws://ip:127.0.0.1:8083/mqtt,没有的路径处为""或"/"
client = new Paho.MQTT.Client("服务器域名", Number(端口号),"路径","客户端ID");
//client = new Paho.MQTT.Client("服务器域名", Number(端口号), "客户端ID");//默认添加/mqtt路径
        client.connect({onSuccess:onConnect});//连接服务器并注册连接成功处理事件
        function onConnect() {
	        console.log("onConnected");
	        client.subscribe("/topic_back");//订阅主题
        }
        client.onConnectionLost = onConnectionLost;//注册连接断开处理事件
        client.onMessageArrived = onMessageArrived;//注册消息接收处理事件
        function onConnectionLost(responseObject) {
            if (responseObject.errorCode !== 0) {
                console.log("onConnectionLost:"+responseObject.errorMessage);
                console.log("连接已断开");
             }
        }
        function onMessageArrived(message) {
		  console.log("收到消息:"+message.payloadString);
		}
        //发送消息
        message = new Paho.MQTT.Message("hello");
		message.destinationName = "/topic";
		client.send(message);

 

3、代码运行效果

MQTT协议 Websocket JS客户端_第1张图片

注意:此处只作演示,发送消息应该放在onConnect函数内,确保连接成功再发送!

4、效果展示

利用MQTT协议远程控制LED灯 http://www.llqqww.com/open/iot/ 

MQTT协议 Websocket JS客户端_第2张图片

[20180701补]

上述案例所用MQTT服务器可能已用不了,最新测试用例:

  
  

[20190319补]

使用下述代码会默认在添加"/mqtt"后缀路径,实际连接的是

ws://主机名:端口号/mqtt

client = new Paho.MQTT.Client("服务器域名", Number(端口号), "客户端ID");//建立客户端实例​​​​​​​

下面是修改后缀路径的方法,如果没有则"路径"为""或"/":

client = new Paho.MQTT.Client("服务器域名", Number(端口号),"路径","客户端ID");//建立客户端实例​​​​​​​

【转载请注明出处:http://blog.csdn.net/leytton/article/details/51896951

 

你可能感兴趣的:(#,MQTT协议,【前端开发】,#,NodeMCU学习教程)