面试题:在地址栏输入url到页面的渲染发生了什么

在地址栏输入url到页面的渲染发生了什么

整体过程在这整个过程中,大致可以分为以下几个过程
1. DNS域名解析
2. TCP连接
3. HTTP请求
4. 处理请求返回HTTP响应
5. 页面渲染
6. 关闭连接

DNS域名解析

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

TCP连接

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

三次握手

因为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,图片文件组成

页面渲染

关闭连接

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

四次挥手

因为关闭服务器需要发送四个包,所以称为四次挥手。客户端和服务端都可以发起挥手动作,只要任意一方执行close()操作即可产生挥手操作,也就是发送一个Fin包
第一次挥手,主动方发送带标志的Fin报文到被动方,请求关闭与被动方的连接,但是tcp协议是双方的,所以被动方收到Fin报文之后仍然可以发送数据,所以被动方会发送两个报文
第二次挥手,被动方接受到Fin报文确认标志正确之后发送一个带标志的Ack报文给主动方,表示收到关闭请求;
第三次挥手,被动方发送一个带标志的Fin包到主动方,请求关闭与主动方的连接
第四次挥手,主动方收到被动方发来的报文,确认标志正确之后发送一个Ack报文到被动方,表示收到被动方的关闭请求

  • 3
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值