Implementing OTA Updates through a Web Server in the SparkFun ESP32 Thing

Advanced ESP32 Over The Air Programming in ESP32
9 minutes
Share the link to this page
Copied
  Completed
You need to have access to the item to view this lesson.
One-time Fee
$69.99
List Price:  $99.99
You save:  $30
€67.10
List Price:  €95.86
You save:  €28.76
£55.67
List Price:  £79.54
You save:  £23.86
CA$100.49
List Price:  CA$143.56
You save:  CA$43.07
A$111.96
List Price:  A$159.95
You save:  A$47.99
S$94.87
List Price:  S$135.54
You save:  S$40.66
HK$544.16
List Price:  HK$777.41
You save:  HK$233.24
CHF 62.56
List Price:  CHF 89.37
You save:  CHF 26.81
NOK kr792.29
List Price:  NOK kr1,131.89
You save:  NOK kr339.60
DKK kr500.54
List Price:  DKK kr715.08
You save:  DKK kr214.54
NZ$123.74
List Price:  NZ$176.78
You save:  NZ$53.04
د.إ257.07
List Price:  د.إ367.26
You save:  د.إ110.19
৳8,330.24
List Price:  ৳11,900.85
You save:  ৳3,570.61
₹5,945.56
List Price:  ₹8,494.03
You save:  ₹2,548.46
RM315.51
List Price:  RM450.75
You save:  RM135.24
₦108,149.19
List Price:  ₦154,505.46
You save:  ₦46,356.27
₨19,403.53
List Price:  ₨27,720.51
You save:  ₨8,316.98
฿2,393.75
List Price:  ฿3,419.79
You save:  ฿1,026.04
₺2,454.67
List Price:  ₺3,506.82
You save:  ₺1,052.15
B$425.95
List Price:  B$608.53
You save:  B$182.58
R1,282.09
List Price:  R1,831.63
You save:  R549.54
Лв131.15
List Price:  Лв187.37
You save:  Лв56.21
₩101,234.93
List Price:  ₩144,627.53
You save:  ₩43,392.60
₪254.67
List Price:  ₪363.83
You save:  ₪109.16
₱4,117.86
List Price:  ₱5,882.91
You save:  ₱1,765.05
¥10,949.58
List Price:  ¥15,642.93
You save:  ¥4,693.35
MX$1,405.49
List Price:  MX$2,007.92
You save:  MX$602.43
QR254.12
List Price:  QR363.05
You save:  QR108.92
P963.49
List Price:  P1,376.48
You save:  P412.98
KSh8,999.72
List Price:  KSh12,857.29
You save:  KSh3,857.57
E£3,561.31
List Price:  E£5,087.81
You save:  E£1,526.49
ብር8,689.79
List Price:  ብር12,414.52
You save:  ብር3,724.72
Kz64,250.82
List Price:  Kz91,790.82
You save:  Kz27,540
CLP$69,143.42
List Price:  CLP$98,780.55
You save:  CLP$29,637.13
CN¥510.67
List Price:  CN¥729.56
You save:  CN¥218.89
RD$4,244.94
List Price:  RD$6,064.47
You save:  RD$1,819.52
DA9,440.04
List Price:  DA13,486.35
You save:  DA4,046.31
FJ$162.13
List Price:  FJ$231.62
You save:  FJ$69.49
Q537.12
List Price:  Q767.35
You save:  Q230.22
GY$14,584.29
List Price:  GY$20,835.60
You save:  GY$6,251.30
ISK kr9,693.35
List Price:  ISK kr13,848.23
You save:  ISK kr4,154.88
DH701.59
List Price:  DH1,002.31
You save:  DH300.72
L1,285.64
List Price:  L1,836.70
You save:  L551.06
ден4,127.89
List Price:  ден5,897.23
You save:  ден1,769.34
MOP$558.06
List Price:  MOP$797.27
You save:  MOP$239.20
N$1,283.39
List Price:  N$1,833.49
You save:  N$550.10
C$2,565.21
List Price:  C$3,664.75
You save:  C$1,099.53
रु9,482.30
List Price:  रु13,546.73
You save:  रु4,064.42
S/259.58
List Price:  S/370.84
You save:  S/111.26
K282.68
List Price:  K403.85
You save:  K121.16
SAR262.90
List Price:  SAR375.59
You save:  SAR112.68
ZK1,929.21
List Price:  ZK2,756.13
You save:  ZK826.92
L333.95
List Price:  L477.10
You save:  L143.14
Kč1,686.22
List Price:  Kč2,408.98
You save:  Kč722.76
Ft27,781.83
List Price:  Ft39,690.03
You save:  Ft11,908.20
SEK kr772.17
List Price:  SEK kr1,103.14
You save:  SEK kr330.97
ARS$71,242.69
List Price:  ARS$101,779.64
You save:  ARS$30,536.94
Bs481.71
List Price:  Bs688.19
You save:  Bs206.47
COP$305,135.87
List Price:  COP$435,927.07
You save:  COP$130,791.20
₡35,171.10
List Price:  ₡50,246.58
You save:  ₡15,075.48
L1,769.55
List Price:  L2,528.04
You save:  L758.48
₲543,563.42
List Price:  ₲776,552.46
You save:  ₲232,989.03
$U3,109.25
List Price:  $U4,441.97
You save:  $U1,332.72
zł286.15
List Price:  zł408.81
You save:  zł122.65
Already have an account? Log In

Transcript

