• Home
  • Archive
  • Tools
  • Contact Us

The Customize Windows

Technology Journal

  • Cloud Computing
  • Computer
  • Digital Photography
  • Windows 7
  • Archive
  • Cloud Computing
  • Virtualization
  • Computer and Internet
  • Digital Photography
  • Android
  • Sysadmin
  • Electronics
  • Big Data
  • Virtualization
  • Downloads
  • Web Development
  • Apple
  • Android
Advertisement
You are here:Home » ESP32 Arduino : Create a Webpage to Control a Relay Module

By Abhishek Ghosh March 6, 2019 5:03 pm Updated on March 6, 2019

ESP32 Arduino : Create a Webpage to Control a Relay Module

Advertisement

Here is How to Create a Webpage to Control a Relay Module Using ESP32 Arduino. For this project, one needs to setup ESP32 with Arduino in the manner we described earlier. It is a Wi-Fi based project (not IoT). This is a basic example which provides the base of advanced projects. Previously we published few basic projects with relay. Use separate DC voltage supply for the relay (avoid AC for testing without guidance according to your age and experience). Using relay with Arduino is easy, it is just like using LED directly :

Vim
1
2
3
4
5
6
7
8
9
10
11
12
int relay_pin = 4;
void setup() {
  pinMode(relay_pin, OUTPUT);
}
void loop() {
  digitalWrite(relay_pin, HIGH);
  delay(4000);
  digitalWrite(relay_pin, LOW);
  delay(4000);
}

ESP32 Arduino Create a Webpage to Control a Relay Module

Now, for the Wi-Fi part, we need to modify the code in this way :

Vim
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
#include <WiFi.h>
 
const char* wifi_name = "your_ssid"; // Your Wifi network name here
const char* wifi_pass = "your_pass";    // Your Wifi network password here
 
WiFiServer server(80);    // Server will be at port 80
 
int relay_pin = 4;
 
void setup()
{
  Serial.begin (115200);
  pinMode (relay_pin, OUTPUT);
  Serial.print ("Connecting to ");
  WiFi.begin (wifi_name, wifi_pass);     // Connecting to the wifi network
  while (WiFi.status() != WL_CONNECTED) // Waiting for the response of wifi network
{
    delay (500);
    Serial.print (".");
}
  Serial.println("");
  Serial.println("Connection Successful");
  Serial.print("IP address: ");
  Serial.println(WiFi.localIP());           // Getting the IP address
  Serial.println("Type the above IP address into browser search bar");
  server.begin();                           // Starting the server
}
...

Now, we need to create a webpage with this kind of HTML code :

Advertisement

---

Vim
1
2
3
4
5
6
7
8
9
<html>
<title>ESP32</title>
<body>
<h1>ESP32 Standalone Relay Control </h1>
<p>Relay Control</p>
<a href="/?relayon"><button>ON</button></a>
<a href="/?relayoff"><button>OFF</button></a>
</body>
</html>

We can write the above code for Arduino in this way :

Vim
1
2
3
4
5
6
7
8
9
10
11
          client.println("HTTP/1.1 200 OK");
          client.println("Content-Type: text/html");
 
          client.println();    
          client.print("<HTML><title>ESP32</title>");
          client.print("<body><h1>ESP32 Standalone Relay Control </h1>");
          client.print("<p>Relay Control</p>");
          client.print("<a href=\"/?relayon\"\"><button>ON</button></a>");
          client.print("<a href=\"/?relayoff\"\"><button>OFF</button></a>");
          client.print("</body></HTML>");
          break;        // break out of the while loop:

The complete code will go like this :

Vim
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
#include <WiFi.h>
 
const char* wifi_name = "your_ssid"; // Your Wifi network name here
const char* wifi_pass = "your_pass";    // Your Wifi network password here
 
WiFiServer server(80);    // Server will be at port 80
 
int relay_pin = 4;
 
