美文网首页计算机网络面试技术专栏技术类文章收集大杂烩
深度解析浏览器中输入 URL 后发生了什么

深度解析浏览器中输入 URL 后发生了什么

作者: 猫仔哦 | 来源:发表于2017-03-26 17:29 被阅读2190次

先上张简单分析的图:


思维导图

1. DNS 域名解析

  • 第一步,浏览器会检查缓存中有没有这个域名对应的解析过的 IP 地址,如果有,解析结束。
    浏览器中的缓存有时间空间限制。
  • 查找操作系统的缓存中是否有这个域名对应的 DNS 解析结果。
    在 Windows 系统中通过 C:\Windows\System32\drivers\etc\hosts 文件可以将域名解析到任何能够访问的 IP 地址,浏览器会首先使用这个地址。Linux 中这个配置文件是 /etc/named.conf。
    缓存时间同样受域名失效时间与缓存空间大小限制。
  • 如果以上还没解析结束,操作系统会把域名发送到 LDNS ( Local DNS Server ),即本地区的域名服务器。
    到这里已经可以解决 80% 的请求了。
  • 如果 LDNS 还没有,直接到 Root Server 域名服务器请求解析。
  • 根域名服务器返回给本地域名服务器一个所查询的主域名服务器( gTDL Server )地址。gTDL 是国际顶级域名服务器,如 .com、.cn 等。
  • 本地域名服务器再向主域名服务器发送请求。
  • 接受请求的主域名服务器查找并返回此域名对应的 Name Server 域名服务器地址,它是注册的域名服务器,如域名提供商的服务器。
  • Name Server 域名服务器查询存储的域名与 IP 的映射关系表,得到 IP 与 TTL值(TTL 值是控制返回时间的)。

2.建立TCP连接

TCP三次握手

  1. 第一次握手:建立连接。客户端发送 SYN 包到服务器,Sequence Number 为 x,进入 SYN_SENT 状态,等待服务器确认。
  2. 第二次握手:服务器收到 SYN 包,对这个报文进行确认,设置 Acknowledgment Number 为 Sequence Number + 1;同时自己也要发送 SYN 包,Sequence Number 为 y;服务器将这些所有信息放入 SYN + ACK 包中发送给客户发,服务器进入 SYN_RCVD 状态。
  3. 第三次握手:客户端收到 SYN + ACK 包。将 Acknowledgment Number 设为 y + 1,即服务器发来的 Sequence Number + 1,并向服务器发送 ACK 包,发送完成后客户端和服务器都进入 ESTABLISHED 状态。
TCP三次握手与四次挥手

3. 发起 HTTP 请求

请求方法

下面只列举了 HTTP/1.1 支持的方法。

方法 说明 备注
GET 获取资源
POST 传输实体主体
DELETE 删除文件 不带验证机制,任何人都可以删除
PUT 传输文件 不带验证机制,任何人都可以上传,存在安全问题
TRACE 追踪路径 容易引发 XSL 跨站攻击
HEAD 获得报文首部
OPTIONS 询问支持方法 查询针对请求 URI 指定的资源支持的方法,响应如 Allow: GET,POST,HEAD
CONNECT 要求用隧道协议连接代理 主要使用 SLL 和 TLS 协议把通信内容加密后经网络隧道传输

请求报文

请求报文

4. 接收响应结果

状态码

状态码的类别

类别 原因
1XX Informational 请求的信息正在处理
2XX Success 请求正常处理完毕
3XX Redirection 需要进行附加操作以完成请求
4XX Client Error 服务器无法处理请求
5XX Server Error 服务器处理请求出错

