文章详情

短信预约-IT技能 免费直播动态提醒

请输入下面的图形验证码

提交验证

短信预约提醒成功

怎么在uniapp项目中使用mqtt

2023-06-15 03:15

关注

这篇文章将为大家详细讲解有关怎么在uniapp项目中使用mqtt,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。

一、uniapp插件市场的参考插件

  https://ext.dcloud.net.cn/plugin?id=854

二、具体引入过程

1.安装mqtt和uuid

在uniapp项目根目录下分别运行安装mqtt和uuid的命令行,因为后面会用uuid生成mqtt的clientId,所以这边就一起安装了。

npm install mqtt@3.0.0npm install uuid

怎么在uniapp项目中使用mqtt

怎么在uniapp项目中使用mqtt

Ps.

①我这里和uniapp提供的插件安装的mqtt版本一样,我也尝试装了最新的版本,会报错,emmmmm...........

②如果没有pakage.json,安装是会提示报错,但是不影响安装使用。如果想方便一点,下次拉代码直接安装的话,可以自己在项目根目录下加一个pakage.json文件,添加如下内容:

{  "name": "",  "version": "1.0.0",  "description": "",  "author": "",  "license": "MIT",  "dependencies": {    "mqtt": "^3.0.0",    "uuid": "^8.3.0"  },  "devDependencies": {},  "scripts": {}}

2.页面引入mqtt并调用

①mqtt连接配置,放在/utils/mqtt.js里面,全局可用。

export const MQTT_IP = '192.168.9.128:8083/mqtt'//mqtt地址端口const MQTT_USERNAME = 'public'//mqtt用户名const MQTT_PASSWORD = 'public'//密码export const MQTT_OPTIONS = {    connectTimeout: 5000,    clientId: '',    username: MQTT_USERNAME,    password: MQTT_PASSWORD,    clean: false}

②vue页面引用mqtt

mqtt里面的clientId用uuid生成唯一标识码,防止不同页面订阅不同主题时数据出现粘连。

<script>    import { v4 } from 'uuid';    import {        MQTT_IP,        MQTT_OPTIONS    } from '@/utils/mqtt.js';    var mqtt = require('mqtt/dist/mqtt.js')    var client    export default {        data() {            return {                topic: '' //要订阅的主题            }        },        mounted() {this.connect() //连接        },        methods: {            connect() {                MQTT_OPTIONS.clientId = v4()                var that = this                // #ifdef H5                client = mqtt.connect('ws://' + MQTT_IP, MQTT_OPTIONS)                // #endif                // #ifdef MP-WEIXIN||APP-PLUS                client = mqtt.connect('wx://' + MQTT_IP, MQTT_OPTIONS)                // #endif                client.on('connect', function() {                    console.log('连接成功')                    client.subscribe(that.topic, function(err) {                        if (!err) {                            console.log('订阅成功')                        }                    })                }).on('reconnect', function(error) {                    console.log('正在重连...', that.topic)                }).on('error', function(error) {                    console.log('连接失败...', error)                }).on('end', function() {                    console.log('连接断开')                }).on('message', function(topic, message) {                    console.log('接收推送信息:', message.toString())                })            }        }    }</script>

3.运行结果

数据实时变化。

怎么在uniapp项目中使用mqtt

关于“怎么在uniapp项目中使用mqtt”这篇文章就分享到这里了,希望以上内容可以对大家有一定的帮助,使各位可以学到更多知识,如果觉得文章不错,请把它分享出去让更多的人看到。

阅读原文内容投诉

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

软考中级精品资料免费领

  • 历年真题答案解析
  • 备考技巧名师总结
  • 高频考点精准押题
  • 2024年上半年信息系统项目管理师第二批次真题及答案解析(完整版)

    难度     813人已做
    查看
  • 【考后总结】2024年5月26日信息系统项目管理师第2批次考情分析

    难度     354人已做
    查看
  • 【考后总结】2024年5月25日信息系统项目管理师第1批次考情分析

    难度     318人已做
    查看
  • 2024年上半年软考高项第一、二批次真题考点汇总(完整版)

    难度     435人已做
    查看
  • 2024年上半年系统架构设计师考试综合知识真题

    难度     224人已做
    查看

相关文章

发现更多好内容

猜你喜欢

AI推送时光机
位置:首页-资讯-后端开发
咦!没有更多了?去看看其它编程学习网 内容吧
首页课程
资料下载
问答资讯