uniapp 连接mqtt

1:下载插件

npm install mqtt
2:创建 mqtt.js
/* main.js 项目主入口注入实例 */
// import mqttTool from './lib/mqttTool.js'
// Vue.prototype.$mqttTool = mqttTool/* 使用范例见 /pages/index/index.vue */
// mqtt协议:H5使用ws/wss APP-PLUS使用wx/wxsvar mqtt = require('mqtt/dist/mqtt.js')let mqttTool = {client: null
}mqttTool.connect = function(params){let options = {clientId: params.clientId,username: params.username,password: params.password,clean: params.clean,connectTimeout: 600000, cleanSession: false}let client = mqtt.connect(params.url, options);mqttTool.client = clientreturn client;
}mqttTool.end = function(){return new Promise((resolve, reject) => {if(mqttTool.client == null){resolve('未连接')console.log('App_text' + ":end 未连接")return;}mqttTool.client.end()mqttTool.client = nullresolve('连接终止')})
}mqttTool.reconnect = function(){return new Promise((resolve, reject) => {if(mqttTool.client == null){resolve('未连接')console.log('App_text' + ":reconnect 未连接")return;}mqttTool.client.reconnect()})
}mqttTool.subscribe = function(params){return new Promise((resolve, reject) => {if(mqttTool.client == null){resolve('未连接')console.log('App_text' + ":unconnect 未连接")return;}mqttTool.client.subscribe(params.topic, {qos:params.qos}, function(err,res) {console.log(err,res)if (!err && res.length>0) {resolve('订阅成功')console.log('App_text' + ":subscribe success 订阅成功")}else{resolve('订阅失败')console.log('App_text' + ":subscribe failed 订阅失败")return;} })  })
}mqttTool.unsubscribe = function(params){return new Promise((resolve, reject) => {if(mqttTool.client == null){resolve('未连接')console.log('App_text' + ":unconnect 未连接")return;}mqttTool.client.unsubscribe(params.topic, function(err) {if (!err) {resolve('取消订阅成功')console.log('App_text' + ":unsubscribe success 取消订阅成功")}else{resolve('取消订阅失败')console.log('App_text' + ":unsubscribe failed 取消订阅失败")return;} })  })
}mqttTool.publish = function(params){return new Promise((resolve, reject) => {if(mqttTool.client == null){resolve('未连接')console.log('App_text' + ":unconnect 未连接")return;}mqttTool.client.publish(params.topic, params.message, function(err){if (!err) {resolve(params.topic + '-' + params.message + '-发送成功')console.log('App_text' + ":publish success 发送成功")}else{resolve(params.topic + '-' + params.message + '-发送失败')console.log('App_text' + ":publish failed 发送失败")return;} })})
}export default mqttTool

3:创建mqtt.vue 并引入mqtt.js