Video implementing ot updates through a web server in the sparkfun ESP 32 thing. In this video, we will learn the need for implementing web server based ot updates, and later implement web server based ot updates in the sparkfun ESP 32 thing. In the last video, you'll learn how to implement an OTA update through Arduino ID. But just imagine that your customer is not tech savvy, and don't have any clue on how to do an OTA update using Arduino ID. In such cases, it's necessary to implement an OTA update through a web server created by the ESP 32. Rather than using Arduino ID.

In this ot a model, the ESP 32 board will create a web server. The customer will be given a binary file of the updated code. The customer can just go to the browser and type In the mdns web page, and use the web server based UI to upload the binary file to complete the OT update. Just like in the previous video, we need to first prepare the ESP 32 abode for web server ot update. First, download the web server ot a dot zip file from the resources section and unzip it. Now open the Enable underscore web server underscore oca.io file in the Arduino ID.

Let's discuss how the code works. Just like the basic RTA code, we will import several libraries other than the usual libraries we imported earlier. We also will import the Wi Fi client dot hedge and the web server dot hedge for configuring and running the web server. But instead of the Arduino ot eight or hedge library, we will import the update dot h library which supports ot update Through HTTP. Thus, we can incorporate this with our web server for implementing RTA. Then we set the hostname and Wi Fi network credentials to these variables.

Please do not forget to edit this and add your wife or network credentials before uploading the code. Remember that the hostname will be mapped to the IP address by the end DNS protocol, making it easy to access the web server later. This instruction creates a web server object that listens for HTTP requests on port 80. Basically, for the OT a web server, we need a login page and ot update page and a general template for styling the web server. I have built here a custom web server experience, which is good to look at. If you are interested in making your own custom ot a web server.

You can visit the links in the resources section to learn more The string style has the HTML template code of the general look and feel of the web server. The string login index has the HTML code for the login authentication page, you can set your own login name and password by editing this line of the code. The string server index has the HTML code for the OTA update page, and handling the OTA update process using HTTP commands. Now let's get into the void setup loop. These instructions essentially do the same functions as these codes from the previous video. The mdns dot begin hostname method basically maps the IP address to the host name, which is ot ESP.

The following print commands will output the web address of your web server. The following codes will be skipped as they are callback functions. Data invoked during different phases of the updation. Once the web server starts just before the end of the Void set upload, the server dot begin function is invoked to start the web server. Inside the void loop, the server dot handle client function will handle all the OTA update process. Using callbacks two different methods in the void setup lobe.

The set of instructions is called when a get request happens for the root page of the web server, which is denoted by a forward slash. This function will display the login page in the web server. When a new user reaches the mdns web page we have set up these set of instructions is called when a get request happens for the server index page of the web server, which is denoted by forward slash server index. This function displays the OT update page in the website. After the user authentication has completed all these instructions till the server dot begin function is a single callback function that handles the uploading of the binary file. It also handles errors during the update process.

This callback is initiated when you click the Update button. After selecting the binary file of the OTA update. Here, a post command is sent on pressing the Update button, and the dot bin file, or binary file of the OTA update program is flashed to the ESP 32 board over the air. The update dot has error function checks the integrity and compatibility of the file being uploaded even before upload and output the status. If an error is detected, the ESP 32 is restarted when the upload is just about to begin, the set of instructions are executed which checks the size of the load. If the size is not compatible with the boat, an error message is shown.

If the upload status is to write the file to the ESP 32 bold, the update dot write function is invoked to handle the flashing of the firmware. As always, error handling instructions are also included. Similarly, when the upload process has ended, these sets of instructions are invoked to convey to the user that the update is successful. The last l slope is included to handle any of the unforeseen errors. Now let's upload the Enable underscore web server underscore ot a dot i n o to the sparkfun ESP 32 thing through the compote. before uploading, make sure that you have edited the Wi Fi SSID and password variables in the code.

Once flashed, open the serial monitor and press the reset button on the boat. Now you can see that the serial monitor will output a webpage URL. Now, you can remove your boat from the computer and power it via a power bank or a compatible battery. Once you have connected your computer to the same Wi Fi network, type in the webpage URL to the browser. Now log in with a user credentials. Next, let's upload a blink program over the air just like we did earlier.

Open the OT underscore program web server.io file in Arduino ID. The code is self explanatory if you understood the previous video. Now we need to create a binary file. Click the export compiled library option under sketch tab in the Arduino ID. The dot bin file will be saved in the same folder as the dot INF file of your sketch. Now go back to your web browser.

Click Choose File and select the binary file we just created. For our blink program, click update and wait till the progress reaches hundred percent. Wait for a couple of seconds No. And you can see that the LED on the sparkfun ESP 32 is indeed blinking. Thus, in the Zotero method, we don't need the Arduino ID to do an OTA update. This will make ot updation very less intimidating to your customers.

You can just send the binary file over to your customers and they can easily implement the updates to the product. I will now give you an activity, do an OT update to change the rate of blinking to one time every two seconds. Congratulations on completing web server implementation of ot update with a sparkfun ESP 32 thing. Summary In this video we have covered the following topics the need for implementing web server ot updates Implementing ot updates through a web server in the sparkfun ESP 32 thing. In the next video, we will implement a cloud based ot update system for the ESP 32 thing using mangoes always

Sign Up

Share

Share with friends, get 20% off
Invite your friends to LearnDesk learning marketplace. For each purchase they make, you get 20% off (upto $10) on your next purchase.