Arduino:
Skicka en HTTP-förfrågan med Basic-autentisering
Hur man gör:
#include <ESP8266WiFi.h>
#include <Base64.h>
const char* ssid = "dittSSID";
const char* password = "dittLösenord";
const char* host = "www.dinserver.com";
const int httpPort = 80;
void setup() {
Serial.begin(115200);
WiFi.begin(ssid, password);
while (WiFi.status() != WL_CONNECTED) {
delay(500);
Serial.print(".");
}
Serial.println("");
Serial.println("WiFi connected");
String authValue = "Basic " + base64::encode(String("användare:lösenord"));
WiFiClient client;
if (!client.connect(host, httpPort)) {
Serial.println("Connection failed");
return;
}
String url = "/min_resurs";
client.print(String("GET ") + url + " HTTP/1.1\r\n" +
"Host: " + host + "\r\n" +
"Authorization: " + authValue + "\r\n" +
"Connection: close\r\n\r\n");
while (client.connected()) {
String line = client.readStringUntil('\n');
if (line == "\r") {
break;
}
}
String response = client.readStringUntil('\n');
Serial.println("Server response: ");
Serial.println(response);
}
void loop() {
// Gör ingenting här
}
Djupdykning
HTTP Basic Authentication introducerades tidigt i webbens historia, som en del av HTTP/1.0-specifikationen. Det är inte det säkraste sättet att skicka känslig information, eftersom inloggningsuppgifterna enkelt kan avkodas om de inte skickas över HTTPS. Men i ett slutet eller säkert nätverk kan det vara tillräckligt för vissa ändamål. Alternativen inkluderar OAuth, API-nycklar eller JWT-tokens, som erbjuder starkare säkerhet. När det implementeras på en Arduino som använder ESP8266-chipet, som i exemplet ovan, används Base64
-biblioteket för att koda användarnamn och lösenord. WiFiClient
används för att upprätta en nätverksanslutning och skicka förfrågan.
Se även
- ESP8266WiFi biblioteket: https://arduino-esp8266.readthedocs.io/en/latest/esp8266wifi/readme.html
- Base64 kodning i Arduino: https://www.arduino.cc/reference/en/libraries/base64/
- Mer om HTTP-autentisering: https://developer.mozilla.org/en-US/docs/Web/HTTP/Authentication