LDR с использованием облака Thingsai: 13 шагов
LDR с использованием облака Thingsai: 13 шагов
Anonim
LDR с использованием облака Thingsai
LDR с использованием облака Thingsai

ЭЙ … сегодня мы узнаем об измерении интенсивности света и размещении значений в облачной платформе THINGSAI IOT с помощью ESP32.

Требования для выполнения этого проекта:

1. ESP32 Development Board (я использовал ESP32 DEVKIT V1)

2. Датчик LDR

3. Проволочные перемычки

4. Аккаунт в ПЛАТФОРМЕ THINGSAI IOT.

Шаг 1. Создание и вход на платформу THINGSIO

Создание и вход на платформу THINGSIO
Создание и вход на платформу THINGSIO

Войдите в учетную запись THINGS AI. Если вы новичок, зарегистрируйтесь в учетной записи, нажав кнопку регистрации и заполните все учетные данные. Будет создана ваша учетная запись, и с этого момента вы сможете работать на облачной платформе и создавать свой собственный проект.

Шаг 2: Создание нового проекта

Создание нового проекта
Создание нового проекта

После входа в учетную запись, чтобы создать проект, просто щелкните новый проект и укажите имя проекта.

Шаг 3: Создание нового устройства

Создание нового устройства
Создание нового устройства

После создания проекта вам нужно будет создать новое устройство. Укажите имя устройства и введите идентификатор устройства вручную или сгенерированный системой.

Шаг 4: Определение параметра устройства

Определение параметра устройства
Определение параметра устройства

Укажите параметр устройства, а затем выберите тип параметра

Шаг 5: Обновление устройства

Обновление устройства
Обновление устройства

Выберите параметр, а затем обновите устройство

Шаг 6: кодирование

Кодирование
Кодирование

Из примеров кодов выберите код esp32, скопируйте его, затем вставьте в IDE arduino и внесите необходимые изменения в соответствии с требованиями. Я привел код ниже

#include #include

#включают

int count = 0, я, м, j, k;

int t; int outputpin = A0; // ds18b20

int sensorvalue;

////////////////////////////////////// ВСЕ ЗАЯВЛЕНИЯ для ОБЛАКА ////// ////////////////////////

const char * host = "api.thingsai.io"; // ИЛИ

host = devapi2.thethingscloud.com

const char * post_url = "/ devices / deviceData"; // ИЛИ / api / v2 / thingscloud2 / _table / data_ac

const char * time_server = "baas.thethingscloud.com"; // это для преобразования метки времени

const int httpPort = 80;

const int httpsPort = 443;

const char * server = "api.thingsai.io"; // URL сервера

временная метка [10];

WiFiMulti WiFiMulti;

// Используйте класс WiFiClient для создания TCP-соединений

Клиент WiFiClient;

/////////////////////////////////////// Функция РАСЧЕТ ВРЕМЕННОЙ АППАРАТУРЫ //////// /////////////////////////////// int GiveMeTimestamp () {unsigned long timeout = millis (); // Клиент WiFiClient;

пока (client.available () == 0)

{

если (millis () - таймаут> 50000)

{

client.stop (); возврат 0;

}

}

пока (client.available ())

{

Строка line = client.readStringUntil ('\ r'); // indexOf () - функция для поиска чего-либо, возвращает -1, если не найдено

int pos = line.indexOf ("\" отметка времени / ""); // ищем "\" отметку времени / "" от начала полученного ответа и копируем все данные после этого, это будет ваша отметка времени

если (pos> = 0)

{

int j = 0;

для (j = 0; j <10; j ++)

{

отметка времени [j] = строка [pos + 12 + j];

}

}

}

} ////////////////////////////////////////////////////////////////////////////////////////////////////////

установка void ()

{

Serial.begin (115200);

задержка (10);

// Начнем с подключения к сети Wi-Fi

WiFiMulti.addAP («Wi-Fi», «pswrd»);

Serial.println ();

Serial.println ();

Serial.print («Ждите WiFi…»);

пока (WiFiMulti.run ()! = WL_CONNECTED)

{

Serial.print (".");

задержка (500);

}

Serial.println ("");

Serial.println («WiFi подключен»);

Serial.println ("IP-адрес:"); Serial.println (WiFi.localIP ());

задержка (500);

}

пустой цикл ()

