MQTT协议 Websocket JS客户端

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

1、引入JS文件

 

<script src="https://cdnjs.cloudflare.com/ajax/libs/paho-mqtt/1.0.1/mqttws31.min.js" type="text/javascript"></script>

 

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、代码运行效果

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

4、效果展示

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

[20180701补]

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

<script src="mqttws31.min.js" type="text/javascript"></script>  
<script>  
client = new Paho.MQTT.Client("iot.eclipse.org", Number(443),'/ws',"clientId-c2471054-a703-4edc-b7dd-c7ed7b19072a");  
client.connect({useSSL: true,onSuccess: onConnect});   
function onConnect() {  
    console.log("onConnected");  
    client.subscribe("/topic_lqw_mcupush"); //订阅主题    
}  
</script>  

[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

 

  • 4
    点赞
  • 40
    收藏
    觉得还不错? 一键收藏
  • 67
    评论
### 回答1: MQTT是一种轻量级、灵活、可靠的信息传输协议,适用于物联网应用。MQTT协议通过发布-订阅模式进行通信,客户端可以订阅一个或多个主题,服务器会将消息推送给相关订阅者。 Websocket是一种浏览器与服务器之间的通信协议,它在建立连接后,可以实现全双工的通信,允许服务器主动向客户端推送消息。 MQTTnet是基于MQTT协议的一个.NET平台下的开源实现。它提供了丰富的API和高度可配置的功能,使开发人员能够在.NET平台上轻松地使用MQTT协议进行物联网应用的开发。MQTTnet支持MQTT 3.1协议规范,并且具有连接验证、消息保持、最后遗嘱消息等高级特性,以确保可靠的通信。 MQTTnet也支持使用Websocket进行通信。通过使用Websocket,可以让MQTTnet在Web浏览器中运行,实现从Web浏览器到服务器之间的实时双向通信。通过Websocket,我们可以在网页上订阅一个或多个主题,并能够接收服务器端实时推送的消息。 使用MQTTnet的Websocket功能,可以方便地将物联网应用部署到Web浏览器上,并实现设备与浏览器之间的实时通信。这对于一些需要实时监控、远程控制等应用非常有用。同时,MQTTnet提供了丰富的安全机制,可以使用TLS/SSL进行加密通信,保障通信的安全性。 总的来说,MQTTnet通过提供WebSocket支持,使得开发人员能够在.NET平台下便捷地使用MQTT协议,实现物联网应用在浏览器上的实时双向通信,具有很大的灵活性和可靠性。 ### 回答2: MQTTnet是一个开源的MQTT客户端库,它提供了许多实用的功能和工具,用于在应用程序中使用MQTT协议进行通信。而WebSocket是一种在Web浏览器和服务器之间进行双向通信的协议MQTTnet的WebSocket扩展功能允许我们使用基于WebsocketMQTT协议进行通信。这意味着我们可以在Web浏览器中直接使用MQTT进行实时通信,无需任何其他的插件或扩展。 通过使用MQTTnet提供的WebSocket扩展,我们可以使用JavaScript或其他支持WebSocket的编程语言来编写客户端代码,与MQTT代理进行通信。这使得我们可以在浏览器中实时接收和发送消息,实现实时通知、推送等功能。 要使用MQTTnet的WebSocket功能,首先需要确保我们的MQTT代理支持WebSocket协议。然后,我们需要在客户端代码中引入MQTTnet的WebSocket库,并使用WebSocket连接字符串来连接到MQTT代理。 一旦连接建立,我们就可以使用MQTTnet的各种方法和事件处理程序来发送和接收消息,订阅主题等。通过WebSocket,我们可以将MQTT消息以JSON格式发送和接收,从而在Web浏览器中进行实时数据传输。 总而言之,MQTTnet WebSocket提供了一种方便快捷的方式,使得我们可以在Web浏览器中使用MQTT协议进行实时通信。它大大简化了在浏览器中使用MQTT的过程,使得我们可以更加轻松地构建实时通知、推送等功能。
评论 67
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值