从输入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 (永久重定向)
- 首次访问:
- 发送请求到原始URL
- 服务器返回301及新URL
- 浏览器缓存此重定向信息
- 跳转到新URL
- 后续访问:
- 浏览器直接使用本地缓存的重定向信息
- 直接访问新URL
- 不会请求原始URL
302 (临时重定向)
- 每次访问:
- 都会请求原始URL
- 服务器返回302及新URL
- 跳转到新URL
- 特点:
- 不会缓存重定向信息
- 每次都需要服务器告知跳转地址