void setup()
{
  Serial.begin (115200);
  pinMode (relay_pin, OUTPUT);
  Serial.print ("Connecting to ");
  WiFi.begin (wifi_name, wifi_pass);     // Connecting to the wifi network
  while (WiFi.status() != WL_CONNECTED) // Waiting for the response of wifi network
{
    delay (500);
    Serial.print (".");
}
  Serial.println("");
  Serial.println("Connection Successful");
  Serial.print("IP address: ");
  Serial.println(WiFi.localIP());           // Getting the IP address
  Serial.println("Type the above IP address into browser search bar");
  server.begin();                           // Starting the server
}
 
 
void loop()
{
  WiFiClient client = server.available();     //Checking if any client request is available or not
  if (client)
{
    boolean currentLineIsBlank = true;
    String buffer = "";  
    while (client.connected())
{
      if (client.available())                    // if there is some client data available
{
        char c = client.read();
        buffer+=c;                              // read a byte
        if (c == '\n' && currentLineIsBlank)    // check for newline character,
{
          client.println("HTTP/1.1 200 OK");
          client.println("Content-Type: text/html");
 
          client.println();    
          client.print("<HTML><title>ESP32</title>");
          client.print("<body><h1>ESP32 Standalone Relay Control </h1>");
          client.print("<p>Relay Control</p>");
          client.print("<a href=\"/?relayon\"\"><button>ON</button></a>");
          client.print("<a href=\"/?relayoff\"\"><button>OFF</button></a>");
          client.print("</body></HTML>");
          break;        // break out of the while loop:
}
        if (c == '\n') {
          currentLineIsBlank = true;
          buffer="";      
}
else
          if (c == '\r') {    
          if(buffer.indexOf("GET /?relayon")>=0)
            digitalWrite(relay_pin, LOW);
          if(buffer.indexOf("GET /?relayoff")>=0)
            digitalWrite(relay_pin, HIGH);  
}
else {
          currentLineIsBlank = false;
}
}
}
    client.stop();
}
}

Notice the logic how we are receiving the command.

Tagged With create a website esp32 , Antennenanalyser mit Arduino ESP32 , control relays using the esp32 , esp32 relay control openhab , control arduino with esp32 , client println(<html><title> , control esp32 with arduino software , client print esp32 , using ESP32 with relay , arduino control via webpage
Facebook Twitter Pinterest

Abhishek Ghosh

About Abhishek Ghosh

Abhishek Ghosh is a Businessman, Surgeon, Author and Blogger. You can keep touch with him on Twitter - @AbhishekCTRL.

Here’s what we’ve got for you which might like :

Articles Related to ESP32 Arduino : Create a Webpage to Control a Relay Module

  • How to Control Multiple Relays With Single Arduino ESP32?

    Before How to Control Multiple Relays With Single Arduino ESP32 Testing, You Need to Learn How to Create Multiple MQTT Channels & Fetch Data.

  • WROOM ESP32 Example Codes For IBM Watson IoT Platform

    Here Are Few WROOM ESP32 Example Codes For IBM Watson IoT Platform So That Anyone Can Get Started With Both of Them Without Huge Experience.

  • Control Multiple AC Appliances With One ESP32 Arduino

    Here is how to use ESP32 and IBM Watson IoT to control multiple relays (i.e. multiple AC appliances) by pushbutton and over the internet.

  • Detect Smartwatch With ESP32 on IBM Watson IoT Widget

    In our previous guide, we have shown that we can trigger ESP32 (with Arduino IDE) to send message to IBM Watson IoT in Presence of a Particular Samsung Galaxy Smartwatch. That process involves BLE and WiFi. In our one series of articles on Samsung Smartwatch as Proximity Switch, we triggered a local event, such as […]

performing a search on this website can help you. Also, we have YouTube Videos.

Take The Conversation Further ...

We'd love to know your thoughts on this article.
Meet the Author over on Twitter to join the conversation right now!

If you want to Advertise on our Article or want a Sponsored Article, you are invited to Contact us.

Contact Us

Subscribe To Our Free Newsletter

Get new posts by email:

Please Confirm the Subscription When Approval Email Will Arrive in Your Email Inbox as Second Step.

Search this website…

 

Popular Articles

Our Homepage is best place to find popular articles!

Here Are Some Good to Read Articles :

  • Cloud Computing Service Models
  • What is Cloud Computing?
  • Cloud Computing and Social Networks in Mobile Space
  • ARM Processor Architecture
  • What Camera Mode to Choose
  • Indispensable MySQL queries for custom fields in WordPress
  • Windows 7 Speech Recognition Scripting Related Tutorials

Social Networks

  • Pinterest (24.3K Followers)
  • Twitter (5.8k Followers)
  • Facebook (5.7k Followers)
  • LinkedIn (3.7k Followers)
  • YouTube (1.3k Followers)
  • GitHub (Repository)
  • GitHub (Gists)
Looking to publish sponsored article on our website?

Contact us

Recent Posts

  • Hybrid Multi-Cloud Environments Are Becoming UbiquitousJuly 12, 2023
  • Data Protection on the InternetJuly 12, 2023
  • Basics of BJT TransistorJuly 11, 2023
  • What is Confidential Computing?July 11, 2023
  • How a MOSFET WorksJuly 10, 2023
PC users can consult Corrine Chorney for Security.

Want to know more about us?

Read Notability and Mentions & Our Setup.

Copyright © 2023 - The Customize Windows | dESIGNed by The Customize Windows

Copyright  · Privacy Policy  · Advertising Policy  · Terms of Service  · Refund Policy