具体状态

  • 2XX
    • 200 OK
      表示从客户端发来的请求在服务器端被正常处理了
    • 204 No Content
      服务器接收的请求已成功处理,但在返回的响应报文中不含实体的主体部分
    • 206 Partial Content
      客户端进行了范围请求,而服务器成功执行了这部分的请求。响应报文中包含 Content-Range 指定范围请求的实体内容。
  • 3XX

    • 301 Move Permanently
      永久重定向。表示该资源已经分配了新的 URI,以后应使用资源现在的 URI。
    • 302 Found
      临时重定向。表示该资源已经分配了新的 URI,希望用户本次能使用新的 URI 访问。
      与 301 不同的是,302 已经移动的资源对应的 URI 将来还有可能改变。
    • 303 See Other
      由于请求对应的资源存在另一个 URI,应使用 GET 定向获取请求的资源。
    • 304 Not Modified
      它与重定向没有关系。
      服务器资源未改变,可直接使用客户端未过期的缓存。304返回时,不包含任何主体部分。
  • 4XX

    • 400 Bad Request
      请求报文中存在语法错误。

    • 401 Unauthorized
      需要有通过 HTTP 认证的认证信息

    • 403 Forbidden
      对请求资源的访问被服务器拒绝了

    • 404 Not Found
      无法找到请求的资源

  • 5XX

    • 500 Internal Server Error
      服务器端在执行请求时发生了错误
    • 503 Service Unavailable
      服务器暂时处于超负载状态或正在维护

响应报文

响应报文

5. 浏览器解析 HTML

渲染引擎开始解析 HTML / SVG / XHTML,并将标签转化为内容树中的 DOM 节点,产生 DOM Tree。接着,它解析 CSS 文件以及标签中的 style 样式信息,形成 CSSOM 树。DOM 树与 CSSOM 树共同构成 Render Tree,即渲染树。

6. 浏览器布局渲染

渲染的流程:

  • 计算 CSS 样式
  • 构建 Render Tree
  • Layout 布局
  • 绘制

Reflow / Layout:发生在元素尺寸改变时,或者将 displayblock 变为 none 时。

Repaint:屏幕的一部分要重绘时,如某个元素背景色的变化。

注:Reflow 的成本比 Repaint 的成本大很多。

值得注意的是,这个 5、6 是逐步完成的,为了更好的用户体验,渲染引擎将会尽可能早的将内容呈现到屏幕上,并不会等到所有的html都解析完成之后再去构建和布局render树。它是解析完一部分内容就显示一部分内容,同时,可能还在通过网络下载其余内容。

参考资料

相关文章

  • iOS 开源库、文章、源码整理

    iOS 开源库、文章、源码整理 iOS10本地推送,上线项目中的实际运用 深度解析浏览器中输入 URL 后发生了什么

  • HTTP协议

    前言 当我们在浏览器中输入url,敲下回车到页面的显示,这个过程中发生了什么? 在浏览器中输入url回车 域名解析...

  • 深度解析浏览器中输入 URL 后发生了什么

    先上张简单分析的图: 1. DNS 域名解析 第一步,浏览器会检查缓存中有没有这个域名对应的解析过的 IP 地址,...

  • 浏览器内容面试

    浏览器 1、输入url到展示页面过程发生了什么? 浏览器会先把url域名解析成对应ip(DNS解析) 解析成ip之...

  • 在浏览器中输入URL并回车后都发生了什么

    1.URL解析 当在浏览器中输入URL后,浏览器首先对拿到的URL进行识别,抽取出域名字段 2.DNS解析(域名解...

  • 随便聊聊一道经典的面试题

    当你在Web浏览器中输入一个URL,发生了什么? 分为8步来回答:1、浏览器(客户端)进行地址解析。 2、将解析出...

  • 从输入url到页面加载完成过程详解

    从输入url到页面加载完成发生了什么 一、浏览器接收到URL,到网络请求线程的开启。 1、URL解析 URL结构:...

  • 令我印象深刻的测试面试题

    在浏览器中输入URL会发生什么,用到了哪些协议 1、浏览器要将URL解析成IP地址,解析域名就要用到DNS协议,(...

  • 浏览器渲染性能优化

    从用户输入浏览器输入url到页面最后呈现 有哪些过程? 答案大致如下: 用户输入URL地址 浏览器解析URL解析出...

  • 理解浏览器与客户端通信过程

    有以下几个场景说明浏览器与客户端通信过程 1.浏览器上输入url之后发生了什么? ①url解析②获取ip地址③建立...

网友评论

本文标题:深度解析浏览器中输入 URL 后发生了什么

本文链接:https://www.haomeiwen.com/subject/yqohottx.html