More than code
Welcome to the website

从地址栏输入URL到页面加载完成发生了什么?

不管是前端还是后台开发,在找工作的时候,只要涉及到网络方面的知识,大都会问到这样一个问题:当在浏览器的地址栏里输入一个完整的URL,在按下回车直至页面加载完成,整个过程发生了什么?这是一道考察综合能力的面试题,今天我们就一起来总结下这个问题涉及到的主要知识点。

整体过程:

  • DNS域名解析
  • TCP连接
  • HTTP请求
  • 处理请求返回HTTP响应
  • 页面渲染
  • 关闭连接

1. DNS域名解析

首先我们应该要知道的是,在地址栏输入的域名并不是最后资源所在的真实位置,域名只是与IP地址的一个映射。网络服务器的IP地址那么多,我们不可能去记一串串的数字,因此域名就产生了,域名解析的过程实际是将域名还原为IP地址的过程。

DNS域名解析有两种方法,分别是迭代查询和递归查询

  • 迭代查询

  • 递归查询

2.TCP连接

在通过第一步的DNS域名解析后,获取到了服务器的IP地址,在获取到IP地址后,便会开始建立一次连接,这是由TCP协议完成的,主要通过三次握手进行连接。

三次握手的示意图如下:

3.HTTP请求

在确认与服务器建立连接后,便会发送一个HTTP请求,HTTP请求的报文主要包括请求行,请求头,请求正文。(HTTP请求主要包括:请求行、请求头、请求正文)

4.处理HTTP请求并响应

服务器在收到浏览器发送的HTTP请求之后,会将收到的HTTP报文封装成HTTP的Request对象,并通过不同的Web服务器进行处理,处理完的结果以HTTP的Response对象返回,主要包括状态码,响应头,响应报文三个部分。

状态码主要包括以下部分:

1xx:指示信息–表示请求已接收,继续处理。
2xx:成功–表示请求已被成功接收、理解、接受。
3xx:重定向–要完成请求必须进行更进一步的操作。
4xx:客户端错误–请求有语法错误或请求无法实现。
5xx:服务器端错误–服务器未能实现合法的请求。

响应头主要由Cache-Control、 Connection、Date、Pragma等组成

响应体为服务器返回给浏览器的信息,主要由HTML,css,js,图片文件组成

5.页面渲染

页面DOM树的渲染是个复杂的过程,需要深入了解DOM原理,这里简要描述一下,主要过程如下:

第一步:渲染引擎首先解析HTML文档,转换为一棵DOM树;

第二步:接下来不管是内联式,外联式还是嵌入式引入的CSS样式也会被解析,渲染出另 外一棵用于渲染DOM树的树-渲染树(render tree) ,渲染树包含带有颜色,尺寸等显示属性的矩形,这些矩形的顺序与显示顺序一致;

第三步:然后就是对渲染树的每个节点进行布局处理,确定其在屏幕上的显示位置;

第四步: 就是遍历渲染树并用UI后端层将每一个节点绘制出来。

6.关闭连接

在页面元素传输完成后,会选择关闭连接,此时用到的是TCP四次挥手,示意图如下:

总结:

以上就是从地址栏输入URL到页面加载完成的过程,更多详细的内容可自行查阅。

赞(0) 打赏
未经允许不得转载:李帅帅空间 » 从地址栏输入URL到页面加载完成发生了什么?

相关推荐

  • 暂无文章

评论 1

  • 昵称 (必填)
  • 邮箱 (必填)
  • 网址
  1. #1

    厉害哦~

    哎呀吆1年前 (2017-05-19)回复

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

微信扫一扫打赏