uniapp 微信小程序接入MQTT

MQTT安裝

前期準備

  1. 由于微信小程序需要wss,所以要有域名SSL證書

  2. 新建目錄/srv/mosquitto/config/srv/mosquitto/config/cert

  3. 目錄/srv/mosquitto/config中新建配置文件mosquitto.conf,文件內容

    persistence true
    persistence_location /mosquitto/data
    log_dest file /mosquitto/log/mosquitto.log
    listener 1883
    listener 9001
    protocol websockets
    certfile /mosquitto/config/cert/mqtt.xxx.com_public.crt
    keyfile /mosquitto/config/cert/mqtt.xxx.com.key
    cafile /mosquitto/config/cert/mqtt.xxx.com_chain.crt
    allow_anonymous false
    password_file /mosquitto/config/pwfile.conf
    

    最后一行 /mosquitto/config/pwfile.conf ,是用戶認證配置,后面會說到

  4. 目錄/srv/mosquitto/config/cert中的證書文件對應上面的配置文件內容

    • mqtt.xxx.com_public.crt
    • mqtt.xxx.com.key
    • mqtt.xxx.com_chain.crt

docker命令部署MQTT服務

docker run -d --name eclipse-mosquitto -p 1883:1883 -p 9001:9001 -v /srv/mosquitto/config/:/mosquitto/config/ -v /srv/mosquitto/data:/mosquitto/data -v /srv/mosquitto/log:/mosquitto/log eclipse-mosquitto

MQTT用戶認證配置

docker exec -it mqtt /bin/sh
mosquitto_passwd /mosquitto/config/pwfile.conf {用戶名}

輸入上面的命令后還要輸入兩次密碼就可以了
如果MQTT客戶端連不上,重啟一下MQTT服務

docker restart mqtt 

uniapp配置

NPM方式安裝

npm i mqtt@4.1.0

安裝指定版本4.1.0,目前【2024-07-09】最新版本有問題

MQTT連接示例

import mqtt from 'mqtt/dist/mqtt'const client = mqtt.connect("wxs://mqtt.xxx.com", {port: '9001',username: '用戶名',password: '密碼',reconnectPeriod: 1000
});
this.client = client
client.on('connect', () => {console.log('connect')
});
// 自動重連
client.on('reconnect', (msg) => {console.log('reconnect', msg)
});
// 錯誤
client.on('error', () => {console.log('error')
});
// 斷開
client.on('end', () => {console.log('end')
});
// 掉線
client.on('offline', (msg) => {console.log('offline', msg)
});
// 收到消息        
client.on('message', (topic, message) => {// 把arrayBuffer轉成字符串let encodedString = String.fromCharCode.apply(null, new Uint8Array(message));
})

熄屏斷連問題

目前我的解決方案是
App.vue文件中onHide時斷開連接,onShow時重新初始化client。
訂閱時topic記錄下來,client.on(‘connect’)時遍歷topic記錄一一訂閱

onHide(() => {console.log("App onHide");client.end();
});

應用實例

我寫了個小程序,目前實現了一個功能

wol遠程電腦開機

微信小程序通過MQTT給ESP8266發送命令,ESP8266收到命令后發送WOL魔術包實現電腦開機,還可以用ESP8266直接連接電腦開機引腳開機。ESP8266代碼在文章的最上面,下載不了可私信我。
在這里插入圖片描述

防火布

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/diannao/44143.shtml
繁體地址,請注明出處:http://hk.pswp.cn/diannao/44143.shtml
英文地址,請注明出處:http://en.pswp.cn/diannao/44143.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

深入探索Apache Flink:流處理的藝術與實踐

在當今的大數據時代,流處理已成為處理實時數據的關鍵技術。Apache Flink,作為一個開源的流處理框架,以其高吞吐量、低延遲和精確一次(exactly-once)的語義處理能力,在眾多流處理框架中脫穎而出。本文將深入…

在樹莓派設備上導出系統鏡像

鏡像導出 前提條件: 已獲取可以正常使用的設備。已獲取鼠標、鍵盤和電源適配器。已將設備接入可正常使用的網絡。 操作步驟: 連接適配器給設備上電,正常啟動設備,連接鼠標和鍵盤。在終端命令窗格執行如下命令,安裝…

數據模型-ER圖在數據模型設計中的應用

ER圖在數據模型設計中的應用 1. ER圖概述:起源與發展? 實體-關系圖(Entity Relationship Diagram,簡稱ER圖)起源于1970年代,由Peter Chen首次提出,作為描述數據和信息間關系的圖形化語言。隨著數據庫技術…

[PM]流程與結構設計

流程圖 流程就是為了達到特定目標, 進行的一系列有邏輯性的操作步驟, 由兩個及已上的步驟, 完成一個完整的行為過程, 即可稱為流程, 流程圖就是對這個過程的圖形化展示 分類 業務流程圖 概念: 描述業務流程的一種圖, 通過特定符號和連線表示具體某個業務的處理步驟和過程作…

MyBatis與JDBC相比,有哪些優勢

MyBatis與JDBC(Java Database Connectivity)相比,在多個方面展現出顯著的優勢。這些優勢使得MyBatis在現代軟件開發中成為一個非常受歡迎的選擇,特別是在處理數據庫交互時。以下是MyBatis相比JDBC的主要優勢: 1. 簡化…

極狐GitLab亮相世界人工智能大會,開啟開源大模型賦能軟件研發新時代

GitLab 是一個全球知名的一體化 DevOps 平臺,很多人都通過私有化部署 GitLab 來進行源代碼托管。極狐GitLab :https://gitlab.cn/install?channelcontent&utm_sourcecsdn 是 GitLab 在中國的發行版,專門為中國程序員服務。可以一鍵式部署…

