Inhoudsopgave:
2025 Auteur: John Day | [email protected]. Laatst gewijzigd: 2025-01-13 06:57
Hallo!In deze tutorial zul je ontdekken hoe je elk Arduino-compatibel apparaat, uitgerust met WiFi, kunt verbinden met REST API's! Gebruik de GitKraken Glo Board-webapp om borden, kolommen en kaarten te maken om dingen te organiseren!
Enige kennis van hoe openbare API werkt is vereist. Dit project is bedoeld om de API van GitKraken Glo te gebruiken om de tijd bij te houden die u besteedt aan taken op uw takenlijsten.
U moet bijvoorbeeld deze taken uitvoeren:
- Koffie drinken
Je drukt op start als je begint, als je klaar bent, druk je op Gereed, en voilà, de tijd die je besteedt, wordt becommentarieerd.
Stap 1: Bouwen
Om te bouwen kun je van alles bedenken. Een kleine stopwatch zou geweldig zijn, maar ik heb niets kleins rondslingeren.
Dus karton en arcade-drukknoppen waren de juiste keuze!
Het bord dat ik heb gebruikt is een ESP8266 WeMos D1 Mini. Dit is goedkoper dan een Arduino, en heeft wifi aan boord!
Het scherm is een Nokia 5110 LCD.
N
Onderdelenlijst op AliExpress:
- Nokia 5110
- 2 arcade-knoppen
- ESP8266
- Doorverbindingsdraden
- Kartonnen doos
Maar je kunt het in principe overal of op andere websites zoals Amazon of eBay vinden.
Totale factuur: 5€86
Pinnen aansluitingen:
ESP8266 WeMos D1 Mini (Nokia 5110 LCD)
- D2 (GPIO4) ↔ 0 RST
- D1 (GPIO5) ↔ 1 CE
- D6 (GPIO12) ↔ 2 DC
- D7 (GPIO13) ↔ 3 DIN
- D5 (GPIO14) ↔ 4 CLK
- 3V3 ↔ 5 VCC
- D0 (GPIO16) ↔ 6 BL
- G (GND) ↔ 7 GND
ESP8266 WeMos D1 Mini (Arcade-knoppen)
D3 (GPI18) ↔ Linkerknop
D4 (GPI17) ↔ Rechter knop
De andere pin van de knop is verbonden met aarde (GND).
Stap 2: Coderen
Geef me gewoon de code
De volledige broncode vind je hier:
github.com/antoinech/glo-stopwatch
Om het voor u te laten werken, moet u deze variabelen wijzigen:
//Plaats uw WiFi-inloggegevens hierconst char* ssid = "--uw--ssid--"; const char* wachtwoord = "--uw--wachtwoord--"; //Plaats uw persoonlijke toegangstoken (https://support.gitkraken.com/developers/pats/) const char *bearer = "Bearer XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX";
Je hebt ook 2 Adafruit-bibliotheken nodig:
github.com/adafruit/Adafruit-GFX-Library
github.com/adafruit/Adafruit-PCD8544-Nokia…
En deze geweldige Arduino Json:
arduinojson.org/
uitleg
In de broncode vind je:
- hoe verbinding te maken met een
- hoe een POST- of GET-verzoek te doen?
- hoe een JSON-antwoord te serialiseren om objecten en arrays te krijgen
- tekst en afbeeldingen weergeven op een Nokia 5110 LCD
Als u meer wilt weten over deze API:
support.gitkraken.com/developers/overview/
Dit verzoek kan op afstand werken met elke API die POST- en GET-verzoeken gebruikt:)
Stap 3: Maak verbinding met een
Deze pseudo-code legt u uit hoe u verbinding kunt maken met een HTTPS-website. De eerste stappen zijn hetzelfde als bij a
WiFiClient-client
maar met een verificatiestap. U moet naar het API-eindpunt gaan dat u wilt verifiëren en de SHA1-vingerafdruk van het certificaat controleren. Kopieer en plak het als een tekenreeks in uw code en bel client.verify(fingerprint, hosturl).
WiFiClientSecure-client;
// Maak verbinding met WiFi WiFi.mode (WIFI_STA); WiFi.begin(ssid, wachtwoord); while (WiFi.status() != WL_CONNECTED) {vertraging (500); Serieel.print("."); } if (!client.connect(host, httpsPort)) { Serial.println("verbinding mislukt"); opbrengst; } if (client.verify(vingerafdruk, host)) { Serial.println("certificaat komt overeen"); } else { Serial.println("certificaat komt niet overeen"); }
Stap 4: Maak POST / GET-verzoeken
NA
Dit is de syntaxis om een POST-verzoek in te dienen:
String PostData = "{"; PostData +="\"text\":\"mijn bericht\""; PostData += "}"; Serial.print(PostData); client.print(String("POST") + url + " HTTP/1.1\r\n" + "Host: " + host + "\r\n" + "Autorisatie: " + drager + "\r\n" + "User-Agent: BuildFailureDetectorESP8266\r\n" + "cache-control: no-cache\r\n" + "Content-Type: application/json \r\n" + "Content-Length: " + PostData. lengte() + "\r\n" + "\r\n" + PostData + "\n"); Serial.println("verzoek verzonden");
de PostData zijn de gegevens die u als JSON verzendt, in dit geval:
{
"tekst": "mijn bericht" }
De url-variabele is de url van het eindpunt, host, de url van de website, drager is het API-toegangstoken.
KRIJGEN
Dit is de pseudo-code voor een GET-verzoek:
client.print(String("GET") + url + " HTTP/1.1\r\n" + "Host: " + host + "\r\n" + "Autorisatie: " + drager + "\r\n" + "User-Agent: BuildFailureDetectorESP8266\r\n" + "Verbinding: keep-alive\r\n\r\n"); Serial.println("verzoek verzonden"); while (client.connected()) { String line = client.readStringUntil('\n'); if (regel == "\r") { Serial.println("headers ontvangen"); pauze; } } String line = client.readStringUntil('\n');
Het resultaat van deze opdracht wordt opgeslagen in de regelvariabele.
Stap 5: JSON & NOKIA LCD
Om een soortgelijk project te realiseren, moet je afbeeldingen, teksten en symbolen weergeven op het LCD-scherm van de Nokia 5110. Je kunt deze diepgaande tutorial bekijken van lastminute-engineers.
Om JSON in Arduino C++ te gebruiken, gebruik je de ArduinoJson-website die je er alles over zal vertellen!
Aarzel niet om vragen te stellen als je die hebt, of post wat je hebt gemaakt met deze broncode / tutorial.