使用Ubidots的MQTT协议简介

电子说

1.3w人已加入

描述

第1步:演示

第2步:使用的资源

•ESP32 LoRa Display

•DHT22

•4k7欧姆电阻

•帐户(试用30天或已付款)

•Proboardboard

步骤3:MQTT协议

MQTT

发布和订阅

步骤4:Ubidots IoT平台

要解决的问题

•创建一个新帐户

•创建新的仪表板

•创建ESP32-DHT设备

•获得MQTT数据-设备ID和主题

•获得MQTT数据-令牌

•在Ubidots中创建变量

•创建湿度和温度小部件

步骤5:创建新帐户

MQTT

MQTT

MQTT

MQTT

MQTT

MQTT

要创建帐户,请访问www.ubidots.com并单击在注册后

A。公司名称

B。项目阶段:

B-我们选择了发现阶段,表明它是一个测试项目。

C。创建应用程序

D。您的姓名

您的电子邮件

创建个人资料

E。登录

密码

开始免费试用

步骤6:创建新仪表板

MQTT

MQTT

一个。单击创建一个新的仪表板

B。输入仪表板的名称,然后单击

步骤7:创建ESP32-DHT设备

MQTT

MQTT

MQTT

MQTT

MQTT

A。单击设备管理和设备

B。单击创建设备或+

C。将打开一个选项卡,列出help.ubidots站点上的教程,以根据各自的制造商对微控制器进行配置和编程。我们将创建一个空白设备。

D。填写字段

1。设备名称

2。标签(它将是MQTT客户端使用的主题的一部分)

3。创建

电子。创建设备后,它将在设备页面上列出,如图所示

1。设备名称

2。上次更新

3。设备创建日期/时间

4。与设备有关的组织

5。添加组织并删除设备

步骤8:获取MQTT数据-设备ID和主题

MQTT

MQTT

MQTT

一个。选择设备

B。设备ID值和主题是根据图像写入的。

使用的端口为1883。

C。根据图像3.1和3.2获得令牌。

步骤9:创建变量

MQTT

MQTT

MQTT

MQTT

要创建引用设备中变量的窗口小部件,必须已经在设备上创建了它。

注意:变量是在Json上传后由Ubidots自动创建的,但为此,必须至少连接一次ESP32。要引用小部件而不必连接ESP,我们必须遵循以下步骤。

A。在设备中,选择设备

B。单击“添加变量”,然后单击“原始”。

注意:定义相同的源代码标签(在MQTT_Client.h文件中)

C。输入标签(VARIABLE_LABEL_TEMPERATURE)

D。重复湿度变量的步骤

(VARIABLE_LABEL_HUMIDITY)

步骤10:创建小部件

MQTT

MQTT

一个。转到仪表板页面

B。单击按钮之一

步骤11:创建小部件-温度

MQTT

MQTT

MQTT

MQTT

MQTT

MQTT

A。选择温度计选项

B。点击添加变量

C。请按照以下步骤选择温度变量

D。单击“确认”

步骤12:创建窗口小部件-湿度

MQTT

MQTT

MQTT

A。添加另一个小部件

B。选择“坦克”选项

C。点击添加变量

D。选择ESP32-DHT,单击湿度,然后确认

E。最后,点击确认

F。湿度小部件将显示在温度G以下。

G。您可以通过拖动窗口来安排

步骤13:汇编

声明和变量

#include

#include //Biblioteca referente ao DHT22

#include “displayESP32LoRa.h” //Arquivo com as funções referentes ao display lora

#include “MQTT_Client.h” //Arquivo com as funções de mqtt

float temperature; //Temperatura que será obtida pelo sensor DHT

float humidity; //Umidade que será obtida pelo sensor DHT

const int pinDHT = 22; //Pino que é ligado no sensor DHT

SimpleDHT22 dht22(pinDHT); //Objeto que possui os métodos de leitura dos valores do sensor DHT

设置

void setup()

{

//Para debug, iniciamos a comunicação serial com 115200 bps

Serial.begin(115200);

//Inicializa display lora

if(!loraDisplayConfig())

ESP.restart();

//Exibe mensagem no display

showDisplay(0, “Setting up mqtt.。.”, true);

Serial.println(“Setting up mqtt.。.”);

//Inicializa mqtt (conecta o esp com o wifi, configura e conecta com o servidor da ubidots)

if(!mqttInit())

{

delay(3000);

showDisplay(0, “Failed!”, false);

Serial.println(“Failed!”);

ESP.restart();

}

showDisplay(0, “OK”, false);

Serial.println(“OK”);

}

