网络相关 - 浏览器输 URL后发生的完整过程

文章目录

    • 一、完整流程概览图
    • 二、详细步骤解析
      • [1. URL 解析与预处理](#1. URL 解析与预处理)
      • [2. DNS 域名解析](#2. DNS 域名解析)
      • [3. 建立 TCP 连接(三次握手)](#3. 建立 TCP 连接(三次握手))
      • [4. TLS 握手(HTTPS 专属)](#4. TLS 握手(HTTPS 专属))
      • [5. 发送 HTTP 请求](#5. 发送 HTTP 请求)
      • [6. 服务器处理请求](#6. 服务器处理请求)
      • [7. 接收 HTTP 响应](#7. 接收 HTTP 响应)
      • [8. 浏览器解析与渲染](#8. 浏览器解析与渲染)
      • [9. 加载静态资源](#9. 加载静态资源)
      • [10. JavaScript 执行](#10. JavaScript 执行)
      • [11. 页面交互就绪](#11. 页面交互就绪)
      • [12. 后续优化行为](#12. 后续优化行为)

当在浏览器地址栏输入 URL(如 https://www.example.com)并按下回车时,背后发生了以下 12 个关键步骤,如下:

一、完整流程概览图

二、详细步骤解析

1. URL 解析与预处理

  • 浏览器解析 URL 结构

    复制代码
    https://www.example.com:443/path?query=1#section
    └─协议 └──主机名 └─端口 └─路径 └──查询参数 └─锚点
  • 自动补全
    若输入example.com,浏览器自动补全为https://www.example.com(根据历史记录和 HSTS 列表)

2. DNS 域名解析

浏览器通过 DNS 查询 将域名转换为 IP 地址,查询顺序如下:

  • 关键点
    • DNS 查询使用 UDP 协议(端口 53)
    • 结果缓存 TTL 由 DNS 服务器设置

3. 建立 TCP 连接(三次握手)

  • 目的:确保双方收发能力正常
  • 耗时:通常 1~3 个 RTT(往返时间)

4. TLS 握手(HTTPS 专属)

  • 关键步骤
    • 证书链验证(CA 机构签名)
    • 密钥交换(ECDHE/RSA)
    • 协商对称加密算法(如 AES_256_GCM)

5. 发送 HTTP 请求

浏览器发送的请求头示例:

http 复制代码
GET /index.html HTTP/1.1
Host: www.example.com
User-Agent: Mozilla/5.0
Accept: text/html,application/xhtml+xml
Cookie: session_id=abc123

6. 服务器处理请求

服务器端典型处理流程:

复制代码
Nginx → 反向代理 → 应用服务器(如Node.js) → 数据库查询 → 生成HTML

7. 接收 HTTP 响应

服务器返回的响应头示例:

http 复制代码
HTTP/1.1 200 OK
Content-Type: text/html; charset=utf-8
Cache-Control: max-age=3600
Set-Cookie: session_id=def456

8. 浏览器解析与渲染

关键子流程

优化策略

  • 预加载扫描器 :提前发现<img>/<script>资源
  • 延迟加载 :对非首屏图片使用loading="lazy"

9. 加载静态资源

  • 并行下载:现代浏览器支持 6~8 个 TCP 连接并行下载
  • 优先级控制
    • CSS/阻塞 JS > 图片 > 异步脚本

10. JavaScript 执行

  • 解析阶段:词法分析 → 语法分析 → 字节码生成
  • 执行阶段
    • 同步任务直接执行
    • 异步任务(如setTimeout)进入事件循环队列

11. 页面交互就绪

  • 触发事件
    DOMContentLoaded(DOM 解析完成) → load(所有资源加载完成)

12. 后续优化行为

  • 预渲染:Chrome 在后台预加载用户可能访问的下一个页面
  • Service Worker 缓存:支持离线访问(PWA 技术)

👉点击进入 我的网站

相关推荐
一只小bit10 小时前
Qt 绘图核心教程:从基础绘制到图像操作全解析
前端·c++·qt·gui
乾元10 小时前
绕过艺术:使用 GANs 对抗 Web 防火墙(WAF)
前端·网络·人工智能·深度学习·安全·架构
HWL567910 小时前
一个CSS属性will-change: transform
前端·css
Y淑滢潇潇10 小时前
WEB 作业 即时内容发布前端交互案例
前端·javascript·交互
玉树临风江流儿10 小时前
WSL2通过主机转发流量,实现与开发板互相ping通
linux·服务器·网络
比特森林探险记10 小时前
后端开发者快速入门react
开发语言·前端·javascript
李松桃10 小时前
python第三次作业
java·前端·python
码界奇点10 小时前
基于eBPF技术的高性能网络防火墙系统设计与实现
开发语言·网络·毕业设计·php·wpf·go语言·源代码管理
熊猫钓鱼>_>10 小时前
从零到一:打造“抗造” Electron 录屏神器的故事
前端·javascript·ffmpeg·electron·node·录屏·record
sunlifenger10 小时前
【兆越课堂】时间的回归|网络“同步性”的进化简史
网络·5g·信息与通信