码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • 【EMQX】使用websocket订阅EMQX数据


    需求:某平台希望通过 websocket 来订阅 EMQX平台上的某些 Topic数据进行处理

    1、EMQX 服务配置

            前提是EMQX服务正常安装运行了,如果EMQX服务未安装的话,详见以下文章关于如何安装部署服务:

    搭建自己的MQTT服务器、实现设备上云(Windows+EMQX)_自己搭建mqtt服务器-CSDN博客

    MQTT 服务器搭建:EMQ X 安装指南和常见问题-CSDN博客

            服务安装运行后,登录到 EMQX 后台。登录地址为:http://{emqxBrokerHost}:{默认端口:18083}。如下所示:

    1.1、查看websocket 服务配置信息

            登录系统后,找到菜单 “管理 --> 监听器”。选择类型为【ws】的记录,点击名称可以查看到如下信息:

            这里面需要注意的信息有以下几个,目的是为了连接到服务。其他配置参数根据需要进行对应调整。

    • 监听地址:EMQX所在服务的IP
    • 16593:EMQX服务分配的关于websocket未加密地址的监听端口
    • MQTT Path:WebSocket 连接的路径,例如 /mqtt,作用是指定 WebSocket 连接的路径,以便在服务器上找到正确的 WebSocket 端点

    1.2、验证 websocket连接

            打开菜单 “问题分析  -->  Websocket 客户端”,如下截图所示:

            如果没有对EMQX服务开启授权认证,那么直接连接即可连接成功(端口没有更改的情况)。也就是说没有开启授权认证的话,就不需要配置用户名与密码可直接连接使用。关于如何开启认证或配置详见以下文章:

    EMQX开启权限认证,添加用户名、密码认证--MQTT_emqx mnesia认证 不输入用户名密码也能登录-CSDN博客文章浏览阅读1.2w次,点赞5次,收藏21次。提示:前置条件,需要安装EMQX,同时可以访问控制面板文章目录前言一、认证方式二、使用步骤--仅介绍Mnesia(用户名/Client ID)认证1.开启插件2.方式一:预设认证用户(不推荐)3.方式二:使用 HTTP API 管理认证数据(推荐)添加认证数据#批量添加认证数据#查看已经添加的认证数据#更改已添加的认证数据#查看指定的认证数据#删除指定的 Clientid 认证数据总结前言EMQ X 默认配置中启用了匿名认证,任何客户端._emqx mnesia认证 不输入用户名密码也能登录https://blog.csdn.net/beibei3321/article/details/124293119        我这边是有配置授权认证的,所以需要查看关于认证用户的相关配置信息。

    1.3、创建用户

            打开菜单 “系统设置  -->  用户”,详见如下所示。需要新增用户直接创建新增配置账户名密码即可使用。需要注意的是,只创建这个用户只能登录到 EMQX 平台,当使用客户端进行授权认证,是还无法使用的。

            比如我这边创建一个账户为【wsTest】:

            此时,我还没有对该用户进行客户端授权配置。我们可以拿这个用户进行websocket验证测试连接是否可以正常使用。

    情况二:

    情况三:配置客户端授权后

    1.4、客户端授权配置

            打开菜单 “访问控制  -->  客户端认证 --->  内置数据库”记录的用户管理。

            很明显我们刚刚新增的用户并没有在列表中,此时我们把刚刚新增的用户配置进来。

            再去进行 websocket 客户端连接测试,如下测试:

            可以看到我们能够正常连接使用,此时我们可以对指定 Topic 进行消息的发布订阅测试。

    2、websocket 客户端订阅发布

    2.1、EMQX 发布订阅(ws)

            根据上文操作后,我们在EMQX平台上已经开启了一个 websocket 订阅客户端并且订阅了主题为 “tohave” 的数据。此时我们在 EMQX 平台的 websocket 客户端里在新建一个客户端连接进行数据发生,验证数据是否能够正常发送接收。

            在 5MZ 的客户端连接里,对Topic “tohave” 发送一条报文为 “大哥你好”的数据,如下图所示。此时在 5MZ 客户端连接里可以看到,我们数据是已经发送出去了,在 已发送 列表里可以看到具体信息。

            此时我们查看另一个客户端连接看数据是否已收到:

    可以看到数据是可以正常发送订阅的

    2.2、websocket网页

            这里我们在用HTML网页进行测试验证看下,网页编写如以下所示。将代码复制出来粘贴到HTML网页文件中,修改对应连接信息双击打开运行即可。

    1. html>
    2. <html>
    3. <body>
    4. <script src="https://cdn.bootcdn.net/ajax/libs/mqtt/5.0.5/mqtt.min.js">script>
    5. <script src="https://cdn.bootcss.com/jquery/3.3.1/jquery.min.js">script>
    6. <h1 id="myDiv">h1>
    7. <script type="text/javascript">
    8. $(function () {
    9. // 连接选项
    10. const options = {
    11. clean: true, // true: 清除会话, false: 保留会话
    12. connectTimeout: 4000, // 超时时间
    13. // 认证信息
    14. clientId: 'wsEmqx' + Math.random(),
    15. //EMQX配置的相关账户密码
    16. username: '账号',
    17. password: '密码',
    18. };
    19. //订阅主题
    20. const subTopic = "subEmqx";
    21. //发布主题
    22. const pubTopic = "tohave";
    23. // 连接字符串, 通过协议指定使用的连接方式
    24. // ws 未加密 WebSocket 连接
    25. // wss 加密 WebSocket 连接
    26. // mqtt 未加密 TCP 连接
    27. // mqtts 加密 TCP 连接
    28. // wxs 微信小程序连接
    29. // alis 支付宝小程序连接
    30. const connectUrl = 'ws://{EMQX服务所在IP}:{EMQX服务分配 ws 类型的监听端口}/mqtt'
    31. const client = mqtt.connect(connectUrl, options)
    32. client.on('connect', function () {
    33. console.log('Connected')
    34. // 订阅主题
    35. client.subscribe(subTopic, function (err) {
    36. if (!err) {
    37. // 发布消息
    38. client.publish(pubTopic, 'EMQX,我想你了!!!')
    39. }
    40. })
    41. })
    42. client.on('reconnect', (error) => {
    43. console.log('正在重连:', error)
    44. })
    45. client.on('error', (error) => {
    46. console.log('连接失败:', error)
    47. })
    48. client.on('message', (topic, message) => {
    49. $("#myDiv").html(message.toString());
    50. console.log('收到消息:', topic, message.toString())
    51. })
    52. });
    53. script>
    54. body>
    55. html>

            相应信息配置完成后,我们双击打开运行。运行后连接成功时,会向EMQX平台的【tohave】主题发送一条消息,如下所示:

            每刷新一次网页就会向EMQX服务端发生一条消息。

            可以看到数据是有发布过去的,此时我们在EMQX上推送下数据到网页端观察看看:

  • 相关阅读:
    海盗分金博弈
    13.java中的抽象类和接口[20220622]
    极狐GitLab 如何重置管理员密码
    一步步指导 AI 画一幅中国山水画
    flink-cdc同步mysql数据到hive
    OpenAI 推出 DALL·E 3 配合 ChatGPT 无需复杂提示词即可作画
    投稿期刊被on hold了是怎么回事?SCI期刊状态解读(超全整理,一文解惑)
    xray的使用
    【ai】pycharm设置软件仓库编译运行基于langchain的chatpdf
    210. 课程表 II
  • 原文地址:https://blog.csdn.net/qq_37165235/article/details/138193161
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | Kerberos协议及其部分攻击手法
    0day的产生 | 不懂代码的"代码审计"
    安装scrcpy-client模块av模块异常,环境问题解决方案
    leetcode hot100【LeetCode 279. 完全平方数】java实现
    OpenWrt下安装Mosquitto
    AnatoMask论文汇总
    【AI日记】24.11.01 LangChain、openai api和github copilot
  • 热门文章
  • 十款代码表白小特效 一个比一个浪漫 赶紧收藏起来吧!!!
    奉劝各位学弟学妹们,该打造你的技术影响力了!
    五年了,我在 CSDN 的两个一百万。
    Java俄罗斯方块,老程序员花了一个周末,连接中学年代!
    面试官都震惊,你这网络基础可以啊!
    你真的会用百度吗?我不信 — 那些不为人知的搜索引擎语法
    心情不好的时候,用 Python 画棵樱花树送给自己吧
    通宵一晚做出来的一款类似CS的第一人称射击游戏Demo!原来做游戏也不是很难,连憨憨学妹都学会了!
    13 万字 C 语言从入门到精通保姆级教程2021 年版
    10行代码集2000张美女图,Python爬虫120例,再上征途
Copyright © 2022 侵权请联系2656653265@qq.com    京ICP备2022015340号-1
正则表达式工具 cron表达式工具 密码生成工具

京公网安备 11010502049817号