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

先上张简单分析的图:


思维导图

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树。它是解析完一部分内容就显示一部分内容,同时,可能还在通过网络下载其余内容。

参考资料

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 159,117评论 4 362
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 67,328评论 1 293
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 108,839评论 0 243
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 44,007评论 0 206
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 52,384评论 3 287
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 40,629评论 1 219
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 31,880评论 2 313
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 30,593评论 0 198
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 34,313评论 1 243
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 30,575评论 2 246
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 32,066评论 1 260
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 28,392评论 2 253
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 33,052评论 3 236
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 26,082评论 0 8
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 26,844评论 0 195
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 35,662评论 2 274
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 35,575评论 2 270

推荐阅读更多精彩内容