从输入URL地址到呈现网页内容的过程 - 於子牙Blog | 每日学习笔记(旧站点)

从输入URL地址到呈现网页内容的过程

启五

手机扫码查看

特别声明:文章多为网络转载,资源使用一般不提供任何帮助,特殊资源除外,如有侵权请联系!

1、域名解析
        当我们在浏览器中输入一个URL,例如”www.google.com”时,这个地址并不是谷歌网站真正意义上的地址。互联网上每一台计算机的唯一标识是它的IP地址,因此我们输入的网址首先需要先解析为IP地址,这一过程叫做DNS解析。

DNS解析是一个递归查询的过程。例如,我们解析於子牙Blog”www.wuaisite.com”时,会经历以下步骤:

  • 在本地域名服务器中查询IP地址,未找到域名;
  • 本地域名服务器回向根域名服务器发送请求,未找到域名;
  • 本地域名服务器向.com顶级域名服务器发送请求,未找到域名;
  • 本地域名服务器向.wuaisite.com域名服务器发送请求,找到该域名,将对应的IP返回给本地域名服务器。
2、TCP连接
HTTP协议是使用TCP协议作为其传输层协议的,在拿到服务器的IP地址后,浏览器客户端会与服务器建立TCP连接。该过程包括三次握手:
  • 第一次握手:建立连接时,客户端向服务端发送请求报文
  • 第二次握手:服务器收到请求报文后,如同意连接,则向客户端发送确认报文
  • 第三次握手,客户端收到服务器的确认后,再次向服务器给出确认报文,完成连接。
三次握手主要是为了防止已经失效的请求报文字段发送给服务器,浪费资源。

3、浏览器发送HTTP请求
浏览器构建http请求报文,并通过TCP协议传送到服务器的指定端口。http请求报文一共包括三个部分:
请求行:指定http请求的方法、url、http协议版本等
请求头:描述浏览器的相关信息,语言、编码等。如下:
浏览器发送http请求.png
请求正文:当发送POST, PUT等请求时,通常需要向服务器传递数据。这些数据就储存在请求正文中。

4、服务器处理HTTP请求
服务器处理http请求,并返回响应报文。响应报文包括三个部分:
  • 状态码:http服务常用的状态码及其含义如下
服务器处理HTTP请求.png
  •  响应头:包含了响应的相关信息,如日期等
HTTP请求.png

  • 响应正文:服务器返回给浏览器的文本信息,通常的html、js、css、图片等就包含在这一部分里面。

5、浏览器页面渲染
浏览器接受到http服务器发送过来的响应报文,并开始解析html文档,渲染页面。具体的渲染过程包括:构建DOM树、构建渲染树、定位页面元素、绘制页面元素等。

6、断开TCP连接
客户端与服务器四次挥手,断开tcp连接。
  • 第一次挥手:客户端想分手,发送消息给服务器
  • 第二次挥手:服务器通知客户端已经接受到分手请求,但还没做好分手准备
  • 第三次回收:服务器已经做好分手准备,通知客户端
  • 第四次挥手:客户端发送消息给服务器,确定分手,服务器关闭连接

分享到:
打赏
未经允许不得转载:

作者: 启五, 转载或复制请以 超链接形式 并注明出处 於子牙Blog | 每日学习笔记(旧站点)
原文地址: 《从输入URL地址到呈现网页内容的过程》 发布于2020-2-21

评论


切换注册

登录

您也可以使用第三方帐号快捷登录

切换登录

注册

login验证码

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

支付宝扫一扫打赏

微信扫一扫打赏