285個地級市-胡煥庸線數據

全國285個地級市-胡煥庸線數據.zip資源-CSDN文庫 胡煥庸線:中國人口與生態的分界線 胡煥庸線,一條在中國地理學界具有劃時代意義的分界線,由著名地理學家胡煥庸于1935年提出。這條線從黑龍江省的璦琿(現黑河市)延伸至…

json-server總結

Json-server 是一個專門用于模擬 RESTful API 的工具,它允許前端開發人員在不依賴后端 API 的情況下進行開發,通過本地搭建一個 JSON 服務來快速生成 REST API 風格的后端服務。 一、主要特點與功能 快速搭建:Json-server 使用 JSON 文件作…

HippoRAG如何從大腦獲取線索以改進LLM檢索

知識存儲和檢索正在成為大型語言模型(LLM)應用的重要組成部分。雖然檢索增強生成(RAG)在該領域取得了巨大進步,但一些局限性仍然沒有克服。 俄亥俄州立大學和斯坦福大學的研究團隊推出了HippoRAG,這是一種創新性的檢索框架,其設計理念源于人類…

數學建模美賽論文文檔

目錄 1. 摘要:1.1 閱讀并理解題目1.2 背景介紹1.3 問題提出 2. 目錄:2.1 引言(Introduction)2.2 假設與合理性說明(Assumptions and Justifications)2.3 符號說明(Notations)2.4 模型…

2.Date類型的請求參數

前端 <el-form-item label"結束日期" prop"endTime"><el-date-pickerv-model"dataForm.endTime"type"date"value-format"yyyy-MM-dd HH:mm:ss"placeholder"選擇日期"></el-date-picker></el…

線下線上游戲電競陪伴APP小程序H5同城線下約玩APP開發,語聊約玩平臺搭建游戲陪玩APP源碼

開發一款線下陪玩約玩APP的實際意義和在生活中的應用場景 1、滿足社交需求:現代社會人們的社交圈往往受到時間、地點和其他限制的影響。線下陪玩約玩APP可以提供一個平臺&#xff0c;讓用戶通過約玩的方式結識新朋友、擴大社交圈 2、解決孤獨感:有些人由于工作忙碌、居住環境單…

論文閱讀2-《Dynamic Multimodal Fusion》

摘要 &#xff08;DynMM&#xff09;&#xff0c;一種新的方法&#xff0c;自適應融合多模態數據和 d在推理過程中生成依賴于數據的前向路徑。為此&#xff0c;我們提出了一種門控功能來提供基于多模態特征和一個的模態級或融合級決策提高計算效率的源感知損失函數。 細節 模…

185240-00G 同軸連接器

型號簡介 185240-00G是Southwest Microwave的2.92 mm連接器。該連接器采用鈹銅合金、工具鋼和不銹鋼等優質材料&#xff0c;并經過金鍍層和鈍化處理&#xff0c;確保其穩定可靠&#xff0c;經久耐用。它還兼容歐盟 RoHS 和 WEEE 指令&#xff0c;是一位環保使者&#xff0c;致力…

AI繪畫Midjourney從入門到實戰應用

大家好&#xff0c;我是愛編程的喵喵。雙985碩士畢業&#xff0c;現擔任全棧工程師一職&#xff0c;熱衷于將數據思維應用到工作與生活中。從事機器學習以及相關的前后端開發工作。曾在阿里云、科大訊飛、CCF等比賽獲得多次Top名次。現為CSDN博客專家、人工智能領域優質創作者。…

概率論習題

泊松分布習題 假設你在醫院值班&#xff0c;每天需要安保人員出動的次數N~P(1),則關于任一天安保人員出動次數&#xff1a; A&#xff1a;出動一次的概率是多少 B&#xff1a;出動次數小于等于一次的概率為 C&#xff1a;出動次數小于一次的概率為 D&#xff1a;若隨機事件發生…

C# 裝飾器模式(Decorator Pattern)

裝飾器模式動態地給一個對象添加一些額外的職責。就增加功能來說&#xff0c;裝飾器模式相比生成子類更為靈活。 // 組件接口 public interface IComponent { void Operation(); } // 具體組件 public class ConcreteComponent : IComponent { public void Opera…

AI推薦系統落地的實現與應用

目錄 一、推薦系統的基礎二、推薦系統的設計與實現三、推薦系統落地的挑戰四、推薦系統的成功案例五、結語 AI推薦系統近年來在各個領域得到了廣泛應用&#xff0c;從電子商務到娛樂&#xff0c;再到個性化學習平臺。它們通過分析用戶行為、偏好和歷史數據&#xff0c;為用戶提…

【NOI-題解】1108 - 正整數N轉換成一個二進制數1290 - 二進制轉換十進制1386 - 小麗找半個回文數1405 - 小麗找潛在的素數?

文章目錄 一、前言二、問題問題&#xff1a;1108 - 正整數N轉換成一個二進制數問題&#xff1a;1290 - 二進制轉換十進制問題&#xff1a;1386 - 小麗找半個回文數問題&#xff1a;1405 - 小麗找潛在的素數&#xff1f; 三、感謝 一、前言 本章節主要對進制轉換的題目進行講解…

ubuntu下aarch64-linux-gnu(交叉編譯) gdb/gdbserver

ubuntu下aarch64-linux-gnu(交叉編譯) gdb/gdbserver gdb是一款開源的、強大的、跨平臺的程序調試工具。主要用于在程序運行時對程序進行控制和檢查&#xff0c;如設置斷點、單步執行、查看變量值、修改內存數據等&#xff0c;從而幫助開發者定位和修復代碼中的錯誤。 gdbserve…