ESP8266使用AT指令完成MQTT功能

ESP8266使用AT指令完成MQTT功能

在esp8266设备中烧录安信可的AT固件之后,进行AT指令完成信息发布,并最终实现在Homeassistant中发布传感器并设置传感器状态。

一、基础指令

以下是完整的步骤和对应的AT指令:

1. 配置ESP8266为Station模式

AT+CWMODE=1

2. 连接到WiFi网络

AT+CWJAP="HM","123321123"

此指令会将ESP8266连接到SSID为HM的WiFi网络,密码为123321123。根据需要进行自行配置。

3. 检查IP地址

AT+CIFSR

此指令会返回ESP8266的IP地址。如图片显示:
在这里插入图片描述

4. 设置MQTT预配置

要配置MQTT功能,您可能需要使用ESP8266的AT指令扩展库,ESP8266标准的固件没有直接提供MQTT支持。如果您的ESP8266固件已经预装了MQTT支持模块,通常会有以下MQTT相关指令:

设置MQTT客户端ID、用户名、密码(如果需要)
AT+MQTTUSERCFG=0,1,"Client_ID","user","pass",0,0,""
  • 0 表示配置第一个客户端。
  • 1 表示启用SSL(0表示不启用)。
  • "Client_ID" 是MQTT客户端的唯一标识符。
  • "user""pass" 分别是MQTT的用户名和密码,若不需要认证则可以为空字符串。
  • 由于我的mqtt服务器不需要验证,因此user和pass随便填写或者不该也没关系。
配置MQTT服务器地址和端口
AT+MQTTCONN=0,"192.168.10.120",1883,0
  • 0 表示第一个客户端。
  • "192.168.10.120" 是MQTT服务器的IP地址。
  • 1883 是MQTT服务器的端口号。
  • 最后的 0 表示清理会话标志。

5. 订阅MQTT主题(可选)

如果您希望订阅某个主题,可以使用以下指令:

AT+MQTTSUB=0,"test/topic",0
  • 0 是客户端ID。
  • "test/topic" 是订阅的主题。
  • 0 表示QoS等级。

6. 发布消息到MQTT服务器

AT+MQTTPUB=0,"test/topic","Hello World",0,0
  • 0 表示客户端ID。
  • "test/topic" 是要发布的主题。
  • "Hello World" 是要发布的消息内容。
  • 第一个 0 是QoS等级。
  • 第二个 0 表示不保留消息。

发布之后,由于前面订阅了该消息,因此串口会接收到相关信息,如下:
在这里插入图片描述

7. 断开MQTT连接

当你不再需要连接MQTT服务器时,可以使用以下指令断开连接:

AT+MQTTCLEAN=0
  • 0 表示客户端ID。

这是完成WiFi连接、MQTT连接、订阅、发布消息等所有步骤的完整流程。

二、指令数组

为了便于单片机通过串口使用ESP8266模块,将所有上述的AT指令放在一个数组中,单片机可以依次读取并发送这些指令。

const char* at_commands[] = {// 设置为Station模式"AT+CWMODE=1\r\n",// 连接到WiFi网络 (SSID: HM, 密码: 123321123)"AT+CWJAP=\"HM\",\"123321123\"\r\n",// 查询IP地址"AT+CIFSR\r\n",// 设置MQTT客户端配置 (Client_ID: ESP8266, 用户名和密码为空)"AT+MQTTUSERCFG=0,1,\"ESP8266\",\"\",\"\",0,0,\"\"\r\n",// 连接到MQTT服务器 (IP: 192.168.10.120, 端口: 1883)"AT+MQTTCONN=0,\"192.168.10.120\",1883,0\r\n",// 订阅主题 (主题: test/topic, QoS: 0)"AT+MQTTSUB=0,\"test/topic\",0\r\n",// 发布消息到主题 (主题: test/topic, 消息: Hello World, QoS: 0, 不保留)"AT+MQTTPUB=0,\"test/topic\",\"Hello World\",0,0\r\n"
};

三、发布话题给Homeassistant

参考教程https://blog.csdn.net/Hot_Ant/article/details/129904700,了解MQTT向HASS中创建设备和发布状态的过程。总结来说即发布配置->发布状态。

要通过ESP8266发送传感器配置和状态的AT指令,以下是分别配置二进制传感器(运动检测)和发布传感器状态的指令。

1. 配置二进制传感器(运动检测)

传感器的配置主题为 homeassistant/binary_sensor/garden/config,有效载荷用于告诉Home Assistant这个传感器的属性,包括名称、类型和状态主题。

对应的AT指令如下,但是可能是因为指令过长或转义问题,导致返回为ERROR,通过MQTT软件提前配置好再发布状态即可。注意双引号和逗号前面,使用了反斜杠进行转移。

AT+MQTTPUB=0,"homeassistant/binary_sensor/garden/config","{\"name\": null\, \"device_class\": \"motion\"\, \"state_topic\": \"homeassistant/binary_sensor/garden/state\"\, \"unique_id\": \"motion01ad\"\, \"device\": {\"identifiers\": [\"01ad\"]\, \"name\": \"Garden\"}}",0,1

