Anda di halaman 1dari 7

ESP8266 NODEMCU ACCESS POINT (AP)

UNTUK WEB SERVER

1.1. Tujuan

Praktikan akan belajar cara mengatur ESP8266 NodeMCU sebagai Access Point (AP)
menggunakan Arduino IDE. Ini memungkinkan untuk terhubung langsung ke ESP8266
melalui Wi-Fi tanpa router nirkabel

1.2. Dasar Teori

Di sebagian besar proyek web server ESP8266 NodeMCU, menghubungkan ESP8266


ke router nirkabel. Pada konfigurasi ini, kita dapat mengakses ESP8266 melalui jaringan
lokal.
Dalam skenario ini, router bertindak sebagai titik akses dan ESP8266 ditetapkan
sebagai stasiun. Jadi, Anda harus terhubung ke router Anda (jaringan lokal) untuk mengontrol
ESP8266.

Dalam beberapa kasus, ini mungkin bukan konfigurasi terbaik (jika Anda tidak
memiliki router di dekatnya). Tetapi jika Anda mengatur ESP8266 sebagai titik akses
(hotspot), Anda dapat terhubung ke ESP8266 menggunakan perangkat apa pun dengan
kemampuan Wi-Fi tanpa perlu terhubung ke router Anda.
Dengan kata sederhana, saat Anda mengatur ESP8266 sebagai titik akses Anda
membuat jaringan Wi-Fi sendiri dan perangkat Wi-Fi terdekat (stasiun) dapat
menghubungkannya (seperti ponsel cerdas atau komputer Anda).
Dalam tutorial ini, akan menunjukkan kepada Anda cara mengatur ESP8266 sebagai
titik akses dalam proyek web server. Dengan cara ini, Anda tidak perlu terhubung ke router
untuk mengontrol ESP8266 Anda.
Karena ESP8266 tidak terhubung lebih jauh ke jaringan kabel (seperti router), ini
disebut soft-AP (Soft Access Point).
Artinya, jika mencoba memuat pustaka atau menggunakan firmware dari internet, ini
tidak akan berfungsi. Ini juga tidak berfungsi jika mencoba membuat permintaan HTTP ke
layanan di internet seperti menerbitkan pembacaan sensor ke cloud.

1.3. Bahan Yang Diperlukan

 NodeMCUESP8266
 DHT22 or DHT11 Temperature and Humidity Sensor
 4.7k Ohm Resistor
 Breadboard
 Jumper wires

1.4. Langkah Percobaan

Menginstal Perpustakaan DHT untuk ESP8266


Ikuti langkah-langkah selanjutnya untuk menginstal kedua pustaka tersebut:
1. Buka Arduino IDE Anda dan pergi ke Sketch > Include Library > Manage
Libraries . Manajer Perpustakaan harus terbuka.
2. Cari " DHT " pada kotak Pencarian dan instal pustaka DHT dari Adafruit.

3. Setelah menginstal pustaka DHT dari Adafruit, ketik " Adafruit Unified Sensor " di kotak
pencarian. Gulir ke bawah untuk menemukan perpustakaan dan menginstalnya.
4. Setelah menginstal pustaka, mulai ulang Arduino IDE Anda.

ESP8266 NodeMCU Access Point (AP)


Unggah sketsa yang disediakan di bawah ini untuk mengatur ESP8266 sebagai titik akses
copies or substantial portions of the Software.
*********/

// Import required libraries


#include <Arduino.h>
#include <ESP8266WiFi.h>
#include <Hash.h>
#include <ESPAsyncTCP.h>
#include <ESPAsyncWebServer.h>
#include <Adafruit_Sensor.h>
#include <DHT.h>

const char* ssid = "ESP8266-Access-Point";


const char* password = "123456789";

#define DHTPIN 5 // Digital pin connected to the DHT sensor

// Uncomment the type of sensor in use:


//#define DHTTYPE DHT11 // DHT 11
#define DHTTYPE DHT22 // DHT 22 (AM2302)
//#define DHTTYPE DHT21 // DHT 21 (AM2301)

DHT dht(DHTPIN, DHTTYPE);

// current temperature & humidity, updated in loop()


float t = 0.0;
float h = 0.0;

// Create AsyncWebServer object on port 80


AsyncWebServer server(80);

