This repository has been archived by the owner on Jan 29, 2023. It is now read-only.
forked from fhessel/esp32_https_server
-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathHTTPS-and-HTTP.ino
156 lines (125 loc) · 4.52 KB
/
HTTPS-and-HTTP.ino
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
/**
Example for the ESP32 HTTP(S) Webserver
IMPORTANT NOTE:
To run this script, your need to
1) Enter your WiFi SSID and PSK below this comment
2) Make sure to have certificate data available. You will find a
shell script and instructions to do so in the library folder
under extras/
This script will install an HTTP Server on port 80 and an HTTPS server
on port 443 of your ESP32 with the following functionalities:
- Show simple page on web server root
- 404 for everything else
The comments in this script focus on making both protocols available,
for setting up the server itself, see Static-Page.
*/
// TODO: Configure your WiFi here
#define WIFI_SSID "your_ssid"
#define WIFI_PSK "12345678"
// Include certificate data (see note above)
#include "cert.h"
#include "private_key.h"
// We will use wifi
#include <WiFi.h>
// Includes for the server
// Note: We include HTTPServer and HTTPSServer
#include <HTTPSServer.hpp>
#include <HTTPServer.hpp>
#include <SSLCert.hpp>
#include <HTTPRequest.hpp>
#include <HTTPResponse.hpp>
// The HTTPS Server comes in a separate namespace. For easier use, include it here.
using namespace httpsserver;
// Create an SSL certificate object from the files included above
SSLCert cert = SSLCert(
example_crt_DER, example_crt_DER_len,
example_key_DER, example_key_DER_len
);
// First, we create the HTTPSServer with the certificate created above
HTTPSServer secureServer = HTTPSServer(&cert);
// Additionally, we create an HTTPServer for unencrypted traffic
HTTPServer insecureServer = HTTPServer();
// The hanlder functions are the same as in the Static-Page example.
// The only difference is the check for isSecure in the root handler
void handleRoot(HTTPRequest * req, HTTPResponse * res)
{
res->setHeader("Content-Type", "text/html");
res->println("<!DOCTYPE html>");
res->println("<html>");
res->println("<head><title>Hello World!</title></head>");
res->println("<body>");
res->println("<h1>Hello World!</h1>");
res->print("<p>Your server is running for ");
res->print((int)(millis() / 1000), DEC);
res->println(" seconds.</p>");
// You can check if you are connected over a secure connection, eg. if you
// want to use authentication and redirect the user to a secure connection
// for that
if (req->isSecure())
{
res->println("<p>You are connected via <strong>HTTPS</strong>.</p>");
}
else
{
res->println("<p>You are connected via <strong>HTTP</strong>.</p>");
}
res->println("</body>");
res->println("</html>");
}
void handle404(HTTPRequest * req, HTTPResponse * res)
{
req->discardRequestBody();
res->setStatusCode(404);
res->setStatusText("Not Found");
res->setHeader("Content-Type", "text/html");
res->println("<!DOCTYPE html>");
res->println("<html>");
res->println("<head><title>Not Found</title></head>");
res->println("<body><h1>404 Not Found</h1><p>The requested resource was not found on this server.</p></body>");
res->println("</html>");
}
void setup()
{
// For logging
Serial.begin(115200);
while (!Serial && millis() < 5000);
///////////////////////////////////////////////
Serial.print("\nStarting HTTPS_and_HTTP on "); Serial.println(ARDUINO_BOARD);
// Connect to WiFi
Serial.println("Setting up WiFi");
WiFi.begin(WIFI_SSID, WIFI_PSK);
while (WiFi.status() != WL_CONNECTED)
{
Serial.print(".");
delay(500);
}
Serial.print("Connected. IP=");
Serial.println(WiFi.localIP());
// For every resource available on the server, we need to create a ResourceNode
// The ResourceNode links URL and HTTP method to a handler function
ResourceNode * nodeRoot = new ResourceNode("/", "GET", &handleRoot);
ResourceNode * node404 = new ResourceNode("", "GET", &handle404);
// Add the root node to the servers. We can use the same ResourceNode on multiple
// servers (you could also run multiple HTTPS servers)
secureServer.registerNode(nodeRoot);
insecureServer.registerNode(nodeRoot);
// We do the same for the default Node
secureServer.setDefaultNode(node404);
insecureServer.setDefaultNode(node404);
Serial.println("Starting HTTPS server...");
secureServer.start();
Serial.println("Starting HTTP server...");
insecureServer.start();
if (secureServer.isRunning() && insecureServer.isRunning())
{
Serial.println("Servers ready.");
}
}
void loop()
{
// We need to call both loop functions here
secureServer.loop();
insecureServer.loop();
// Other code would go here...
delay(1);
}