导航流程:从输入URL到页面展示,这中间发生了什么

110 阅读2分钟

从输入URL到页面展示,这中间发生了什么

  • 用户输入URL并回车。

  • 浏览器进程检查URL,组装协议,构成完整的URL。

  • 浏览器进程通过进程间通信(IPC)把URL请求发送给网络进程。

  • 网络进程接收到URL请求后检查本地缓存是否缓存了该请求资源,如果有则将该资源返回给浏览器进程。

  • 如果没有,网络进程向web服务器发起http请求(网络请求),请求流程如下:

    • 进行DNS解析,获取服务器IP地址(端口号的指定是在DNS解析完成后的通信环节处理的)。
    • 利用IP地址和服务器建立TCP连接。
    • 构建请求头信息。
    • 发送请求头信息。
    • 服务器响应后,网络进程接收响应头和响应信息,并解析响应内容。
  • 网络进程解析响应流程:

    • 检查状态码,如果是301/302,则需要重定向,从Location字段中读取地址,重新进行第4步(301/302跳转与缓存的处理需要了解一下),如果是200,则继续处理请求。
    • 200响应处理:检查响应类型 Content-Type,如果是字节流类型,则将请求提交给下载管理器,该导航流程结束,不再进行后续的渲染,如果是html则通知浏览器进程准备渲染进程准备进行渲染。
  • 准备渲染进程:

    • 浏览器进程检查当前URL是否和之前打开的渲染进程根域名是否相同,如果相同,则复用原来的进程,如果不同,则开启新的渲染进程。
  • 传输数据、更新状态:

    • 渲染进程准备好后,浏览器向渲染进程发起“提交文档”的消息,渲染进程接收到消息和网络进程建立传输数据的“管道”。
    • 渲染进程接收完数据后,向浏览器发送“确认提交”消息。
    • 浏览器进程接收到确认消息后更新浏览器界面状态:安全、地址栏URL、前进后退的历史状态、更新web页面。

备注

301和302跳转时的缓存行为有所不同:

301 (永久重定向)

  1. 首次访问:
  • 发送请求到原始URL
  • 服务器返回301及新URL
  • 浏览器缓存此重定向信息
  • 跳转到新URL
  1. 后续访问:
  • 浏览器直接使用本地缓存的重定向信息
  • 直接访问新URL
  • 不会请求原始URL

302 (临时重定向)

  1. 每次访问:
  • 都会请求原始URL
  • 服务器返回302及新URL
  • 跳转到新URL
  1. 特点:
  • 不会缓存重定向信息
  • 每次都需要服务器告知跳转地址