循环

void loop()

{

//Se o esp foi desconectado do ubidots, tentamos reconectar

if(!client.connected())

reconnect();

//Lê a temperatura e umidade e exibimos no display passando uma flag (que sinaliza sucesso na leitura)

if(getClimate())

showClimate(true);

else

showClimate(false);

//Esperamos 2.5s antes de exibir o status do envio para dar efeito de pisca no display

delay(2500);

if(sendValues(temperature, humidity))

{

Serial.println(“Successfully sent data”);

showDisplay(4,“Successfully sent data”, false);

}

else

{

Serial.println(“Failed to send sensor data”);

showDisplay(4,“Failed to send sensor data”, false);

}

//Esperamos 2.5s para dar tempo de ler as mensagens acima

delay(2500);

}

循环-从DHT22读取值

//Obtém temperatura e umidade do sensor

bool getClimate()

{

int err = SimpleDHTErrSuccess;

//Passamos as variáveis ‘temperature’ e ‘humidity’ por parâmetro na função chamada ‘read2’, elas serão retornadas por referência

//Se não for retornado o código de SimpleDHTErrSuccess (sucesso), exibimos o valor de erro obtido

if ((err = dht22.read2(&temperature, &humidity, NULL)) != SimpleDHTErrSuccess)

{

Serial.print(“Read DHT22 failed, err=”);

Serial.println(err);

//Zera valores

temperature = humidity = 0;

return false;

}

return true;

}

循环-在显示屏上显示值

//Essa função exibe os valores com suas respectivas unidades de medida para caso a flag ‘success’ seja true

//Caso a flag ‘success’ seja false, exibimos apenas um traço ‘-’

void showClimate(bool success)

{

if(success)

{

showDisplay(0, “Temperature: ”+String(temperature)+“ °C”, true);

showDisplay(1, “Humidity: ”+String(humidity)+“ %”, false);

Serial.println(“Temperature: ”+String(temperature)+“ °C”);

Serial.println(“Humidity: ”+String(humidity)+“ %”);

}

else

{

showDisplay(0, “Temperature: -”, true);

showDisplay(1, “Humidity: -”, false);

Serial.println(“Temperature: -”);

Serial.println(“Humidity: -”);

}

}

MQTT_Client-声明和变量

#include

#include //Biblioteca para as publicações via mqtt

#include “displayESP32LoRa.h” //Arquivo com as funções referentes ao display lora

#define WIFISSID “MEU_SSID” //Coloque seu SSID de WiFi aqui

#define PASSWORD “MEU_PASSWORD” //Coloque seu password de WiFi aqui

#define TOKEN “xxxxxx” //Coloque seu TOKEN do Ubidots aqui

#define VARIABLE_LABEL_TEMPERATURE “temperature” //Label referente a variável de temperatura criada no ubidots

#define VARIABLE_LABEL_HUMIDITY “humidity” //Label referente a variável de umidade criada no ubidots

#define DEVICE_ID “xxxxxx” //ID do dispositivo (Device id, também chamado de client name)

#define SERVER “things.ubidots.com” //Servidor do Ubidots (broker)

//Porta padrão

#define PORT 1883

//Tópico aonde serão feitos os publish, “esp32-dht” é o DEVICE_LABEL

#define TOPIC “/v1.6/devices/esp32-dht”

//Objeto WiFiClient usado para a conexão wifi

WiFiClient ubidots;

//Objeto PubSubClient usado para publish–subscribe

PubSubClient client(ubidots);

MQTT_Client-引导

bool mqttInit()

{

//Inicia WiFi com o SSID e a senha

WiFi.begin(WIFISSID, PASSWORD);

//Loop até que o WiFi esteja conectado

while (WiFi.status() != WL_CONNECTED)

{

delay(1000);

Serial.println(“Establishing connection to WiFi.。”);

}

//Exibe no monitor serial

Serial.println(“Connected to network”);

//Seta servidor com o broker e a porta

client.setServer(SERVER, PORT);

//Conecta no ubidots com o Device id e o token, o password é informado como vazio

while(!client.connect(DEVICE_ID, TOKEN, “”))

{

Serial.println(“MQTT - Connect error”);

return false;

}

Serial.println(“MQTT - Connect ok”);

return true;

}

MQTT_Client-重新连接

void reconnect()