// Generally, you should use "unsigned long" for variables that hold time
// The value will quickly become too large for an int to store
unsigned long previousMillis = 0; // will store last time DHT was updated

// Updates DHT readings every 10 seconds


const long interval = 10000;

const char index_html[] PROGMEM = R"rawliteral(


<!DOCTYPE HTML><html>
<head>
<meta name="viewport" content="width=device-width, initial-scale=1">
<style>
html {
font-family: Arial;
display: inline-block;
margin: 0px auto;
text-align: center;
}
h2 { font-size: 3.0rem; }
p { font-size: 3.0rem; }
.units { font-size: 1.2rem; }
.dht-labels{
font-size: 1.5rem;
vertical-align:middle;
padding-bottom: 15px;
}
</style>
</head>
<body>
<h2>ESP8266 DHT Server</h2>
<p>
<span class="dht-labels">Temperature</span>
<span id="temperature">%TEMPERATURE%</span>
<sup class="units">&deg;C</sup>
</p>
<p>
<span class="dht-labels">Humidity</span>
<span id="humidity">%HUMIDITY%</span>
<sup class="units">%</sup>
</p>
</body>
<script>
setInterval(function ( ) {
var xhttp = new XMLHttpRequest();
xhttp.onreadystatechange = function() {
if (this.readyState == 4 && this.status == 200) {
document.getElementById("temperature").innerHTML = this.responseText;
}
};
xhttp.open("GET", "/temperature", true);
xhttp.send();
}, 10000 ) ;

setInterval(function ( ) {
var xhttp = new XMLHttpRequest();
xhttp.onreadystatechange = function() {
if (this.readyState == 4 && this.status == 200) {
document.getElementById("humidity").innerHTML = this.responseText;
}
};
xhttp.open("GET", "/humidity", true);
xhttp.send();
}, 10000 ) ;
</script>
</html>)rawliteral";

// Replaces placeholder with DHT values


String processor(const String& var){
//Serial.println(var);
if(var == "TEMPERATURE"){
return String(t);
}
else if(var == "HUMIDITY"){
return String(h);
}
return String();
}

void setup(){
// Serial port for debugging purposes
Serial.begin(115200);
dht.begin();

Serial.print("Setting AP (Access Point)…");


// Remove the password parameter, if you want the AP (Access Point) to be open
WiFi.softAP(ssid, password);

IPAddress IP = WiFi.softAPIP();
Serial.print("AP IP address: ");
Serial.println(IP);

// Print ESP8266 Local IP Address


Serial.println(WiFi.localIP());

// Route for root / web page


server.on("/", HTTP_GET, [](AsyncWebServerRequest *request){
request->send_P(200, "text/html", index_html, processor);
});
server.on("/temperature", HTTP_GET, [](AsyncWebServerRequest *request){
request->send_P(200, "text/plain", String(t).c_str());
});
server.on("/humidity", HTTP_GET, [](AsyncWebServerRequest *request){
request->send_P(200, "text/plain", String(h).c_str());
});

// Start server
server.begin();
}

void loop(){
unsigned long currentMillis = millis();
if (currentMillis - previousMillis >= interval) {
// save the last time you updated the DHT values
previousMillis = currentMillis;
// Read temperature as Celsius (the default)
float newT = dht.readTemperature();
// Read temperature as Fahrenheit (isFahrenheit = true)
//float newT = dht.readTemperature(true);
// if temperature read failed, don't change t value
if (isnan(newT)) {
Serial.println("Failed to read from DHT sensor!");
}
else {
t = newT;
Serial.println(t);
}
// Read Humidity
float newH = dht.readHumidity();
// if humidity read failed, don't change h value
if (isnan(newH)) {
Serial.println("Failed to read from DHT sensor!");
}
else {
h = newH;
Serial.println(h);
}
}
}

Catatan: secara default, alamat IP titik akses adalah 192.168.4.1


Diagram skematik

Menghubungkan ke Titik Akses ESP8266


Setelah ESP8266 menjalankan sketsa, di ponsel cerdas Anda buka pengaturan Wi-Fi Anda dan ketuk
jaringan ESP8266-Access-Point :
Masukkan kata sandi yang Anda tentukan sebelumnya.

Buka browser web Anda dan ketik alamat IP http://192.168.4.1 . Halaman server web harus memuat:

1.5. Analisa Data

1.6. Kesimpulan

Anda mungkin juga menyukai