ESP32网络开发:1.创建一个基于TCP网络协议的网站

news2024/9/21 4:29:15

一、TCP协议的介绍

        TCP(传输控制协议,Transmission Control Protocol)是互联网协议套件中的一种核心协议,主要用于在网络中的计算机之间可靠地传输数据。TCP协议位于OSI模型(开放系统互联模型)的传输层,它为应用层协议(如HTTP、FTP、SMTP等)提供服务。

        以下是TCP协议的一些关键特性,用通俗易懂的方式解释:

  1. 连接导向:TCP协议在数据传输之前,需要在发送方和接收方之间建立一个连接。这就像打电话,需要先拨号,对方接听后,双方才能开始通话。

  2. 可靠性:TCP确保数据包能够无误地从发送方传输到接收方。如果某个数据包在传输过程中丢失或损坏,TCP会负责重新发送这个数据包。这就像邮寄包裹,如果包裹丢失,邮局会负责重新邮寄。

  3. 顺序保证:即使数据包通过不同的路径传输,TCP也能确保它们按照发送的顺序到达接收方。这就像排队买票,即使有人插队,最终大家还是按照先来后到的顺序买到票。

  4. 流量控制:TCP可以调整数据传输的速率,以避免发送方发送数据过快,导致接收方处理不过来。这就像交通流量控制,通过红绿灯调节车辆的通行速度,避免交通拥堵。

  5. 拥塞控制:当网络拥堵时,TCP会减少数据的发送速率,以避免加剧网络拥堵。这就像在繁忙的街道上,司机看到前方拥堵,会减速行驶,避免造成更大的交通堵塞。

  6. 错误检测:TCP使用校验和(checksum)来检测数据包在传输过程中是否发生错误。这就像快递包裹上的条形码,可以用来检查包裹是否在运输过程中受损。

        总结来说,TCP协议就像一个可靠的邮递服务,确保信件(数据包)能够准确、有序地从发送方传递到接收方,并且在传递过程中进行流量和拥塞控制,确保整个过程顺畅无误。

二、详细代码

        这里需将ssid和password改为你对应的WIFI或热点,并且随便写一个网址。

#include <WiFi.h>
#include <WiFiClient.h>
#include <WiFiServer.h>

// 替换为你的WiFi网络名称和密码
const char* ssid = ".....";
const char* password = ".....";

// 定义TCP服务器的端口号
const int port = 80;

// 创建一个TCP服务器实例
WiFiServer server(port);

void setup() {
  Serial.begin(115200);
  delay(1000);

  // 连接到WiFi网络
  Serial.println();
  Serial.print("Connecting to ");
  Serial.println(ssid);

  WiFi.begin(ssid, password);

  while (WiFi.status() != WL_CONNECTED) {
    delay(500);
    Serial.print(".");
  }

  Serial.println("");
  Serial.println("WiFi connected.");
  Serial.println("IP address: ");
  Serial.println(WiFi.localIP());

  // 启动TCP服务器
  server.begin();
  Serial.println("TCP server started.");
}

void loop() {
  // 检查是否有客户端连接
  WiFiClient client = server.available();

  if (client) {
    Serial.println("New client connected.");

    // 读取客户端请求
    String request = "";
    while (client.connected()) {
      if (client.available()) {
        char c = client.read();
        request += c;

        // 如果请求结束,发送响应
        if (c == '\n') {
          // 发送HTTP响应
          client.println("HTTP/1.1 200 OK");
          client.println("Content-type:text/html");
          client.println();
          client.println("<!DOCTYPE html>");
          client.println("<html>");
          client.println("<head>");
          client.println("<title>ESP32 Sci-Fi Web Server</title>");
          client.println("<style>");
          client.println("body { font-family: 'Courier New', monospace; background-color: black; color: #00FF00; }");
          client.println("h1 { color: #00FF00; }");
          client.println("button { background-color: #00FF00; color: black; border: none; padding: 10px 20px; font-size: 16px; cursor: pointer; }");
          client.println("button:hover { background-color: #00CC00; }");
          client.println("</style>");
          client.println("</head>");
          client.println("<body>");
          client.println("<h1>Welcome to the Web Server</h1>");
          client.println("<p>This is a web interface powered by ESP32, m3?</p>");
          client.println("<button onclick=\"alert('Restart')\">Button 1</button>");
          client.println("<button onclick=\"alert('Self-destruction')\">Button 2</button>");
          client.println("<button onclick=\"alert('Send gifts')\">Button 3</button>");
          client.println("</body>");
          client.println("</html>");
          client.println();

          // 关闭连接
          client.stop();
          Serial.println("Client disconnected.");
          break;
        }
      }
    }
  }
}

