Creating a Wireless Network with ESP32 using Arduino: AP Mode Walkthrough

Learn how to create your own WiFi network using the ESP32 AP Mode. Connect and send information with WiFi without the Internet! This can be used to host web servers that devices can access as long as the network is running, and can later be used to send information between Arduino-based controllers without access to the global Internet!

Before reading the remainder, be sure to subscribe and support the channel if you have not!

Subscribe:

Youtube

Support:

https://www.buymeacoffee.com/mmshilleh

Step 1-) Upload Code to ESP32 in Arduino IDE

In today’s example we will write a simple script that simply generates an HTTP response when we connect to the ESP32 and type in the IP address in our browser. The code below handles incoming HTTP requests and returns a Hello World response.

#include <WiFi.h>

// Replace with your network credentials
const char* ssid     = "ESP32-Access-Point";
const char* password = "123456789";

// Set web server port number to 80
WiFiServer server(80);

void setup() {
  Serial.begin(115200);
  
  // Connect to Wi-Fi network with SSID and password
  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);
  
  server.begin();
}

void loop(){
  WiFiClient client = server.available();   // Listen for incoming clients

  if (client) {                             // If a new client connects,
    Serial.println("New Client.");          // print a message out in the serial port
    String currentLine = "";                // make a String to hold incoming data from the client
    while (client.connected()) {            // loop while the client's connected
      if (client.available()) {             // if there's bytes to read from the client,
        char c = client.read();             // read a byte, then
        Serial.write(c);                    // print it out the serial monitor
        currentLine += c;
        if (c == '\n') {                    // if the byte is a newline character
          // if the current line is blank, you got two newline characters in a row.
          // that's the end of the client HTTP request, so send a response:
          if (currentLine.length() == 2) {
            // HTTP headers always start with a response code (e.g. HTTP/1.1 200 OK)
            // and a content-type so the client knows what's coming, then a blank line:
            client.println("HTTP/1.1 200 OK");
            client.println("Content-type:text/html");
            client.println("Connection: close");
            client.println();
            
            // Send your "Hello World" HTML response
            client.println("<html><head><meta name=\"viewport\" content=\"width=device-width, initial-scale=1\"></head>");
            client.println("<body><h1>Hello World</h1></body></html>");
            
            // The HTTP response ends with another blank line
            client.println();
            // Break out of the while loop
            break;
          } else { // if you got a newline, then clear currentLine
            currentLine = "";
          }
        } else if (c != '\r') {  // if you got anything else but a carriage return character,
          currentLine += c;      // add it to the end of the currentLine
        }
      }
    }
    // Close the connection
    client.stop();
    Serial.println("Client disconnected.");
    Serial.println("");
  }
}
  • The code begins by including the necessary header file, WiFi.h, for working with Wi-Fi connections on the ESP32.
  • It sets up variables for the Wi-Fi network credentials, including the SSID (network name) and password.
  • The code defines a web server that listens on port 80 using the WiFiServer class.
  • In the setup() function:
    • Serial communication is initialized for debugging purposes at a baud rate of 115200.
    • The ESP32 is configured to create an Access Point (AP) with the specified SSID and password using WiFi.softAP(ssid, password).
    • The IP address of the Access Point is obtained and printed to the serial monitor.
    • The web server is started with server.begin().
  • In the loop() function:
    • It checks for incoming client connections using server.available().
    • If a client connects, it prints a message to the serial monitor.
    • It initializes a String variable currentLine to store incoming data from the client.
  • Inside a while loop that runs as long as the client is connected:

    • It checks if there is data available to read from the client using client.available().
    • If data is available, it reads a byte and prints it to the serial monitor.
    • It appends the received byte to the currentLine string.
    • If the received byte is a newline character (\n), it checks the length of currentLine.

      • If the length is 2, it indicates two consecutive newline characters, meaning the end of the client's HTTP request.
      • In response, it sends HTTP headers indicating a successful response (HTTP/1.1 200 OK), sets the content type to HTML, and includes a basic "Hello World" HTML page.
      • It then sends an additional blank line to signal the end of the HTTP response.
      • Finally, it breaks out of the while loop.
      • Otherwise, if it received a single newline character, it clears the currentLine string for the next part of the HTTP request.
  • After handling the client's request, it closes the client connection using client.stop() and prints a message indicating that the client has disconnected.
  • The code repeats this process in the loop() function, continuously listening for and handling incoming client connections.

            This code essentially turns the ESP32 into a simple web server that responds with a "Hello World" HTML page when accessed through a web browser or other HTTP client. It is set up to handle HTTP requests one at a time, and it provides basic debugging information through the serial monitor.

            Step 2-) Connect to Device Network

            Once the code is uploaded, you will see the WiFi network available to connect to as shown here.

            Type in your password as needed.

            Now enter the IP Address of your device into your internet browser using the http protocol. You can get the IP address of the ESP32 from the Serial Monitor in Arduino IDE. I used the following: http://192.168.4.1/

            If you did everything right you should see the Hello World message!

            Conclusion

            This should give the basics to start using AP Mode with the ESP32 for more advanced use cases! If you have any questions let me know in the comment section on Youtube! Do not forget to subscribe for more useful content.

            Create a free account to access full content.

            All access to code and resources on ShillehTek.

            Signup Now

            Already a member? Sign In

            Explore More on Our Blog

            How to Create a Time-Lapse Video with a Raspberry Pi Camera

            How to Create a Time-Lapse Video with a Raspberry Pi Camera

            Learn how to make a timelapse with your Raspberry Pi in Python.

            How to Integrate the MPU6050 with the STM32 Blue Pill

            How to Integrate the MPU6050 with the STM32 Blue Pill

            Learn how to measure acceleration with the STM32 and the MPU6050 in the Arduino IDE.

            Getting Started with STM32 Blue Pill in Arduino IDE Using a USB to TTL Converter — Write Your First Program

            Getting Started with STM32 Blue Pill in Arduino IDE Using a USB to TTL Converter — Write Your First Program

            This comprehensive tutorial will guide you through the process of setting up and programming the STM32 Blue Pill...

            Automate Task Scheduling in AWS with Lambda, Step Functions, and CloudWatch

            Automate Task Scheduling in AWS with Lambda, Step Functions, and CloudWatch

            In this tutorial, I'll show you how to automatically schedule tasks in AWS at regular intervals using AWS...

            Implementing Google reCAPTCHA in a Simple React and Node.js App

            Implementing Google reCAPTCHA in a Simple React and Node.js App

            Learn how to protect your React applications from bots and spam with Google reCAPTCHA integration! This step-by-step tutorial...

            AWS Lambda Tutorial: Using Selenium with Chromedriver in Python

            AWS Lambda Tutorial: Using Selenium with Chromedriver in Python

            In this tutorial, I will guide you through the process of running Selenium with ChromeDriver inside an AWS...

            How to Connect MLX90614 Infrared Thermometer to Raspberry Pi Pico W: MicroPython Tutorial!

            How to Connect MLX90614 Infrared Thermometer to Raspberry Pi Pico W: MicroPython Tutorial!

            Learn how to use the MLX90614 with the Raspberry Pi Pico W and get infrared values in MicroPython.

            Raspberry Pi Pico/Pico W Free Simulator

            Raspberry Pi Pico/Pico W Free Simulator

            Discover how to simulate Raspberry Pi Pico projects using Wokwi, a free online simulator for Arduino and MicroPython....

            Interfacing the MPU6050 with Raspberry Pi Pico W in C++

            Interfacing the MPU6050 with Raspberry Pi Pico W in C++

            Interface with the MPU6050 using the Raspberry Pi Pico W in C++.

            How to Write your First C++ Program on the Raspberry Pi Pico W

            How to Write your First C++ Program on the Raspberry Pi Pico W

            Write your first C++ Program on the Pico W in a few simple steps.

            Back to blog

            Leave a comment

            Please note, comments need to be approved before they are published.