跳到主要内容
极客日志极客日志面向AI+效率的开发者社区
首页博客GitHub 精选镜像工具UI配色美学隐私政策关于联系
搜索内容 / 工具 / 仓库 / 镜像...⌘K搜索
注册
博客列表
Javajava

Java 后端开发:网络通讯核心协议详解

综述由AI生成网络通信核心协议是后端开发的基石。对比了 TCP 与 UDP 在可靠性、速度及适用场景上的差异,解析了 HTTP 从 1.0 到 3.0 的演进特性。重点阐述了 HTTPS 基于 SSL/TLS 的加密原理与握手流程,并通过端到端通信实例展示了 DNS 解析、连接建立至数据交互的完整链路。掌握这些协议机制有助于优化系统性能与安全性。

刀狂发布于 2026/3/21更新于 2026/6/1120 浏览
Java 后端开发:网络通讯核心协议详解

引言

网络通信的核心协议,不仅是后端开发的必备技能,也是前端优化、架构设计乃至安全防护的基础。OSI 七层模型与 TCP/IP 四层模型是理解网络通信的理论框架。在实际应用中,TCP/IP 模型更为广泛使用,包括应用层、传输层、网络层和链路层。本文重点讨论应用层协议 HTTP/HTTPS 和传输层协议 TCP/UDP。

传输层协议详解

TCP(传输控制协议)

在网络世界里,TCP 几乎是可靠传输的代名词。它以其可靠性和有序性著称,是大多数业务场景的首选。

核心特性:

  • 面向连接:通信前必须建立连接,通信结束后释放连接
  • 可靠传输:通过确认、重传、校验等机制确保数据正确到达
  • 流量控制:滑动窗口机制防止发送方淹没接收方
  • 拥塞控制:慢启动、拥塞避免、快速重传、快速恢复算法

三次握手建立连接:

文章配图

这个过程确保了双方都准备好收发数据,并协商初始序列号。

四次挥手释放连接:

文章配图

双向连接的独立关闭保证了数据传输的完整性。

UDP(用户数据报协议)

UDP 则是另一种思路,以简单和高效为设计理念。

核心特性:

  • 无连接:发送数据前不需要建立连接
  • 不可靠传输:不保证数据到达,不保证顺序
  • 无状态:不维护连接状态
  • 开销小:头部仅 8 字节,比 TCP 的 20 字节更精简

TCP vs UDP 对比分析

特性TCPUDP
连接性面向连接无连接
可靠性高(确认、重传)低(无机制)
顺序性保证顺序不保证顺序
速度较慢(建立连接、确认)快(无握手)

选择策略:

  • 选择 TCP:需要可靠传输、数据完整性优先的场景
  • 选择 UDP:实时性要求高、可容忍少量丢包、需要多播的场景
  • 混合使用:部分应用在 UDP 上实现可靠传输机制

应用层协议详解

HTTP(超文本传输协议)

协议演进:

  • HTTP/1.0:每个请求/响应后关闭连接
  • HTTP/1.1:持久连接、管道化、分块传输
  • HTTP/2:多路复用、头部压缩、服务器推送
  • HTTP/3:基于 QUIC,解决队头阻塞

常用方法:

  • GET:获取资源
  • POST:提交数据
  • PUT:更新资源
  • DELETE:删除资源
  • PATCH:部分更新
  • HEAD:获取头部信息
  • OPTIONS:查询支持方法

状态码分类:

  • 1xx:信息性状态码
  • 2xx:成功(200 OK、201 Created、204 No Content)
  • 3xx:重定向(301 Moved Permanently、304 Not Modified)
  • 4xx:客户端错误(400 Bad Request、403 Forbidden、404 Not Found)
  • 5xx:服务器错误(500 Internal Server Error、502 Bad Gateway)

HTTP/2 核心改进:

  1. 二进制分帧:将消息分解为独立帧,交错发送
  2. 多路复用:一个连接并行多个请求/响应
  3. 头部压缩:HPACK 算法减少头部大小
  4. 服务器推送:服务器主动推送客户端可能需要的资源

HTTPS(安全超文本传输协议)

HTTPS = HTTP + SSL/TLS,为 HTTP通信提供加密、完整性和身份验证。

加密原理:

  1. 对称加密:加密解密使用相同密钥,速度快算法:AES、DES、3DES
  2. 非对称加密:公钥加密,私钥解密,安全性高算法:RSA、ECC、DH
  3. 混合加密:结合两者优势,用非对称加密交换对称密钥

数字证书与 PKI:

  • CA(证书颁发机构):受信任的第三方
  • 数字证书:包含公钥、持有者信息、CA 签名
  • 证书链:根证书 → 中间证书 → 服务器证书

TLS 握手过程:

  1. ClientHello:客户端支持的 TLS 版本、密码套件、随机数
  2. ServerHello:服务器选择 TLS 版本、密码套件、随机数,发送证书
  3. 证书验证:客户端验证服务器证书
  4. 密钥交换:客户端生成预主密钥,用服务器公钥加密发送
  5. 计算密钥:双方用随机数和预主密钥计算会话密钥
  6. 完成消息:验证握手过程完整性

