找回密碼
 立即注冊

QQ登錄

只需一步,快速開始

搜索
查看: 2541|回復(fù): 3
收起左側(cè)

用思維導(dǎo)圖分析代碼,讓初學(xué)者更輕松搞懂程序的運(yùn)作

[復(fù)制鏈接]
ID:636442 發(fā)表于 2022-10-22 15:57 | 顯示全部樓層 |閱讀模式
學(xué)習(xí)和使用ESP8266,在ardoinoIDE寫程序一個多月了。
剛開始看代碼時,由于水平比較低,
分析代碼比較難,
所以,在一邊學(xué)習(xí)時,一邊用思維導(dǎo)圖去分析代碼。
分析完,感覺思路有些清晰,
希望這個思維導(dǎo)圖對一些初學(xué)者有些參考意義。

001-簡概.png


003-.jpg


002-arduino-用WEB網(wǎng)頁-輸入WIFI名與密碼.png


004-.png


005-.png


006-.png


  1. #include <ESP8266WiFi.h>
  2. #include <DNSServer.h>
  3. #include <ESP8266WebServer.h>

  4. const char* AP_NAME = "qyz-SET-WIFI";//寫入自己設(shè)計的wifi名字
  5. //暫時存儲wifi賬號密碼
  6. char sta_ssid[32] = {0};
  7. char sta_password[64] = {0};


  8. //配網(wǎng)頁面代碼
  9. const char* page_html = "\
  10. <!DOCTYPE html>\r\n\
  11. <html lang='en'>\r\n\
  12. <head>\r\n\
  13.   <meta charset='UTF-8'>\r\n\
  14.   <meta name='viewport' content='width=device-width, initial-scale=1.0'>\r\n\
  15.   <title>Document</title>\r\n\
  16. </head>\r\n\
  17. <body>\r\n\
  18.   <form name='input' action='/' method='POST'>\r\n\
  19.         qyz設(shè)計測試: <br>\r\n\
  20.         wifi名稱: <br>\r\n\
  21.         <input type='text' name='ssid'><br>\r\n\
  22.         wifi密碼:<br>\r\n\
  23.         <input type='text' name='password'><br>\r\n\
  24.         <input type='submit' value='保存'>\r\n\
  25.     </form>\r\n\
  26. </body>\r\n\
  27. </html>\r\n\
  28. ";

  29. const byte DNS_PORT = 53;//DNS端口號
  30. IPAddress apIP(192, 168, 4, 1);//esp8266-AP-IP地址
  31. DNSServer dnsServer;//創(chuàng)建dnsServer實例
  32. ESP8266WebServer server(80);//創(chuàng)建WebServer

  33. void handleRoot() {//訪問主頁回調(diào)函數(shù)
  34.   server.send(200, "text/html", page_html);
  35. }

  36. void handleRootPost() {//Post回調(diào)函數(shù)
  37.   Serial.println("handleRootPost");
  38.   if (server.hasArg("ssid")) {//判斷是否有賬號參數(shù)
  39.     Serial.print("got ssid:");
  40.     strcpy(sta_ssid, server.arg("ssid").c_str());//將賬號參數(shù)拷貝到sta_ssid中
  41.     Serial.println(sta_ssid);
  42.   } else {//沒有參數(shù)
  43.     Serial.println("error, not found ssid");
  44.     server.send(200, "text/html", "<meta charset='UTF-8'>沒有輸入1error, not found ssid");//返回錯誤頁面
  45.     return;
  46.   }
  47.   //密碼與賬號同理
  48.   if (server.hasArg("password")) {
  49.     Serial.print("got password:");
  50.     strcpy(sta_password, server.arg("password").c_str());
  51.     Serial.println(sta_password);
  52.   } else {
  53.     Serial.println("error, not found password");
  54.     server.send(200, "text/html", "<meta charset='UTF-8'>沒有輸入2error, not found password");
  55.     return;
  56.   }

  57.   server.send(200, "text/html", "<meta charset='UTF-8'>保存成功");//返回保存成功頁面
  58.   delay(2000);
  59.   //連接wifi
  60.   connectNewWifi();
  61. }


  62. void initBasic(void){//初始化基礎(chǔ)
  63.   Serial.begin(115200);
  64.   WiFi.hostname("Smart-ESP8266");//設(shè)置ESP8266設(shè)備名
  65. }

  66. void initSoftAP(void){//初始化AP模式
  67.   WiFi.mode(WIFI_AP);
  68.   WiFi.softAPConfig(apIP, apIP, IPAddress(255, 255, 255, 0));
  69.   if(WiFi.softAP(AP_NAME)){
  70.     Serial.println("ESP8266 SoftAP is right");
  71.   }
  72. }

  73. void initWebServer(void){//初始化WebServer
  74.   //server.on("/",handleRoot);
  75.   //上面那行必須以下面這種格式去寫否則無法強(qiáng)制門戶
  76.   server.on("/", HTTP_GET, handleRoot);//設(shè)置主頁回調(diào)函數(shù)
  77.   server.onNotFound(handleRoot);//設(shè)置無法響應(yīng)的http請求的回調(diào)函數(shù)
  78.   server.on("/", HTTP_POST, handleRootPost);//設(shè)置Post請求回調(diào)函數(shù)
  79.   server.begin();//啟動WebServer
  80.   Serial.println("WebServer started!");
  81. }

  82. void initDNS(void){//初始化DNS服務(wù)器
  83.   if(dnsServer.start(DNS_PORT, "*", apIP)){//判斷將所有地址映射到esp8266的ip上是否成功
  84.     Serial.println("start dnsserver success.");
  85.   }
  86.   else Serial.println("start dnsserver failed.");
  87. }

  88. void connectNewWifi(void){

  89.   WiFi.mode(WIFI_STA);//切換為STA模式
  90.   WiFi.setAutoConnect(true);//設(shè)置自動連接
  91.   WiFi.begin();//連接上一次連接成功的wifi
  92.   Serial.println("");
  93.   Serial.print("Connect to wifi");

  94.   int count = 0;
  95.    while (WiFi.status() != WL_CONNECTED) {
  96.     delay(500);
  97.     count++;
  98.     if(count > 10){//如果5秒內(nèi)沒有連上,就開啟Web配網(wǎng) 可適當(dāng)調(diào)整這個時間
  99.       initSoftAP();
  100.       initWebServer();
  101.       initDNS();
  102.       break;//跳出 防止無限初始化
  103.     }
  104.     Serial.print(".");
  105.   }
  106.   Serial.println("");
  107.   if(WiFi.status() == WL_CONNECTED){//如果連接上 就輸出IP信息 防止未連接上break后會誤輸出
  108.     Serial.println("WIFI Connected!");
  109.     Serial.print("IP address: ");
  110.     Serial.println(WiFi.localIP());//打印esp8266的IP地址
  111.     server.stop();
  112.   }
  113. }

  114. void setup() {
  115.   initBasic();
  116.   connectNewWifi();
  117. }

  118. void loop() {
  119.   server.handleClient();
  120.   dnsServer.processNextRequest();
  121. }
復(fù)制代碼

評分

參與人數(shù) 2黑幣 +120 收起 理由
wps10025 + 30 贊一個!
admin + 90

查看全部評分

回復(fù)

使用道具 舉報

ID:310441 發(fā)表于 2022-10-23 08:07 來自手機(jī) | 顯示全部樓層
思路很清晰!
回復(fù)

使用道具 舉報

ID:607710 發(fā)表于 2022-12-19 07:49 來自手機(jī) | 顯示全部樓層
我一直都是這樣做的,包括自己編寫的時候也是先寫大綱。
回復(fù)

使用道具 舉報

ID:1062304 發(fā)表于 2023-2-14 16:02 | 顯示全部樓層
脈絡(luò)很清晰,有助于思考
回復(fù)

使用道具 舉報

您需要登錄后才可以回帖 登錄 | 立即注冊

本版積分規(guī)則

手機(jī)版|小黑屋|51黑電子論壇 |51黑電子論壇6群 QQ 管理員QQ:125739409;技術(shù)交流QQ群281945664

Powered by 單片機(jī)教程網(wǎng)

快速回復(fù) 返回頂部 返回列表