<template><view class="mqtt"><u-navbar title='MQTT调试' autoBack bgColor="#fff" placeholder></u-navbar><view class="options"><view class="info"><view class="bar"><text class="label">clientId:</text><input v-model="connectInfo.clientId" class="value" style="width:70%" :adjust-position="false" placeholder=""/></view><view class="flex-between"><view class="bar"><text class="label">username:</text><input v-model="connectInfo.username" class="value" :adjust-position="false" placeholder=""/></view><view class="bar" style="margin-left:4px;"><text class="label">password:</text><input v-model="connectInfo.password" class="value" :adjust-position="false" placeholder=""/></view></view><view class="flex-between"><view class="btn" @click="startConnect">连接</view><view class="btn" @click="endConnect">终止</view><view class="btn" @click="reConnect">重新连接</view></view><view class="flex-between"><view class="bar" style="width:40%;"><text class="label">topic</text><input v-model="subscribeInfo.topic" class="value" :adjust-position="false" placeholder=""/></view><view class="bar" @click="changeQos"><text class="label">qos</text><text class="value">{{subscribeInfo.qos}}</text></view><view class="bar" @click="connectInfo.clean = !connectInfo.clean"><text class="label">clean</text><text class="value">{{connectInfo.clean}}</text></view></view><view class="flex-row"><view class="btn" @click="startSubscribe">订阅</view><view class="btn" style="margin-left:6px;" @click="endSubscribe">取消订阅</view></view><view class="tips"><text class="tips-lab">操作日志:</text><text class="tips-reset" @click="clearConfig">清空配置</text><text class="tips-buffer" :style="isBuffer?'':'opacity:0.5'" @click="isBuffer=!isBuffer">打印Buffer</text><text class="tips-clear" @click="cealrLog">清空日志</text></view></view></view><scroll-view class="logs" scroll-y><view class="logs-list" v-for="(item,index) in logs" :key="index">{{item.option + item.log}}</view></scroll-view><view class="feet" :style="'bottom:' + (isSending?sendInfo.keyboard:0) + 'px;'"><view class="inpbar"><input v-model="sendInfo.msg" @focus="focusSend(true)" @blur="focusSend(false)" :adjust-position="false" :cursor-spacing="12" class="inp" type="text" placeholder="请输入内容" placeholder-style="color:#cccccc;"/><view v-if="sendInfo.msg==''" class="send send-dark">发送q</view><view v-else @click="publish()" class="send">发送</view></view></view></view>
</template><script>export default{data(){return{/* 连接信息 */connectInfo: {clientId: '随机客户id',username: '你的用户名',password: '用户密码',clean: false},/* 订阅信息 */subscribeInfo: {topic: '你订阅的topic',qos: 1},/* 日志信息 */isBuffer: false,logs: [{option:'环境配置:', log:'配置成功'},],/* 发送信息 */isSending: false,sendInfo: {msg: '',keyboard: 0}}},computed:{/* system */systemInfo(){return uni.getSystemInfoSync()},},onLoad(){/* 即时通讯类键盘元素高度处理 */uni.onKeyboardHeightChange(res => {this.sendInfo.keyboard = res.height})},onUnload(){uni.offKeyboardHeightChange();},methods:{/* 连接 */startConnect(){var _this = thislet opts = {url: 'wx://你的服务器域名:8083/mqtt',clientId: this.connectInfo.clientId,username: this.connectInfo.username,password: this.connectInfo.password,clean: this.connectInfo.clean}var client =  this.$mqttTool.connect(opts);client.on('connect', function(res) {_this.logs.unshift({option:'mqtt:', log:'连接成功'})})client.on('reconnect', function(res) {_this.logs.unshift({option:'mqtt:', log:'重新连接'})})client.on('error', function(res) {_this.logs.unshift({option:'mqtt:', log:'连接失败'})})client.on('close', function(res) {_this.logs.unshift({option:'mqtt:', log:'关闭成功'})})client.on('message', function(topic, message, buffer) {if(_this.isBuffer){_this.logs.unshift({option:topic+' buffer:', log: JSON.stringify(buffer)})}_this.logs.unshift({option:topic+' message:', log: message.toString()})})},/* 终止连接 */endConnect(){var _this = thisthis.$mqttTool.end().then(res =>{_this.logs.unshift({option:'终止:', log:res})})},/* 重新连接 */reConnect(){var _this = thisthis.$mqttTool.reconnect().then(res =>{_this.logs.unshift({option:'重连:', log:res})})},/* 更改Qos */changeQos(){var _this = thisif(this.subscribeInfo.qos >= 2){this.subscribeInfo.qos = 0this.logs.unshift({option:'Qos:', log:this.subscribeInfo.qos + ' Qos变更,订阅已取消,请重新发起订阅'})this.endSubscribe();}else{this.subscribeInfo.qos += 1this.logs.unshift({option:'Qos:', log:this.subscribeInfo.qos + ' Qos变更,订阅已取消,请重新发起订阅'})this.endSubscribe();}},/* 订阅 */startSubscribe(){if(this.subscribeInfo.topic == ''){uni.showToast({icon: 'none',title: '输入topic'})return;}var _this = thislet opts = {topic: this.subscribeInfo.topic,qos: this.subscribeInfo.qos,}this.$mqttTool.subscribe(opts).then(res =>{_this.logs.unshift({option:'订阅' + opts.topic + ':', log:res})})},/* 取消订阅 */endSubscribe(){var _this = thislet opts = {topic: this.subscribeInfo.topic}this.$mqttTool.unsubscribe(opts).then(res =>{_this.logs.unshift({option:'取消订阅:', log:res})})},/* 发送消息 */publish(){var _this = thislet opts = {topic: this.subscribeInfo.topic,message: this.sendInfo.msg,}this.$mqttTool.publish(opts).then(res =>{_this.sendInfo.msg = ''_this.logs.unshift({option:'发送:', log:res})}).catch(err=>{_this.logs.unshift({option:'发送失败:', log:err})})},/* 清空配置 */clearConfig(){this.endConnect();this.connectInfo = {clientId: '',username: '',password: ''}this.subscribeInfo = {topic: '',qos: 1,sendMsg: ''}this.isBuffer = false},/* 清空日志 */cealrLog(){this.logs = [{option:'环境配置:', log:'配置成功'}]},/* 聚焦 */focusSend(val){this.isSending = val},}}
</script><style lang="less" scoped>.flex-row{display: flex;flex-direction: row;align-items: center;justify-content: flex-start;}.flex-between{display: flex;flex-direction: row;align-items: center;justify-content: space-between;}.mqtt{width: 100vw;height: 100vh;background-color: #f8f8f8;.options{width: 100%;height: 316px;background-color: #ffffff;box-shadow: 0px 0px 8px rgba(0, 0, 0, 0.1);font-size: 13px;color: #666666;.title{width: 710upx;margin: 0 auto;font-size: 15px;font-weight: 500;color: #333333;text-align: center;padding-bottom: 8px;display: flex;flex-direction: row;align-items: center;justify-content: space-between;.title-btn{font-size: 14px;font-weight: 400;color: #3F536E;}}.info{width: 710upx;margin: 0 auto;.bar{min-width: 160upx;margin-bottom: 8px;height: 30px;border-radius: 8px;box-shadow: inset 0px 0px 6px rgba(0, 0, 0, 0.1);border: 1px solid #cccccc;display: flex;flex-direction: row;align-items: center;justify-content: flex-start;font-size: 14px;.label{height: 30px;background-color: #f8f8f8;padding: 0px 10px;line-height: 30px;border-right: 1px solid #eeeeee;border-radius: 15px 0px 0px 15px;}.value{height: 30px;padding: 0px 12px;line-height: 30px;font-size: 14px;color: #3F536E;}}.btn{width: 30%;height: 32px;background-color: #3F536E;color: #ffffff;border-radius: 8px;margin-bottom: 8px;text-align: center;line-height: 32px;}.tips{width: 100%;height: 30px;margin-top: 6px;display: flex;flex-direction: row;align-items: center;position: relative;.tips-lab{font-size: 14px;color: #333333;}.tips-reset{font-size: 14px;font-weight: 500;color: #3F536E;position: absolute;right: 150px;}.tips-buffer{font-size: 14px;font-weight: 500;color: #3F536E;position: absolute;right: 70px;}.tips-clear{font-size: 14px;font-weight: 500;color: #3F536E;position: absolute;right: 0px;}}}}.logs{width: 100%;height: calc(100% - 396px);.logs-list{padding: 14upx 20upx;border-bottom: 1px solid #eeeeee;font-size: 13px;color: #3e3d3e;word-break: break-all;}}.feet{width: 100%;height: 80px;background-color: #ffffff;position: absolute;bottom: 0px;transition: all 0.35s;-webkit-transition: all 0.35s;&::before{position: absolute;content: '';top: 0px;background: rgba(0,0,0,0.2);width: 100%;height: 1px;transform: scaleY(0.5);transform-origin: 0 0;-webkit-transform: scaleY(0.5);-webkit-transform-origin: 0 0;}.inpbar{width: 710upx;height: 44px;background-color: #eeeeee;border-radius: 10px;position: absolute;left: 20upx;top: 10px;display: flex;flex-direction: row;align-items: center;justify-content: space-between;.img{width: 30px;height: 30px;margin-left: 12px;}.inp{width: calc(100% - 138px);height: 40px;margin: 0px 12px;font-size: 14px;color: #000000;}.send-dark{opacity: 0.7;}.send{width: 60px;height: 32px;background-color: #3F536E;border-radius: 6px;font-size: 14px;color: #ffffff;display: flex;align-items: center;justify-content: center;margin-right: 12px;}}}}
</style>

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/895787.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

shell脚本备份PostgreSQL数据库和库下表

注意&#xff1a; 以下为对PostgreSQL13.16版本数据库备份shell脚本参考请确认备份节点上psql和pgdump的版本不至于太低&#xff0c;建议>13.16该脚本目前是对于整库、&#xff08;默认针对public这个schema&#xff0c;如果有其他schema&#xff0c;请自行添加一层循环&am…

EXCEL解决IF函数“您已为此函数输入太多个参数”的报错

IF函数的基本结构是IF(条件, 值为真时的结果, 值为假时的结果)&#xff0c;所以标准的IF函数最多只能有三个参数。当用户输入的参数超过三个时&#xff0c;Excel就会报这个错误。比如多个IF语句叠加&#xff0c;但可能在嵌套的过程中没有正确关闭每个IF函数的括号&#xff0c;导…

图像质量评价指标-UCIQE-UIQM

一、评价指标UCIQE 在文章《An underwater color image quality evaluation metric》中&#xff0c;提到的了评价指标UCIQE&#xff08;Underwater Colour Image Quality Evaluation&#xff09;&#xff0c;是一种无参考图像质量评价指标&#xff0c;主要用于评估水下图像的质…

Vue 前端开发中的路由知识:从入门到精通

文章目录 引言1. Vue Router 简介1.1 安装 Vue Router1.2 配置 Vue Router1.3 在 Vue 实例中使用 Vue Router 2. 路由的基本用法2.1 路由映射2.2 路由视图2.3 路由链接 3. 动态路由3.1 动态路径参数3.2 访问动态参数3.3 响应路由参数的变化 4. 嵌套路由4.1 定义嵌套路由4.2 渲染…

基于Springboot+微信小程序调用文心一言大模型实现AI聊天

一、文章前言 此文主要实现基于Springboot微信小程序调用文心一言大模型实现AI聊天对话功能&#xff0c;使用Java作为后端语言进行支持&#xff0c;界面友好&#xff0c;开发简单。 二、开发流程及工具准备 2.1、登录百度智能云平台&#xff0c;获取 API Key 和 Secret Key两个…

leaflet前端初始化项目

1、通过npm安装leaflet包&#xff0c;或者直接在项目中引入leaflet.js库文件。 npm 安装&#xff1a;npm i leaflet 如果在index.html中引入leaflet.js,在项目中可以直接使用变量L. 注意:尽量要么使用npm包&#xff0c;要么使用leaflet.js库&#xff0c;两者一起使用容易发生…

Deepseek官网接口文档

API 接口 生成完成 生成聊天完成 创建模型 列出本地模型 显示模型信息 复制模型 删除模型 拉取模型 推送模型 生成嵌入 列出运行中的模型 版本 约定 模型名称 模型名称遵循 model:tag 格式&#xff0c;其中 model 可以有一个可选的命名空间&#xff0c;例如 ex…

容器运行常见数据库

一.涉及镜像压缩包 均为amd架构版本&#xff1a;mysql:5.7.42、postgres:13.16、dm8:20250206_rev257733_x86_rh6_64、oceanbase-ce:v4.0、opengauss:5.0.2 通过网盘分享的文件&#xff1a;db.tgz 链接: https://pan.baidu.com/s/1EBbFPZj1FxCA4_GxjVunWg?pwd563s 提取码: 5…

python爬虫系列课程2:如何下载Xpath Helper

python爬虫系列课程2:如何下载Xpath Helper 一、访问极简插件官网二、点击搜索按钮三、输入xpath并点击搜索四、点击推荐下载五、将下载下来的文件解压缩六、打开扩展程序界面七、将xpath.crx文件拖入扩展程序界面一、访问极简插件官网 极简插件官网地址:https://chrome.zzz…

PHP支付宝--转账到支付宝账户

官方参考文档&#xff1a; ​https://opendocs.alipay.com/open/62987723_alipay.fund.trans.uni.transfer?sceneca56bca529e64125a2786703c6192d41&pathHash66064890​ 可以使用默认应用&#xff0c;也可以自建新应用&#xff0c;此处以默认应用来讲解【默认应用默认支持…

前端开发岗模拟面试题套卷A答案及解析(一)技术面部分

前端开发岗模拟面试题套卷A答案及解析(一)技术面部分 (一)技术面 一、JavaScript核心技术(ES6+) 1-1、实现防抖函数 function debounce(fn, delay) {let timer = null;return function(...args) {clearTimeout(timer); // 清除已有定时器timer = setTimeout(() =>…

对称加密算法——IDEA加密算法

Java IDEA算法详解 1. 理论背景 IDEA&#xff08;International Data Encryption Algorithm&#xff09;是一种对称密钥加密算法&#xff0c;由Xuejia Lai和James Massey于1991年提出。它被设计用于替代DES&#xff08;Data Encryption Standard&#xff09;算法&#xff0c;…

单例模式、构造函数、左值右值

拷贝构造函数 简单的说就是——用一个对象构造另外一个对象 class Myclass {public:int d0;Myclass(int d_){d d_}; //常用的构造函数Myclass(Myclass c) //拷贝构造函数{d c.d;} }; //对比 class Myclass {public:int d0;Myclass(int d_){d d_}; //常用的构造函数Myclass…

rustdesk远程桌面自建服务器

首先&#xff0c;我这里用到的是阿里云服务器 centos7版本&#xff0c;win版客户端。 准备工作 centos7 服务器端文件&#xff1a; https://github.com/rustdesk/rustdesk-server/releases/download/1.1.11-1/rustdesk-server-linux-amd64.zip win版客户端安装包&#xff1…

【深度学习】Transformer入门:通俗易懂的介绍

【深度学习】Transformer入门&#xff1a;通俗易懂的介绍 一、引言二、从前的“读句子”方式三、Transformer的“超级阅读能力”四、Transformer是怎么做到的&#xff1f;五、Transformer的“多视角”能力六、Transformer的“位置记忆”七、Transformer的“翻译流程”八、Trans…

用deepseek学大模型03-数学基础 概率论 最大似然估计(MLE)最大后验估计(MAP)

https://metaso.cn/s/r4kq4Ni 什么是最大似然估计&#xff08;MLE&#xff09;最大后验估计&#xff08;MAP&#xff09;&#xff1f;深度学习中如何应用&#xff0c;举例说明。 好的&#xff0c;我现在需要回答关于最大似然估计&#xff08;MLE&#xff09;和最大后验估计&…

Socket通讯协议理解及客户端服务器程序流程

Socket通讯我们可以从以下几个方面简单理解 1.Socket是网络通信中的一项重要技术&#xff0c;它提供了在网络上进行数据交换的接口。用C#、Java、C等开发语言&#xff0c;都可以开发Socket网络通信程序。 2.Socket(套接字)是计算机网络编程中的一种抽象&#xff0c;它允许不同…

《Stable Diffusion绘画完全指南:从入门到精通的Prompt设计艺术》-配套代码示例

第一章&#xff1a;模型加载与基础生成 1.1 基础模型加载 from diffusers import StableDiffusionPipeline import torch# 加载SD 1.5基础模型&#xff08;FP32精度&#xff09; pipe StableDiffusionPipeline.from_pretrained("runwayml/stable-diffusion-v1-5",…

【DL】浅谈深度学习中的知识蒸馏 | 输出层知识蒸馏

目录 一 核心概念与背景 二 输出层知识蒸馏 1 教师模型训练 2 软标签生成&#xff08;Soft Targets&#xff09; 3 学生模型训练 三 扩展 1 有效性分析 2 关键影响因素 3 变体 一 核心概念与背景 知识蒸馏&#xff08;Knowledge Distillation, KD&#xff09;是一种模…

嵌入式学习第十六天--stdio(二)

文件打开 open函数 #include <fcntl.h> int open(const char *pathname&#xff0c;int flags); int open(const char *pathname&#xff0c;int flags&#xff0c;mode_t mode); 功能: 打开或创建文件 参数: pathname //打开的文件名 flags //操作…