mirror of
				https://github.com/0xFEEDC0DE64/arduino-esp32.git
				synced 2025-10-22 18:51:41 +02:00 
			
		
		
		
	* fix sdmmc config * Fix warnings in EEPROM from @Curclamas * remove leftover TAG in EEPROM * Initial add of @stickbreaker i2c * Add log_n * fix warnings when log is off * i2c code clean up and reorganization * add flags to interrupt allocator * fix sdmmc config * Fix warnings in EEPROM from @Curclamas * remove leftover TAG in EEPROM * fix errors with latest IDF * fix debug optimization (#1365) incorrect optimization for debugging tick markers. * Fix some missing BT header * Change BTSerial log calls * Update BLE lib * Arduino-ESP32 release management scripted (#1515) * Calculate an absolute path for a custom partitions table (#1452) * * Arduino-ESP32 release management scripted (ready-to-merge) * * secure env for espressif/arduino-esp32 * * build tests enabled * gitter webhook enabled * * gitter room link fixed * better comment * * filepaths fixed * BT Serial adjustments * * don't run sketch builds & tests for tagged builds * Return false from WiFi.hostByName() if hostname is not resolved * Free BT Memory when BT is not used * WIFI_MODE_NULL is not supported anymore * Select some key examples to build with PlatformIO to save some time * Update BLE lib * Fixed BLE lib * Major WiFi overhaul - auto reconnect on connection loss now works - moved to event groups - some code clean up and procedure optimizations - new methods to get a more elaborate system ststus * Add cmake tests to travis * Add initial AsyncUDP * Add NetBIOS lib and fix CMake includes * Add Initial WebServer * Fix WebServer and examples * travis not quiting on build fail * Try different travis build * Update IDF to aaf1239 * Fix WPS Example * fix script permission and add some fail tests to sketch builder * Add missing space in WiFiClient::write(Stream &stream)
		
			
				
	
	
		
			133 lines
		
	
	
		
			4.1 KiB
		
	
	
	
		
			C++
		
	
	
	
	
	
			
		
		
	
	
			133 lines
		
	
	
		
			4.1 KiB
		
	
	
	
		
			C++
		
	
	
	
	
	
| #include <WiFi.h>
 | |
| #include <WiFiClient.h>
 | |
| #include <WebServer.h>
 | |
| 
 | |
| const char* ssid = "........";
 | |
| const char* password = "........";
 | |
| 
 | |
| WebServer server(80);
 | |
| 
 | |
| //Check if header is present and correct
 | |
| bool is_authentified() {
 | |
|   Serial.println("Enter is_authentified");
 | |
|   if (server.hasHeader("Cookie")) {
 | |
|     Serial.print("Found cookie: ");
 | |
|     String cookie = server.header("Cookie");
 | |
|     Serial.println(cookie);
 | |
|     if (cookie.indexOf("ESPSESSIONID=1") != -1) {
 | |
|       Serial.println("Authentification Successful");
 | |
|       return true;
 | |
|     }
 | |
|   }
 | |
|   Serial.println("Authentification Failed");
 | |
|   return false;
 | |
| }
 | |
| 
 | |
| //login page, also called for disconnect
 | |
| void handleLogin() {
 | |
|   String msg;
 | |
|   if (server.hasHeader("Cookie")) {
 | |
|     Serial.print("Found cookie: ");
 | |
|     String cookie = server.header("Cookie");
 | |
|     Serial.println(cookie);
 | |
|   }
 | |
|   if (server.hasArg("DISCONNECT")) {
 | |
|     Serial.println("Disconnection");
 | |
|     server.sendHeader("Location", "/login");
 | |
|     server.sendHeader("Cache-Control", "no-cache");
 | |
|     server.sendHeader("Set-Cookie", "ESPSESSIONID=0");
 | |
|     server.send(301);
 | |
|     return;
 | |
|   }
 | |
|   if (server.hasArg("USERNAME") && server.hasArg("PASSWORD")) {
 | |
|     if (server.arg("USERNAME") == "admin" &&  server.arg("PASSWORD") == "admin") {
 | |
|       server.sendHeader("Location", "/");
 | |
|       server.sendHeader("Cache-Control", "no-cache");
 | |
|       server.sendHeader("Set-Cookie", "ESPSESSIONID=1");
 | |
|       server.send(301);
 | |
|       Serial.println("Log in Successful");
 | |
|       return;
 | |
|     }
 | |
|     msg = "Wrong username/password! try again.";
 | |
|     Serial.println("Log in Failed");
 | |
|   }
 | |
|   String content = "<html><body><form action='/login' method='POST'>To log in, please use : admin/admin<br>";
 | |
|   content += "User:<input type='text' name='USERNAME' placeholder='user name'><br>";
 | |
|   content += "Password:<input type='password' name='PASSWORD' placeholder='password'><br>";
 | |
|   content += "<input type='submit' name='SUBMIT' value='Submit'></form>" + msg + "<br>";
 | |
|   content += "You also can go <a href='/inline'>here</a></body></html>";
 | |
|   server.send(200, "text/html", content);
 | |
| }
 | |
| 
 | |
| //root page can be accessed only if authentification is ok
 | |
| void handleRoot() {
 | |
|   Serial.println("Enter handleRoot");
 | |
|   String header;
 | |
|   if (!is_authentified()) {
 | |
|     server.sendHeader("Location", "/login");
 | |
|     server.sendHeader("Cache-Control", "no-cache");
 | |
|     server.send(301);
 | |
|     return;
 | |
|   }
 | |
|   String content = "<html><body><H2>hello, you successfully connected to esp8266!</H2><br>";
 | |
|   if (server.hasHeader("User-Agent")) {
 | |
|     content += "the user agent used is : " + server.header("User-Agent") + "<br><br>";
 | |
|   }
 | |
|   content += "You can access this page until you <a href=\"/login?DISCONNECT=YES\">disconnect</a></body></html>";
 | |
|   server.send(200, "text/html", content);
 | |
| }
 | |
| 
 | |
| //no need authentification
 | |
| void handleNotFound() {
 | |
|   String message = "File Not Found\n\n";
 | |
|   message += "URI: ";
 | |
|   message += server.uri();
 | |
|   message += "\nMethod: ";
 | |
|   message += (server.method() == HTTP_GET) ? "GET" : "POST";
 | |
|   message += "\nArguments: ";
 | |
|   message += server.args();
 | |
|   message += "\n";
 | |
|   for (uint8_t i = 0; i < server.args(); i++) {
 | |
|     message += " " + server.argName(i) + ": " + server.arg(i) + "\n";
 | |
|   }
 | |
|   server.send(404, "text/plain", message);
 | |
| }
 | |
| 
 | |
| void setup(void) {
 | |
|   Serial.begin(115200);
 | |
|   WiFi.mode(WIFI_STA);
 | |
|   WiFi.begin(ssid, password);
 | |
|   Serial.println("");
 | |
| 
 | |
|   // Wait for connection
 | |
|   while (WiFi.status() != WL_CONNECTED) {
 | |
|     delay(500);
 | |
|     Serial.print(".");
 | |
|   }
 | |
|   Serial.println("");
 | |
|   Serial.print("Connected to ");
 | |
|   Serial.println(ssid);
 | |
|   Serial.print("IP address: ");
 | |
|   Serial.println(WiFi.localIP());
 | |
| 
 | |
| 
 | |
|   server.on("/", handleRoot);
 | |
|   server.on("/login", handleLogin);
 | |
|   server.on("/inline", []() {
 | |
|     server.send(200, "text/plain", "this works without need of authentification");
 | |
|   });
 | |
| 
 | |
|   server.onNotFound(handleNotFound);
 | |
|   //here the list of headers to be recorded
 | |
|   const char * headerkeys[] = {"User-Agent", "Cookie"} ;
 | |
|   size_t headerkeyssize = sizeof(headerkeys) / sizeof(char*);
 | |
|   //ask server to track these headers
 | |
|   server.collectHeaders(headerkeys, headerkeyssize);
 | |
|   server.begin();
 | |
|   Serial.println("HTTP server started");
 | |
| }
 | |
| 
 | |
| void loop(void) {
 | |
|   server.handleClient();
 | |
| }
 |