三、打开网址

        程序下载完成后,先打开串口调试助手,选择打印出来的IP地址,复制在浏览器打开。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1916427.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

系统架构设计师教程(清华第2版)<第2章 计算机系统基础知识>解读

系统架构设计师教程 第二章 计算机系统基础知识-2.1计算机系统概述 2.2 计算机硬件 2.1 计算机系统概述2.2 计算机硬件2.2.1 计算机硬件组成2.2.2 处理器2.2.2.1 控制单元(CU)2.2.2.2 算术逻辑单元(ALU)2.2.2.3 指令集2.2.2.3.1 CISC的特点2.2.2.3.2 RISC的特点2.2.3 存储器2.2…

大白话讲解AI大模型

大白话讲解大模型 大模型的发展重要大模型发展时间线 大模型的简单原理-训练⼤模型是如何训练并应⽤到场景中的&#xff1f;如果训练私有化模型 模型&#xff1a;model 语料库&#xff1a;用于训练模型的数据 大模型的发展 详细信息来源&#xff1a;DataLearner 2022年11月底…

【STM32学习】stm32cubemx基础配置,点亮/闪烁一个LED灯

1、cubemx开始 打开cubemx&#xff0c;在help栏中&#xff0c;点击&#xff0c;选择安装你所需要的stm32芯片版本&#xff0c; 打开后&#xff0c;选择你所配置的芯片型号&#xff0c;如我配置的是stm32f4系列&#xff0c;勾选&#xff0c;点击Install。 安装好后&#xff0c;…

防火墙配置安全策略以及用户认证综合实验

一、拓扑图&#xff1a; 二、实验需求&#xff1a; 1、DMz区内的服务器&#xff0c;办公区仅能在办公时间内(9:00-18&#xff1a;00)可以访问&#xff0c;生产区的设备全天可以访问&#xff1b; 2、生产区不允许访问互联网&#xff0c;办公区和游客区允许访问互联网 3、办公…

如何挑选适合的需求池管理系统?10款优质工具分享

本文将分享10款优质需求池管理工具&#xff1a;PingCode、Worktile、Teambition、Epicor Kinetic、TAPD、SAP IBP、Logility、RELEX Solutions、JIRA、明道云。 在管理项目和产品需求时&#xff0c;正确的工具能够大幅提高效率与透明度。如何从众多需求池工具中选择最适合团队的…

昇思25天学习打卡营第17天|基于MobileNetv2的垃圾分类

今天学习的内容是利用视觉图像技术&#xff0c;来实现垃圾分类代码开发的方法。通过读取本地图像数据作为输入&#xff0c;对图像中的垃圾物体进行检测&#xff0c;并且将检测结果图片保存到文件中。 本章节主要包括8部分内容&#xff1a; 1、实验目的 1、了解熟悉垃圾分类应用…

基于Python的哔哩哔哩数据分析系统设计实现过程,技术使用flask、MySQL、echarts,前端使用Layui

背景和意义 随着互联网和数字媒体行业的快速发展&#xff0c;视频网站作为重要的内容传播平台之一&#xff0c;用户量和内容丰富度呈现爆发式增长。本研究旨在设计并实现一种基于Python的哔哩哔哩数据分析系统&#xff0c;采用Flask框架、MySQL数据库以及echarts数据可视化技术…

前端--第一个前端程序

第一个前端程序 第一步&#xff1a; 使用记事本&#xff0c;编写代码 在你的一个磁盘里面创建一个文件夹&#xff0c;名为前端&#xff0c;然后在里面新建一个记事本&#xff0c;在里面写如下代码&#xff0c;注意一定要使用英文&#xff0c;然后把后缀名称改为.html。 第二…

MGRE环境下的OSPF实验

1、IP进行分配&#xff0c;并配置 配置各个路由器上的换回地址 配置接口地址 将缺省路由配出来 2、R1/4/5全连的MGRE以R1为中心 R1配置 进入隧道接口并配置ip 将协议配置为MGRE 并配置源接口IP 配置nhrp的id R3配置 R4配置

