websocket推送消息,模拟推送

上一篇文章:什么是webSocket?以及它的一些相关理论知识

背景:

MQTT 的发布/订阅模式与 WebSocket 的双向通信特性相结合。

通过将 MQTT 与 WebSocket 结合使用,可以在 Web 应用中实现高效、实时的消息传输,特别适用于需要实时数据更新的应用场景。

效果展示:

一、MQTT工具的使用:

MQTT 客户端的操作界面:

简化了初始化一个MQTT对象的代码书写。

MQTT客户端的操作步骤:

1.双击运行

2.打开界面,连接服务器

3.配置参数

4.订阅消息

5.发布消息

6.MQTT的历史记录

MQTT的代码示例:

前端使用 MQTT.js 库

MQTT.js 是一个功能强大的 MQTT 客户端库,支持在 Node.js 和浏览器中使用。下面是一个简单的示例,展示如何在浏览器中使用 MQTT over WebSocket。

html 复制代码
<!DOCTYPE html>
<html lang="en">
<head>
  <meta charset="UTF-8">
  <meta name="viewport" content="width=device-width, initial-scale=1.0">
  <title>MQTT over WebSocket Example</title>
  <script src="https://cdnjs.cloudflare.com/ajax/libs/mqtt/4.2.6/mqtt.min.js"></script>
</head>
<body>
  <h1>MQTT over WebSocket Example</h1>
  <div>
    <label for="message">Message:</label>
    <input type="text" id="message">
    <button onclick="sendMessage()">Send</button>
  </div>
  <ul id="messages"></ul>

  <script>
    // 连接到 MQTT 代理
    var client = mqtt.connect('ws://localhost:8083');

    // 当连接建立时触发
    client.on('connect', function () {
      console.log('Connected to MQTT broker');
      // 订阅主题
      client.subscribe('test/topic', function (err) {
        if (!err) {
          console.log('Subscribed to test/topic');
        }
      });
    });

    // 当接收到消息时触发
    client.on('message', function (topic, message) {
      // 将消息添加到页面
      var msg = document.createElement('li');
      msg.textContent = topic + ": " + message.toString();
      document.getElementById('messages').appendChild(msg);
    });

    // 发送消息
    function sendMessage() {
      var message = document.getElementById('message').value;
      client.publish('test/topic', message);
    }
  </script>
</body>
</html>

示例解释:

  • 引入 MQTT.js 库

    • 通过 CDN 引入 MQTT.js 库。
  • 连接到 MQTT 代理

    • 使用 mqtt.connect('ws://localhost:8083') 连接到启用了 WebSocket 的 MQTT 代理。
  • 订阅主题

    • 在连接建立后,订阅 test/topic 主题。
  • 接收消息

    • 通过 client.on('message', function (topic, message) { ... }) 处理接收到的消息,并将其显示在页面上。
  • 发送消息

    • 使用 client.publish('test/topic', message)test/topic 主题发送消息。
相关推荐
临水逸3 小时前
一次路径穿越漏洞引发的NAS安全危机:飞牛fnOS漏洞深度剖析与用户自救指南
网络·安全·web安全
强风7943 小时前
Linux-传输层协议TCP
linux·网络·tcp/ip
狮驼岭的小钻风3 小时前
汽车V模型开发流程、ASPICE、汽车功能安全的基石是国际标准 ISO 26262
网络·安全·汽车
崎岖Qiu3 小时前
【计算机网络 | 第十篇】以太网的 MAC 层
网络·笔记·计算机网络·mac地址
looking_for__3 小时前
【Linux】应用层自定义协议与序列化
linux·服务器·网络
JMchen1233 小时前
Android网络安全实战:从HTTPS到双向认证
android·经验分享·网络协议·安全·web安全·https·kotlin
m0_737302583 小时前
安卓证书在线生成_免费一键制作apk打包 一键制作工具
网络协议·https·ssl
科技块儿3 小时前
如何选择合适的IP查询工具?精准度与更新频率全面分析
网络·tcp/ip·安全
devmoon3 小时前
Polkadot SDK 自定义 Pallet Benchmark 指南:生成并接入 Weight
开发语言·网络·数据库·web3·区块链·波卡
Zach_yuan3 小时前
传输层之TCP/UDP 核心原理全解析:从协议基础到实战机制
linux·网络协议·tcp/ip·udp