从地址栏输入URL到页面加载完成了什么操作

前言

不管是前端开发还是后台开发,在找工作的时候,只要设计到网络方面的知识,必然会问到这样一个问题:当我们在浏览器的地址栏中输入了一个完整的URL,在按下回车键直至页面加载完成,整个过程发生了什么?今天我们就一起来总结下该如何问答这个问题,这里只讲解主要的知识点,涉及到的细节还需要大家再去找资料看。

整体过程

在这整个过程中,大致可以分为以下几个过程:
  • DNS域名解析
  • TCP连接
  • HTTP请求
  • 处理请求返回HTTP响应
  • 页面渲染
  • 关闭连接

DNS域名解析
首先我们应该要知道的是,在地址栏输入的域名并不是最后资源所在的真实位置,域名只是与IP地址的一个映射。网络服务器的IP地址那么多,我们不可能去记一串串的数字,因此域名产生了,域名解析的过程实际是将域名还原成IP地址的过程。DNS域名解析有两种方法,分别是迭代查询和递归查询。
迭代查询:
这里写图片描述
递归查询:
这里写图片描述


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


HTTP请求
在确认与服务器建立连接后,便会发送一个HTTP请求,HTTP请求的报文主要包括请求行,请求头,请求正文。请求行的内容一般类似于:GET index.html HTTP/1.1。请求头的内容一般如下,可以通过浏览器的开发工具查看
这里写图片描述


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

  • 1xx:指示信息–表示请求已接受,继续处理
  • 2xx:成功–表示请求已被成功接收,理解,接受
  • 3xx:重定向–要完成请求必须进行更进一步的操作
  • 4xx:客户端错误–请求有语法错误或者请求无法实现
  • 5xx:服务器端错误:服务器未能实现合法的请求
    响应头主要由Cache-Control,Connection,Date,Pragma等组成。响应体为服务器返回给浏览器的信息,主要由HTML,css,js,图片文件组成。

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


关闭连接
在页面元素传输完成后,会选择关闭连接,此时用到了是TCP四次握手,示意图如下:
这里写图片描述


后需还需要补充的是 本地DNS的解析,CDN的缓存,浏览器的缓存等相关的知识

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值