{

//Loop até que o MQTT esteja conectado

while (!client.connected())

{

//sinaliza desconexão do mqtt no display

showDisplay(0,“Disconnected”, true);

showDisplay(1, “Trying to reconnect mqtt.。.”, false);

Serial.println(“Attempting MQTT connection.。.”);

//Tenta conectar

if (client.connect(DEVICE_ID, TOKEN,“”))

Serial.println(“connected”);

else

{

Serial.print(“failed, rc=”);

Serial.print(client.state());

Serial.println(“ try again in 2 seconds”);

//Aguarda 2 segundos antes de retomar

delay(2000);

}

}

//Sinaliza reconexão do mqtt no display

showDisplay(4,“Reconnected”, false);

}

MQTT_Client-提交(发布)

//Envia valores por mqtt

//Exemplo: {“temperature”:{“value”:24.50, “context”:{“temperature”:24.50, “humidity”:57.20}}}

bool sendValues(float temperature, float humidity)

{

char json[250];

//Atribui para a cadeia de caracteres “json” os valores referentes a temperatura e os envia para a variável do ubidots correspondente

sprintf(json, “{”%s“:{”value“:%02.02f, ”context“:{”temperature“:%02.02f, ”humidity“:%02.02f}}}”, VARIABLE_LABEL_TEMPERATURE, temperature, temperature, humidity);

if(!client.publish(TOPIC, json))

return false;

//Atribui para a cadeia de caracteres “json” os valores referentes a umidade e os envia para a variável do ubidots correspondente

sprintf(json, “{”%s“:{”value“:%02.02f, ”context“:{”temperature“:%02.02f, ”humidity“:%02.02f}}}”, VARIABLE_LABEL_HUMIDITY, humidity, temperature, humidity);

if(!client.publish(TOPIC, json))

return false;

//Se tudo der certo retorna true

return true;

}

步骤14:ESP32代码

Json

(图像)

显示LoRa

#ifndef _DISPLAY_LORA_

#define _DISPLAY_LORA_

#include “SSD1306.h”

//Define os pinos que serão utilizados pelo display LoRa

#define SCK 5 // GPIO5 -- SX127x‘s SCK

#define MISO 19 // GPIO19 -- SX127x’s MISO

#define MOSI 27 // GPIO27 -- SX127x‘s MOSI

#define SS 18 // GPIO18 -- SX127x’s CS

#define RST 14 // GPIO14 -- SX127x‘s RESET

#define DI00 26 // GPIO26 -- SX127x’s IRQ(Interrupt Request)

SSD1306 display(0x3c, 4, 15); //Construtor do objeto do display LoRa

显示LoRa-loraDisplayConfig

//Configura Display LoRa

bool loraDisplayConfig()

{

//Configura RST do oled como saida

pinMode(16,OUTPUT);

//Reseta o OLED

digitalWrite(16, LOW);

//Aguarda 50ms

delay(50);

//Enquanto o OLED estiver ligado, GPIO16 deve estar HIGH

digitalWrite(16, HIGH);

//Inicializa display

if(!display.init())

return false;

//Inverte a tela verticalmente (de ponta cabeça)

display.flipScreenVertically();

//Configura a fonte do display

display.setFont(ArialMT_Plain_10);

//Aguarda 200ms

delay(200);

//Limpa display

display.clear();

return true;

}

#endif

Display LoRa-showDisplay

//Exibe mensagem recebida como parâmetro

void showDisplay(int line, String msg, bool clear)

{

//Limpa o display

if(clear)

{

display.clear();

//Configura alinhamento de texto à esquerda

display.setTextAlignment(TEXT_ALIGN_LEFT);

//Configura fonte do texto

display.setFont(ArialMT_Plain_10);

}

//Escreve na pos 0,25 a mensagem

display.drawString(0 , line*10 , msg);

//Exibe no display

display.display();

}

步骤15:安装库

SimpleDHT

https://github.com/winlinvip/SimpleDHT

Pubsubclient

https://github.com/knolleary/pubsubclient

*显示LoRa附加到项目中的

责任编辑:wv

打开APP阅读更多精彩内容
声明:本文内容及配图由入驻作者撰写或者入驻合作网站授权转载。文章观点仅代表作者本人,不代表电子发烧友网立场。文章及其配图仅供工程师学习之用,如有内容侵权或者其他违规问题,请联系本站处理。 举报投诉

全部0条评论

快来发表一下你的评论吧 !

×
20
完善资料,
赚取积分