隔离计数器卡 脉冲编码器模块USB2392 采集48V电压 北京阿尔泰科技

1、简介&#xff1a; 2、主要系统框图&#xff1a; 2.3、规格参数&#xff1a; 3、板卡外形图&#xff1a;

Qt+MySQL实现社团管理系统

开发环境 ● Qt 5.14.1 ● Win10 ● Mysql 5.7.28 系统介绍 系统主要实现的功能如下图所示 社团管理系统主要包含了以下几个亮点功能 轮播图显示社团信息支持excel形式的导入导出学生信息权限控制&#xff08;管理员、超级管理员、用户&#xff09; 系统效果展示 登录界面…

Python-找客户软件

软件功能 请求代码&#xff1a; 填充表格&#xff1a; 可以search全国各个区县的所有企业信息&#xff0c;过滤手机号、查看是否续存/在业状态。方便找客户。 支持定-制-其他引-留-阮*件&#xff08;XHSS&#xff0c;DYY&#xff0c;KS&#xff0c;Bi-li*Bi-li&#xff09; V*…

Open3D 四元数法实现对应点集配准

目录 一、概述 1.1 基本思想 ​1.2详细步骤 二、代码实现 三、实现效果 3.1原始点云 3.2配准后点云 3.3变换矩阵 一、概述 在点云配准中&#xff0c;四元数法是一种精确计算旋转和平移变换的方法。其目标是找到一个刚体变换&#xff0c;使源点云和目标点云的对应点集之…

电厂数字孪生能源数据可视化运维平台开发炫酷且性价比更高

3D数据可视化大屏平台是我们为工厂车间提供的线上展示自定义工具&#xff0c;深度融合了web3D开发建模、AI和图形图像技术&#xff0c;完美还原车间产线布局&#xff0c;让复杂的生产流程和设备运行数据在大屏上直观呈现。 3D可视化数据大屏采用全景3D视角和虚拟现实技术&#…

Matlab中如何添加OptiluX?

1、打开Matlab&#xff0c;依次点击“新建”&#xff0c;“工程”&#xff0c;“从SVN”。 2、存储库路径输入&#xff1a; p/optilux/code - Revision 80: /trunk 同时在“源代码控制集成”菜单中选择“SVN (1.9)” 3、沙盒选择一个自己建的文件夹即可。 来源&#xff1a;Opt…

1290. 二进制链表转整数

给你一个单链表的引用结点 head。链表中每个结点的值不是 0 就是 1。已知此链表是一个整数数字的二进制表示形式。 请你返回该链表所表示数字的 十进制值 。 示例 1&#xff1a; 输入&#xff1a;head [1,0,1] 输出&#xff1a;5 解释&#xff1a;二进制数 (101) 转化为十进制…

【中项第三版】系统集成项目管理工程师 | 第 4 章 信息系统架构⑤ | 4.8 - 4.9

前言 第4章对应的内容选择题和案例分析都会进行考查&#xff0c;这一章节属于技术相关的内容&#xff0c;学习要以教材为准。本章分值预计在4-5分。 目录 4.8 云原生架构 4.8.1 发展概述 4.8.2 架构定义 4.8.3 基本原则 4.8.4 常用架构模式 4.8.5 云原生案例 4.9 本章…

防火墙(ensp USG6000v)---安全策略 + 用户认证综合实验

一. 题目 1&#xff09; 拓扑 2&#xff09;要求 1. DMZ区内的服务器&#xff0c;办公区仅能在办公时间内(9:00 -- 18: 00)可以访问&#xff0c;生产区的设备全天可以访问 2.生产区不允许访问互联网&#xff0c;办公区和游客区允许访问互联网 3.办公区设备10.0.2.10不充许…

链表 OJ(一)

移除链表元素 题目连接&#xff1a; https://leetcode.cn/problems/remove-linked-list-elements/description/ 使用双指针法&#xff0c;开始时&#xff0c;一个指针指向头节点&#xff0c;另一个指针指向头节点的下一个结点&#xff0c;然后开始遍历链表删除结点。 这里要注…

【React Hooks原理 - useState】

概述 useState赋予了Function Component状态管理的能力&#xff0c;可以让你在不编写 class 的情况下使用 state 。其本质上就是一类特殊的函数&#xff0c;它们约定以 use 开头。本文从源码出发&#xff0c;一步一步看看useState是如何实现以及工作的。 基础使用 function …