HTTPS 优势:

  • **防窃听:**加密传输内容
  • **防篡改:**数字签名保证完整性
  • **防冒充:**证书验证身份
  • **SEO 优势:**搜索引擎排名因素

协议间的协同工作

端到端通信流程实例

我们以访问 "https://www.example.com" 为例:

  1. DNS 解析:UDP 查询 www.example.com 的 IP 地址
  2. TCP 连接:与服务器 443 端口三次握手建立连接
  3. TLS 握手:协商加密参数,验证证书
  4. HTTP 请求:发送加密的 HTTP 请求
  5. HTTP 响应:接收加密的 HTTP 响应
  6. 渲染页面:浏览器解析 HTML,加载资源
  7. 连接关闭:四次挥手释放连接

常见通信模式

短连接模式(HTTP/1.0 默认):

请求 -> 响应 -> 关闭连接 新请求 -> 新连接 -> 响应 -> 关闭连接
  • 优点:服务器资源占用少
  • 缺点:连接建立开销大

持久连接模式(HTTP/1.1 默认):

建立连接 请求 1 → 响应 1 请求 2 → 响应 2 ... 请求 N → 响应 N 关闭连接
  • 优点:减少连接建立开销
  • 缺点:服务器需维护连接状态

HTTP/2 多路复用:

连接 ├─ 流 1:请求 1 → 响应 1 ├─ 流 2:请求 2 → 响应 2 ├─ 流 3:请求 3 → 响应 3 └─ 流 4:服务器推送资源
  • 完全解决队头阻塞
  • 头部压缩减少开销

目录

  1. 引言
  2. 传输层协议详解
  3. TCP(传输控制协议)
  4. UDP(用户数据报协议)
  5. TCP vs UDP 对比分析
  6. 应用层协议详解
  7. HTTP(超文本传输协议)
  8. HTTPS(安全超文本传输协议)
  9. 协议间的协同工作
  10. 端到端通信流程实例
  11. 常见通信模式
  • 💰 8折买阿里云服务器限时8折了解详情
  • Magick API 一键接入全球大模型注册送1000万token查看
  • 🤖 一键搭建Deepseek满血版了解详情
  • 一键打造专属AI 智能体了解详情
极客日志微信公众号二维码

微信扫一扫,关注极客日志

微信公众号「极客日志V2」,在微信中扫描左侧二维码关注。展示文案:极客日志V2 zeeklog

更多推荐文章

查看全部
  • 深入理解 C++ 异常机制
  • 算法专题:模拟算法实战(替换问号、提莫攻击、Z 字形变换等)
  • 基于 Whisper-large-v3 的短视频配音识别与字幕生成
  • Ubuntu 22.04 系统安装 MuJoCo 完整指南
  • AI 开发不仅是调接口:技术深度与工程实践解析
  • OpenClaw 配置 Codex 5.3 个人 AI 编程方案实战
  • 【Project Aria】Meta新一代的AR眼镜及其数据集
  • Visual Studio 关闭 Copilot AI 代码提示的方法
  • Go Web 开发核心理论:HTTP、数据库与模板
  • Spring Boot 邮件与消息通知
  • Prompt 提示词工程核销逻辑与高效 AI 交互策略
  • 基于 OpenClaw 架构构建 C++ 量化交易引擎 QuantClaw 实战
  • 国产数据库新路径:电科金仓融合架构与 AI 实践
  • OpenClaw Skill 指南:从零开始打造专属 AI 助手
  • 带有机器人站点的无人机辅助车辆路径规划问题解析
  • XRoboToolkit:基于 PICO 4 Ultra 的机器人遥操作方案(一)
  • FastGPT 结合 MCP 协议构建工具增强型 AI Agent
  • 深入理解大语言模型:原理、训练与未来趋势
  • 下一代无障碍交互架构:Web MCP 微核多态与本地优先 SaaS 设计
  • 高鋒集團與 Web3Labs 如何賦能傳統企業 Web3 轉型

相关免费在线工具

  • Keycode 信息

    查找任何按下的键的javascript键代码、代码、位置和修饰符。 在线工具,Keycode 信息在线工具,online

  • Escape 与 Native 编解码

    JavaScript 字符串转义/反转义;Java 风格 \uXXXX(Native2Ascii)编码与解码。 在线工具,Escape 与 Native 编解码在线工具,online

  • JavaScript / HTML 格式化

    使用 Prettier 在浏览器内格式化 JavaScript 或 HTML 片段。 在线工具,JavaScript / HTML 格式化在线工具,online

  • JavaScript 压缩与混淆

    Terser 压缩、变量名混淆,或 javascript-obfuscator 高强度混淆(体积会增大)。 在线工具,JavaScript 压缩与混淆在线工具,online

  • Base64 字符串编码/解码

    将字符串编码和解码为其 Base64 格式表示形式即可。 在线工具,Base64 字符串编码/解码在线工具,online

  • Base64 文件转换器

    将字符串、文件或图像转换为其 Base64 表示形式。 在线工具,Base64 文件转换器在线工具,online