当前位置: 首页 > news >正文

一个页面从输入 URL 到页面加载显示完成,这个过程中都发生了什么

一个页面从输入URL到加载显示完成经历了以下过程:

  1. DNS解析:浏览器会解析URL中的域名,将其转换为对应的IP地址。如果浏览器缓存中存在该域名的IP地址,则跳过DNS解析步骤。

  2. 建立TCP连接:通过解析得到的IP地址,浏览器与服务器建立TCP连接。这个过程涉及三次握手,确保客户端和服务器之间的连接可靠。

  3. 发送HTTP请求:TCP连接建立后,浏览器向服务器发送HTTP请求。请求中包含了请求方法(GET、POST等)、请求头(包括用户代理、Cookie等信息)和请求体(对于POST请求)。

  4. 服务器处理请求:服务器接收到HTTP请求后,会根据请求的路径和参数进行处理,并生成相应的响应内容。

  5. 接收响应:浏览器接收到服务器返回的响应,响应包含了响应状态码、响应头和响应体。

  6. 处理响应:浏览器开始处理响应,根据响应状态码判断请求是否成功,根据响应头中的Content-Type确定如何处理响应体的数据类型(如HTML、CSS、JavaScript等)。

  7. 渲染页面:浏览器根据HTML文档解析页面结构,构建DOM树;同时解析CSS样式表,生成CSSOM树;然后将DOM树和CSSOM树合并为渲染树(Render Tree)。最后,基于渲染树进行布局(Layout)和绘制(Painting),将页面内容显示在用户的屏幕上。

  8. 加载资源:在渲染过程中,如果遇到外部资源(如图片、脚本、样式表等),浏览器会发送额外的请求去获取这些资源,并再次经历上述的请求和相应的过程。

  9. 完成页面加载:当所有资源都被加载完成,并且页面的渲染、布局、绘制都完成后,浏览器视为页面加载显示完成。

需要注意的是,以上步骤并非严格按照顺序一次性完成,而是同时或交替进行的。此外,每个步骤的具体细节还涉及到网络延迟、服务器处理速度、资源大小等因素,可能会影响整个过程的耗时。

http://www.lryc.cn/news/252596.html

相关文章:

  • iOS ------ UICollectionView
  • ElasticSearch知识体系详解
  • Linux自启服务提示:systemd[1]: *.service: main process exited, code=exited, status=1问题
  • LoadBalancer将服务暴露到外部实现负载均衡purelb-layer2模式配置介绍
  • Spring Bean的生命周期各阶段详解附源码
  • LoadBalancer将服务暴露到外部实现负载均衡Openelb-layer2模式配置介绍
  • Android异步之旅:探索IntentService
  • 131.类型题-计算数学序列的和,请编写函数fun,其功能是S=……【满分解题代码+详细分析】(数学序列的和类型题-C/C++JavaPython实现)
  • 【Unity动画】状态机中层的融合原理与用法详解
  • 等保之道:从基础出发,解密网站防护的重要性
  • 7. 系统信息与系统资源
  • 【重点】【滑动窗口】239. 滑动窗口最大值
  • d3dx9_43.dll丢失原因以及5个解决方法详解
  • Python实现FA萤火虫优化算法优化卷积神经网络分类模型(CNN分类算法)项目实战
  • 不瞒各位,不安装软件也能操作Xmind文档
  • 你了解Redis 的二进制安全吗
  • 探索前端设计的新境界——介绍IVueUI工具助力Vue页面设计
  • 数据管理系统-week10-数据库安全
  • MySQL笔记-第05章_排序与分页
  • MySQL笔记-第02章_MySQL环境搭建
  • ★136. 只出现一次的数字(位运算)
  • 阿里云效一键部署前后端
  • 【算法集训】基础数据结构:一、顺序表(上)
  • 封装websocket并在vuejs中调用
  • 博捷芯:半导体芯片切割,一道精细工艺的科技之门
  • BiseNet实现遥感影像地物分类
  • 【SpringBoot系列】SpringBoot时间字段格式化
  • .net core 连接数据库,通过数据库生成Modell
  • 开发工具idea中推荐插件
  • [c++]—string类___深度学习string标准库成员函数与非成员函数