DS18B20 with NodeMCU Local WebServer

DS18B20 with NodeMCU Local WebServer

There are many temperature sensors available in the market. Yo might have come across many and used in your projects as well. In this article we will see how to connect a DS18B20 with NodeMCU Local WebServer. This project will be independent from internet.

We will also create a web server in NodeMCU, where we will be getting the output. This tutorial is simple and easy to build. Let’s see what are the components needed for building this project.

Parts List

How it Works?

Here we are connecting NodeMCU with DS18B20. After uploading code, we can get the IP address visible in Arduino IDE serial monitor. This is the IP address of the web server. We can put that IP in our mobile or computer web browser and it will start displaying the temperature readings. It will automatically update with the change in temperature reading.

DS18B20 with NodeMCU Local WebServer

Sensors and Modules Functions

DS18B20 Temperature Sensor

This is a one wire temperature sensor, which can be used to build many useful projects. It has 3 leads like a transistor. It is also easy to interface with different development boards. This measures the temperature and sends it to NodeMCU web server.

Some Features of DS18B20

  • Temperatures Range from -55°C to +125°C (-67°F to +257°F)
  • Accuracy ±0.5°C  from -10°C to +85°C
  • 1-Wire Interface which requires Only One Port for Communication
  • Programmable Resolution from 9 Bits to 12 Bits
  • No External Components Required
  • Parasitic Power Mode Requires Only 2 Pins for Operation (DQ and GND)
  • Each Device Has a Unique 64-Bit Serial Code Stored in On-Board ROM
  • Available in 8-Pin SO (150 mils), 8-Pin µSOP, and 3-Pin TO-92 Packages

NodeMCU Wifi Module

Node MCU is very well know ESP8266 chip based development board. This is very popular among all electronics and IoT lovers. This will be working a the brain of this project. Below diagram shows the nodemcu pinout. You can also connect esp-01 to ds18b20.

Also Read:

DS18B20 with NodeMCU Local WebServer

Circuit Diagram

You can connect the components as per the given diagram or you can mount it on a PCB as well.DS18B20 with NodeMCU Local WebServer

Code & Libraries

The code is big but it is simple to understand. For illustration of the code please refer the video tutorial below. You can download the libraries from given link

You have to download One wire  and Dallas temperature library. Go to Sketch Include Library > Manage Libraries

Search for Onewire and install it.

Install Dallas Temperature Library as well.

After installing all library, copy paste the below code in Arduino IDE. Now save and compile. Once the compilation is done, upload the code.

#include <ESP8266WiFi.h>
#include <Hash.h>
#include <ESPAsyncTCP.h>
#include <ESPAsyncWebServer.h>
#include <OneWire.h>
#include <DallasTemperature.h>

// Data wire is connected to GPIO 4
#define ONE_WIRE_BUS 4

// Setup a oneWire instance to communicate with any OneWire devices
OneWire oneWire(ONE_WIRE_BUS);

// Pass our oneWire reference to Dallas Temperature sensor
DallasTemperature sensors(&oneWire);

// Replace with your network credentials
const char* ssid = "Your network SSID";
const char* password = "Your Network Password";

// Create AsyncWebServer object on port 80
AsyncWebServer server(80);

String sensor_dataC() {
// Call sensors.requestTemperatures() to issue a global temperature and Requests to all devices on the bus
sensors.requestTemperatures();
float tempC = sensors.getTempCByIndex(0);

if (tempC == -127.00) {
Serial.println("Unable to read from sensor");
return "--";
} else {
Serial.print("Temp. in Celsius: ");
Serial.println(tempC);
}
return String(tempC);
}
String sensor_dataF() {
// Call sensors.requestTemperatures() to issue a global temperature and Requests to all devices on the bus
sensors.requestTemperatures();
float tempF = sensors.getTempFByIndex(0);

if (int(tempF) == -196) {
Serial.println("Unable to read from sensor");
return "--";
} else {
Serial.print("Temp. in Fahrenheit: ");
Serial.println(tempF);
}
return String(tempF);
}

