前提・実現したいこと
ESP32-DevkitC-32E開発ボードにArduino-IDEを用いて、自宅のWiFiルータに接続してサーバとして動作するスケッチを作成。
このサーバに「Tera Term」でTelnetで接続して通信を確認しています
接続はできているようなのですが、5秒後に切断されてしまいます。
発生している問題・エラーメッセージ
該当のIPアドレスに接続確立表示されたあと、 必ず5秒後に"Tera Term-[未接続]VT"が表示されて切断されてしまいます。
該当のソースコード
C++
1 2#include <WiFi.h> 3#include <WebServer.h> 4#include <ESPmDNS.h> 5 6const char* ssid = "**********"; 7const char* password = "**********"; 8 9WebServer server(80); 10 11const int led = 13; 12 13void handleIndex(){ 14 digitalWrite(led, 1); 15 String htmlHead="<html><head><title>HTTP case study</title></head>"; 16 String htmlbody00="<body>Wellcome to my web page."; 17 String htmlbody01="</body></html>"; 18 String html=htmlHead+htmlbody00+htmlbody01; 19 //作成したhtmlをレスポンスとして送信する 20 server.send(200,"text/html", html); 21 digitalWrite(led, 0); 22} 23 24void handleRoot() { 25 digitalWrite(led, 1); 26 server.send(200, "text/plain", "hello from esp32!"); 27 digitalWrite(led, 0); 28} 29 30void handleNotFound() { 31 digitalWrite(led, 1); 32 String message = "File Not Found\n\n"; 33 message += "URI: "; 34 message += server.uri(); 35 message += "\nMethod: "; 36 message += (server.method() == HTTP_GET) ? "GET" : "POST"; 37 message += "\nArguments: "; 38 message += server.args(); 39 message += "\n"; 40 for (uint8_t i = 0; i < server.args(); i++) { 41 message += " " + server.argName(i) + ": " + server.arg(i) + "\n"; 42 } 43 server.send(404, "text/plain", message); 44 digitalWrite(led, 0); 45} 46 47void setup(void) { 48 pinMode(led, OUTPUT); 49 digitalWrite(led, 0); 50 Serial.begin(115200); 51 WiFi.mode(WIFI_STA); 52 WiFi.begin(ssid, password); 53 Serial.println(""); 54 55 // Wait for connection 56 Serial.println("--------------------------"); 57 Serial.print("Now connecting to "); 58 Serial.println(ssid); 59 Serial.println("--------------------------"); 60 while (WiFi.status() != WL_CONNECTED) { 61 delay(500); 62 Serial.print("."); 63 } 64 Serial.println(""); 65 Serial.print("Connected to "); 66 Serial.println(ssid); 67 Serial.print("IP address: "); 68 Serial.println(WiFi.localIP()); 69 70 if (MDNS.begin("esp32")) { 71 // ホスト名:esp32.local 72 Serial.println("MDNS responder started"); 73 } 74 server.on("/", handleRoot); 75 server.on("/index.html",handleIndex ); 76 server.onNotFound(handleNotFound); 77 78 server.begin(); 79 Serial.println("HTTP server started"); 80} 81 82void loop(void) { 83 server.handleClient(); 84 delay(2);//allow the cpu to switch to other tasks 85}
試したこと
Tera Termの設定は以下で試しました
1)設定→端末
- 改行コード
受信:CR+LF
送信:CR+LF
- 「ローカルエコー」にチェック
2)設定→TCP/IP
- 「Telnet」にチェック
-「Keep-alive」を300秒に設定
-「自動的にウィンドウを閉じる」のチェックを外す
3)ファイル→新しい接続
- 「TCP/IP」のラジオボタンを選択
- 「ホスト」にIPアドレスを設定(ex:192.168.11.11)
- 「Telnet」のラジオボタンを選択
- 「TCPポート」に80を設定
4)3)で「OK」ボタンを押下すると、5秒間は指定したIPアドレスに接続できますが、5秒後に切断されていまします。
補足情報
Xampでローカルサーバを起動して Telnetで接続した場合は、切断されませんでした。
ご助言いただけると幸いです。
以上よろしくお願いいたします。
回答2件
あなたの回答
tips
プレビュー