mirror of
https://github.com/IoTManagerProject/IoTManager.git
synced 2026-03-29 07:32:18 +03:00
Добавил библиотечные веб сокеты, проверенная версия.
This commit is contained in:
@@ -1,6 +1,9 @@
|
||||
#include "Global.h"
|
||||
|
||||
//глобальные объекты классов
|
||||
/*********************************************************************************************************************
|
||||
*****************************************глобальные объекты классов***************************************************
|
||||
**********************************************************************************************************************/
|
||||
|
||||
TickerScheduler ts(MYTEST + 1);
|
||||
#ifdef ASYNC_WEB_SERVER
|
||||
AsyncWebServer server(80);
|
||||
@@ -16,7 +19,14 @@ WebServer HTTP(80);
|
||||
#endif
|
||||
#endif
|
||||
|
||||
//глобальные переменные
|
||||
#ifdef STANDARD_WEB_SOCKETS
|
||||
WebSocketsServer standWebSocket = WebSocketsServer(81);
|
||||
#endif
|
||||
|
||||
/*********************************************************************************************************************
|
||||
***********************************************глобальные переменные**************************************************
|
||||
**********************************************************************************************************************/
|
||||
|
||||
String settingsFlashJson = "{}"; //переменная в которой хранятся все настройки, находится в оперативной памяти и синхронизированна с flash памятью
|
||||
String paramsFlashJson = "{}"; //переменная в которой хранятся все параметры, находится в оперативной памяти и синхронизированна с flash памятью
|
||||
String paramsHeapJson = "{}"; //переменная в которой хранятся все параметры, находится в оперативной памяти только
|
||||
@@ -68,7 +68,7 @@ bool handleFileRead(String path) {
|
||||
if (FileFS.exists(pathWithGz))
|
||||
path += ".gz";
|
||||
File file = FileFS.open(path, "r");
|
||||
size_t sent = HTTP.streamFile(file, contentType);
|
||||
HTTP.streamFile(file, contentType);
|
||||
file.close();
|
||||
return true;
|
||||
}
|
||||
@@ -181,3 +181,45 @@ void handleFileList() {
|
||||
}
|
||||
#endif
|
||||
#endif
|
||||
|
||||
#ifdef STANDARD_WEB_SOCKETS
|
||||
void standWebSocketsInit() {
|
||||
standWebSocket.begin();
|
||||
standWebSocket.onEvent(webSocketEvent);
|
||||
}
|
||||
|
||||
void webSocketEvent(uint8_t num, WStype_t type, uint8_t* payload, size_t length) {
|
||||
switch (type) {
|
||||
case WStype_DISCONNECTED:
|
||||
Serial.printf("[%u] Disconnected!\n", num);
|
||||
break;
|
||||
|
||||
case WStype_CONNECTED: {
|
||||
IPAddress ip = standWebSocket.remoteIP(num);
|
||||
Serial.printf("[%u] Connected from %d.%d.%d.%d url: %s\n", num, ip[0], ip[1], ip[2], ip[3], payload);
|
||||
|
||||
// send message to client
|
||||
standWebSocket.sendTXT(num, "Connected");
|
||||
} break;
|
||||
|
||||
case WStype_TEXT:
|
||||
Serial.printf("[%u] get Text: %s\n", num, payload);
|
||||
|
||||
// send message to client
|
||||
// standWebSocket.sendTXT(num, "message here");
|
||||
|
||||
// send data to all connected clients
|
||||
// standWebSocket.broadcastTXT("message here");
|
||||
break;
|
||||
|
||||
case WStype_BIN:
|
||||
Serial.printf("[%u] get binary length: %u\n", num, length);
|
||||
hexdump(payload, length);
|
||||
|
||||
// send message to client
|
||||
// standWebSocket.sendBIN(num, payload, length);
|
||||
break;
|
||||
}
|
||||
}
|
||||
|
||||
#endif
|
||||
|
||||
@@ -24,6 +24,10 @@ void setup() {
|
||||
standWebServerFiles();
|
||||
#endif
|
||||
|
||||
#ifdef STANDARD_WEB_SOCKETS
|
||||
standWebSocketsInit();
|
||||
#endif
|
||||
|
||||
//подключаемся к роутеру
|
||||
routerConnect();
|
||||
|
||||
@@ -48,4 +52,8 @@ void loop() {
|
||||
#ifdef STANDARD_WEB_SERVER
|
||||
HTTP.handleClient();
|
||||
#endif
|
||||
|
||||
#ifdef STANDARD_WEB_SOCKETS
|
||||
standWebSocket.loop();
|
||||
#endif
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user