const char index_html[] PROGMEM = R"rawliteral(
<!DOCTYPE HTML><html>
<head>
<meta name="viewport" content="width=device-width, initial-scale=1">
<link rel="stylesheet" href="https://use.fontawesome.com/releases/v5.7.2/css/all.css"
integrity="sha384-fnmOCqbTlWIlj8LyTjo7mOUStjsKC4pOpQbqyi7RrhN7udi9RwhKkMHpvLbHG9Sr" crossorigin="anonymous">
<img src="" data-wp-preserve="%3Cstyle%3E%0Ahtml%20%7B%0Afont-family%3A%20Arial%3B%0Adisplay%3A%20inline-block%3B%0Amargin%3A%200px%20auto%3B%0Atext-align%3A%20center%3B%0A%7D%0Ah2%20%7B%20font-size%3A%203.0rem%3B%20%7D%0Ap%20%7B%20font-size%3A%203.0rem%3B%20%7D%0A.units%20%7B%20font-size%3A%201.8rem%3B%20%7D%0A.ds-labels%7B%0Afont-size%3A%201.8rem%3B%0Avertical-align%3Amiddle%3B%0Apadding-bottom%3A%2015px%3B%0A%7D%0A%3C%2Fstyle%3E" data-mce-resize="false" data-mce-placeholder="1" class="mce-object" width="20" height="20" alt="&lt;style&gt;" title="&lt;style&gt;" />
</head>
<body>
<h2>NodeMCU & DS18B20 Based Temperature Monitor</h2>
<p>
<i class="fa fa-thermometer-three-quarters" aria-hidden="true" style="color:#471ccf;"></i>
<span class="ds-labels">Temperature in Celsius</span>
<span id="tempc">%TEMPC%</span>
<sup class="units">&deg;C</sup>
</p>
<p>
<i class="fa fa-thermometer-three-quarters" aria-hidden="true" style="color:#f01313;"></i>
<span class="ds-labels">Temperature in Fahrenheit</span>
<span id="tempf">%TEMPF%</span>
<sup class="units">&deg;F</sup>
</p>
</body>
<img src="" data-wp-preserve="%3Cscript%3E%0AsetInterval(function%20(%20)%20%7B%0Avar%20xhttp%20%3D%20new%20XMLHttpRequest()%3B%0Axhttp.onreadystatechange%20%3D%20function()%20%7B%0Aif%20(this.readyState%20%3D%3D%204%20%26%26%20this.status%20%3D%3D%20200)%20%7B%0Adocument.getElementById(%22tempc%22).innerHTML%20%3D%20this.responseText%3B%0A%7D%0A%7D%3B%0Axhttp.open(%22GET%22%2C%20%22%2Ftempc%22%2C%20true)%3B%0Axhttp.send()%3B%0A%7D%2C%2010000)%20%3B%0AsetInterval(function%20(%20)%20%7B%0Avar%20xhttp%20%3D%20new%20XMLHttpRequest()%3B%0Axhttp.onreadystatechange%20%3D%20function()%20%7B%0Aif%20(this.readyState%20%3D%3D%204%20%26%26%20this.status%20%3D%3D%20200)%20%7B%0Adocument.getElementById(%22tempf%22).innerHTML%20%3D%20this.responseText%3B%0A%7D%0A%7D%3B%0Axhttp.open(%22GET%22%2C%20%22%2Ftempf%22%2C%20true)%3B%0Axhttp.send()%3B%0A%7D%2C%2010000)%20%3B%0A%3C%2Fscript%3E" data-mce-resize="false" data-mce-placeholder="1" class="mce-object" width="20" height="20" alt="&lt;script&gt;" title="&lt;script&gt;" />
</html>)rawliteral";

// Replaces placeholder with DHT values
String update_data(const String& var)
{
//Serial.println(var);
if (var == "TEMPC") {
return sensor_dataC();
}
else if (var == "TEMPF") {
return sensor_dataF();
}
return String();
}

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

// Start up the DS18B20 library
sensors.begin();

// Connect to Wi-Fi
WiFi.begin(ssid, password);
Serial.println("Connecting to WiFi");
while (WiFi.status() != WL_CONNECTED) {
delay(500);
Serial.print(".");
}
Serial.println();

// Print ESP 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, update_data);
});
server.on("/tempc", HTTP_GET, [](AsyncWebServerRequest * request) {
request->send_P(200, "text/plain", sensor_dataC().c_str());
});
server.on("/tempf", HTTP_GET, [](AsyncWebServerRequest * request) {
request->send_P(200, "text/plain", sensor_dataF().c_str());
});
// Start server
server.begin();
}

void loop() {

}

Construction & Code Uploading

The initial construction is simple and can be mounted on a breadboard as per the circuit diagram. For uploading the code please check the link below

Easy NodeMCU Programming with Simple Steps

DS18B20 with NodeMCU Local WebServer

Testing

After uploading the code, open serial monitor in Arduino IDE. Then reset NodeMCU and you will be able to see the web server IP address.

Enter the same IP in your web browser. Your mobile or computer should be connected to same network.

DS18B20 with NodeMCU Local WebServer

Even if you don’t have internet this web server will work and share the data.

DS18B20 with NodeMCU Local WebServer

Video Tutorial

Conclusion

DS18B20 is a good temperature sensor to start with. It has one wire interface and doesn’t need any additional components to interface. DS18B20 can be easily interfaced with arduino as well. You can connect to esp8266 onewire temperature sensor and build a esp8266 thermometer. Here we have built DS18B20 with NodeMCU Local WebServer.

Leave a Comment