解释:

  • homeassistant/binary_sensor/garden/config 是配置的主题。
  • JSON字符串是传感器的配置,使用了双反斜杠转义双引号。
  • 0 表示QoS为0。
  • 1 表示保留消息(MQTT Retain Flag)。

在这里插入图片描述

在这里插入图片描述

2. 发布传感器状态

当传感器状态发生变化时,需要通过发布消息来更新传感器的状态。

发布状态为“ON”(表示检测到运动)
AT+MQTTPUB=0,"homeassistant/binary_sensor/garden/state","ON",0,0

在这里插入图片描述

发布状态为“OFF”(表示未检测到运动)
AT+MQTTPUB=0,"homeassistant/binary_sensor/garden/state","OFF",0,0

在这里插入图片描述

四、解决发布config报错问题

  1. 尝试了一些方法,均无解,只要缩短一部分长度后,就可以正常OK了,使用完整指令就会报错。
  2. 后续尝试使用esp32进行测试。也是可能这款单片机只有1M的flash导致的。

结论

  1. 使用ESP烧录官方的AT指令同样存在问题。
  2. 经测试,是因为最大发送长度为256,上述指令超过了,导致error。
  3. 减少长度,例如配置homeassistant,将其前缀改为hass之类的减少长度,并设置name为123,这样指令刚好是256长度,就可以正常发送了:
    在这里插入图片描述

解决2:

  1. 查看官方教程,发现了还有一个发送函数AT+MQTTPUBRAW,可以发送更长的MQTT数据。【还是得看手册,本来想去github上提出issue的】

在这里插入图片描述

  1. 但是AT+MQTTPUBRAW指令并不是直接发送数据,而是先确定要发送的数据长度,然后再发送数据,满足要求后会发送数据。
AT+MQTTPUBRAW=<LinkID>,<"topic">,<length>,<qos>,<retain>
  1. 因此,需要先确定上述mqtt消息的长度,但是这时候不需要转义符了,因此长度为181。
AT+MQTTPUBRAW=0,"homeassistant/binary_sensor/garden/config",181,0,1
{"name": null, "device_class": "motion", "state_topic": "homeassistant/binary_sensor/garden/state", "unique_id": "motion01ad", "device": {"identifiers": ["01ad"], "name": "Garden"}}
  1. 此方法也适用于ESP8266

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

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

相关文章

贪吃蛇游戏(代码篇)

我们并不是为了满足别人的期待而活着。 前言 这是我自己做的第五个小项目---贪吃蛇游戏&#xff08;代码篇&#xff09;。后期我会继续制作其他小项目并开源至博客上。 上一小项目是贪吃蛇游戏&#xff08;必备知识篇&#xff09;&#xff0c;没看过的同学可以去看看&#xf…

多态对象的存储方案小结

某个类型有几种不同的子类&#xff0c;Jackson中的JsonTypeInfo 和JsonSubTypes可以应对这种情形&#xff0c;但有点麻烦&#xff0c;并且name属性必须是字符串、必须用Jackson为基础的json工具类对json字符串和对象进行序列化和反序列化。用过一次这种方案后边就不想再用了。 …

【Python数据结构】深入理解Python中的列表、字典和集合!

【Python数据结构】深入理解Python中的列表、字典和集合&#xff01; 在Python编程中&#xff0c;数据结构是处理和组织数据的核心部分。Python提供了许多内置的数据结构&#xff0c;如列表、字典和集合&#xff0c;它们为程序员提供了灵活、高效的数据管理方式。本篇博客将深…

如何实现简单的 WinCC 项目分屏?

说明&#xff1a; 本文主要介绍了在不使用分屏器的情况下&#xff0c;通过 WinCC 项目中的设置&#xff0c;实现简单的分屏操作。两台显示器分别显示不同的 WinCC 画面&#xff0c;独自操作&#xff0c;互不影响。 试验环境 &#xff1a; 本文试验时所用硬件及软件环境…

Ubuntu如何显示pcl版本

终端输入&#xff1a; apt-cache show libpcl-dev可以看到&#xff0c;Ubuntu20.04&#xff0c;下载的pcl&#xff0c;应该都是1.10版本的

机器学习可解释性

机器学习的稳健性、可解释性和结果正确性等是人工智能安全可信应用必须解决的关键问题。 传统机器学习&#xff1a; 内置可解释性&#xff1a;决策树IF-Then规则&#xff0c;直观可理解事后可解释性&#xff1a;训练结束后的可解释技术特定于模型体系结构的解释与解释方法及模…

VS Code设置右侧滚动条高亮选中的字符位置

打开菜单“文件 -> 首选项 -> 设置”&#xff0c; 搜索“hightlight”,扩展中的Highlight Selections&#xff0c;再点击“在 settings.json中编辑”&#xff0c; 将editor.selectionHighlight选项改为true保存即可

【读书笔记·VLSI电路设计方法解密】问题12:制造MOSFET晶体管的主要工艺步骤是什么