{

int analogValue = analogRead (вывод);

{/////////////////////////////////////// ОТПРАВИТЬ ЗАПРОС И ПОЛУЧИТЕ ОТВЕТ /// ////////////////////

значение датчика = analogRead (A0); // считываем аналоговый входной контакт 0

значение датчика = значение датчика / 100;

Serial.print (значение датчика, DEC); // выводит прочитанное значение

Serial.print ("\ n"); // печатает пробел между числами

задержка (1000); // ждем 100 мс для следующего чтения

Serial.print («подключение к»); Serial.println (хост); // определенный потенциал роста: - host = devapi2.thethingscloud.com или 139.59.26.117

///////////////////////////////////// КОД TIMESTAMP КОД ИНФОРМАЦИЯ ////////// ///////////////

Serial.println ("получить метку времени / n");

если (! client.connect (сервер_времени, { возвращение; // * - * - * - * - * - * - * - * - * - *}

client.println ("GET / api / timestamp HTTP / 1.1"); // Что делает эта часть, я не получил client.println ("Host: baas.thethingscloud.com");

client.println ("Контроль кеширования: без кеширования");

client.println ("Почтальон-токен: ea3c18c6-09ba-d049-ccf3-369a22a284b8");

client.println ();

GiveMeTimestamp (); // вызовет функцию, которая получит ответ с отметкой времени от сервера Serial.println ("отметка времени получена");

Serial.println (отметка времени);

Serial.println («внутри ThingsCloudPost»);

Строка PostValue = "{" id_устройства / ": 61121695844, \" slave_id / ": 2";

PostValue = PostValue + ", \" dts / ":" + отметка времени;

PostValue = PostValue + ", \" данные / ": {" ИНТЕНСИВНОСТЬ / ":" + / sensorvalue + "}" + "}";

Serial.println (PostValue);

/ * создаем экземпляр WiFiClientSecure * / WiFiClientSecure client;

Serial.println («Подключиться к серверу через порт 443»);

если (! client.connect (сервер, 443))

{

Serial.println («Ошибка подключения!»);

}

еще

{Serial.println («Подключено к серверу!»); / * создаем HTTP-запрос * /

client.println ("POST / devices / deviceData HTTP / 1.1");

client.println ("Хост: api.thingsai.io"); //client.println("Connection: close "); cl

ient.println ("Content-Type: application / json");

client.println ("управление кешем: без кеша");

client.println («Авторизация: BearereyJ0eXAiOiJKV1QiLCJhbGciOiJIUzI1NiJ9. IjVhMzBkZDFkN2QwYjNhNGQzODkwYzQ4OSI.kaY6OMj5cYlWNqC9PNtdk; client.print ("Длина содержимого:");

client.println (PostValue.length ());

client.println ();

client.println (PostValue); ////////////////////////////////// Публикация данных в облако завершена, и теперь мы получаем облако формы ответа. сервер //////////////////

Serial.print («Жду ответа»);

while (! client.available ()) {

задержка (50); //

Serial.print (".");

} / * если данные доступны, получим и распечатаем в Терминал * /

пока (client.available ())

{

char c = client.read ();

Serial.write (c);

}

/ * если сервер отключился, останавливаем клиента * /

если (! client.connected ())

{

Serial.println ();

Serial.println («Сервер отключен»);

client.stop ();

}

} Serial.println ("////////////////////// КОНЕЦ //////////////////// / ");

задержка (3000); }}

Шаг 7: Выбор платы и Com-порта

Выбор платы и порта связи
Выбор платы и порта связи

Из инструментов выберите плату, а затем выберите com-порт.

Шаг 8: Подключение цепей

Цепные соединения
Цепные соединения
Цепные соединения
Цепные соединения
Цепные соединения
Цепные соединения

После завершения кодирования выполните следующие подключения, как указано ниже.

СОЕДИНЕНИЯ:

GND esp32 к GND датчика LDR

3V3 0f esp32 к Vcc LDR

Вице-президент esp32 в A0 LDR

Шаг 9: скомпилируйте и загрузите

Скомпилировать и загрузить
Скомпилировать и загрузить

скомпилируйте и загрузите код в esp32, а затем прочтите показания последовательного монитора. Результат будет примерно таким

Шаг 10: последовательный монитор

Последовательный монитор
Последовательный монитор

Значения получаются на последовательном мониторе, а затем отправляются в платформу THINGSAI IOT Cloud.

Шаг 11: чтения

Чтения
Чтения

Здесь показаны значения, полученные от платы esp32.

Шаг 12: графическое представление

Графическое представление
Графическое представление

Это графическое представление полученных значений. Это конец учебника. Надеюсь, вы поняли. Спасибо