VLSI芯片是在半导体材料上制造的,这种材料的导电性介于绝缘体和导体之间。通过一种称为掺杂的工艺引入杂质,可以改变半导体的电气特性。能够在半导体材料的细小且定义明确的区域内控制导电性,促使了半导体器件的发展。结合更简单的无源元件(电阻、电容和电感),这些器件被…

股市入门常见术语介绍

鉴于最近行情讨论火热&#xff0c;我也想借此平台&#xff0c;结合我大学时期身边同学老师的投资经历&#xff0c;写一篇交易入门术语简介。内容不多但是足以达到科普之用。 ​ 希望大家能谨慎对待投资&#xff0c;始终保持谦虚学习的态度。不要迷失在瞬息万变的金融市场&…

Redis拒绝连接问题分析与解决方案

目录 前言1. 问题描述2. Redis拒绝连接的常见原因分析2.1 Redis服务未启动2.2 Redis配置中的绑定地址问题2.3 防火墙或安全组问题2.4 Redis连接池耗尽2.5 Redis服务器负载过高2.6 权限配置问题 3. 深度解决方案和优化建议4. 总结 前言 在分布式系统中&#xff0c;Redis作为高性…

游戏服务端架构演进

文章目录 前言初出茅庐粗通皮毛略有小成炉火纯青内劲深厚最后 前言 对于网络游戏&#xff0c;一般分为客户端和服务端&#xff0c;客户端主要负责界面图像的渲染与一些交互操作&#xff0c;服务端主要负责数据的业务处理与存储还有与客户端之间的信息交互 比如玩家聊天、广播…

黑马程序员-redis项目实践笔记1

目录 一、 基于Session实现登录 发送验证码 验证用户输入验证码 校验登录状态 Redis代替Session登录 发送验证码修改 验证用户输入验证码 登录拦截器的优化 二、 商铺查询缓存 缓存更新策略 数据库和缓存不一致解决方案 缓存更新策略的最佳实践方案 实现商铺缓…

TS中如何正确处理window类型

在Typescript项目中&#xff0c;你可能都遇到过这个错误&#xff1a; Window & typeof globalThis 类型上不存在属性 X。 快速修复方案 我们将介绍几种不同的解决方案来解决这个问题。 Window 接口是在名为 lib.dom.d.ts 的文件中全局定义的。你可以使用各种技术来更改它&a…

Windows 11 24H2版本有哪些新功能_Windows 11 24H2十四大新功能介绍

距离上次发布的23H2版本已经过去了一年时间&#xff0c;现在&#xff0c;Win 11的24H2版本终于等到了&#xff0c;微软已经全面公开发布Win11 24H2版本&#xff0c;版本号为26100.1742&#xff0c;此次官宣的版本包括了消费者版、商业版、LTSC 2024版等&#xff0c;各种语言版本…

如何启动hive

检查mysql是否启动 通过Navicat测试mysql是否可以连接 找打hive配置文件所在目录 检查连接mysql的账号密码是否正确,如果不正确就要修改为正确的 初始化hive元数据存储的库:schematool -dbType <database_type> -initSchema 检查mysql中是否创建hive数据库,这里看到hive数…

zookeeper客户端

启动单机版的zookeeper 配置Maven环境 (1) IDEA自带maven (2) 更新Maven库镜像地址&#xff1a; ① 拷贝D:\Program Files\JetBrains\IntelliJ IDEA 2018.3.5\plugins\maven\lib\maven3\conf\settings.xml [IntelliJ的安装目录]到 C:/用户/username/.m2 (如果.m2文件不存在&…

华宇携司法大模型亮相2024中国移动全球合作伙伴大会

2024中国移动全球合作伙伴大会于10月11日在广州琶洲保利世贸博览馆盛大开幕。本届大会以“智焕新生 共创AI时代”为主题&#xff0c;深入探讨数据、算力与人工智能如何深度融合&#xff0c;全力推进AI规模发展、规模应用&#xff0c;加快形成AI技术能力、经济效益上的规模效应&…

第十三章 RabbitMQ之消息幂等性

目录 一、引言 二、消息幂等解决方案 2.1. 方案一 2.2. 方案二 一、引言 幂等是一个数学概念&#xff0c;用函数表达式来描述是这样的&#xff1a;f(x) f(f(x)) 。在程序开发中&#xff0c;则是指同一个业务&#xff0c;执行一次或多次对业务状态的影响是一致的。有些业务…

react实现实时计时的最简方式

js中时间的处理&#xff0c;不借助于moment/dayjs这样的工具库&#xff0c;原生获取格式化的时间&#xff0c;最简单的实现方式可以参考下面这样。 实现效果 代码实现 封装hooks import { useState, useEffect } from "react";export function useCountTime() {c…

Python酷库之旅-第三方库Pandas(150)

目录 一、用法精讲 681、pandas.Timestamp.now方法 681-1、语法 681-2、参数 681-3、功能 681-4、返回值 681-5、说明 681-6、用法 681-6-1、数据准备 681-6-2、代码示例 681-6-3、结果输出 682、pandas.Timestamp.replace方法 682-1、语法 682-2、参数 682-3、…