We read every piece of feedback, and take your input very seriously.
To see all available qualifiers, see our documentation.
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
简单的分析,从输入URL到回车后发生的行为如下:
URL
首先判断你输入的是一个合法的URL还是一个待搜索的关键词,并且根据你输入的内容进行对应操作
URL的解析第过程中的第一步,一个url的结构解析如下:
url
在之前文章中讲过DNS的查询,这里就不再讲述了
DNS
整个查询过程如下图所示:
最终,获取到了域名对应的目标服务器IP地址
IP
在之前文章中,了解到tcp是一种面向有连接的传输层协议
tcp
在确定目标服务器服务器的IP地址后,则经历三次握手建立TCP连接,流程如下:
TCP
当建立tcp连接之后,就可以在这基础上进行通信,浏览器发送http请求到目标服务器
http
请求的内容包括:
当服务器接收到浏览器的请求之后,就会进行逻辑操作,处理完成之后返回一个HTTP响应消息,包括:
在服务器响应之后,由于现在http默认开始长连接keep-alive,当页面关闭之后,tcp链接则会经过四次挥手完成断开
keep-alive
为什么数据传输是用对称加密?
公钥加密数据速度太慢,系统消耗大。对称加密算法性能是非对称的1000倍这个数量级,而 http 的应用场景中通常端与端之间存在大量的交互,非对称加密的效率是无法接受的。
另外:在 HTTPS 的场景中只有服务端保存了私钥,一对公私钥只能实现单向的加解密,所以HTTPS 中内容传输加密采取的是对称加密,而不是非对称加密。
当浏览器接收到服务器响应的资源后,首先会对资源进行解析:
cookie
gzip
Content-Type
关于页面的渲染过程如下:
HTML
DOM
CSS
render
Layout / reflow
paint
GPU
The text was updated successfully, but these errors were encountered:
No branches or pull requests
一、简单分析
简单的分析,从输入
URL
到回车后发生的行为如下:二、详细分析
URL解析
首先判断你输入的是一个合法的
URL
还是一个待搜索的关键词,并且根据你输入的内容进行对应操作URL
的解析第过程中的第一步,一个url
的结构解析如下:DNS查询
在之前文章中讲过
DNS
的查询,这里就不再讲述了整个查询过程如下图所示:
最终,获取到了域名对应的目标服务器
IP
地址TCP连接
在之前文章中,了解到
tcp
是一种面向有连接的传输层协议在确定目标服务器服务器的
IP
地址后,则经历三次握手建立TCP
连接,流程如下:发送 http 请求
当建立
tcp
连接之后,就可以在这基础上进行通信,浏览器发送http
请求到目标服务器请求的内容包括:
响应请求
当服务器接收到浏览器的请求之后,就会进行逻辑操作,处理完成之后返回一个HTTP响应消息,包括:
在服务器响应之后,由于现在
http
默认开始长连接keep-alive
,当页面关闭之后,tcp
链接则会经过四次挥手完成断开注意
公钥加密数据速度太慢,系统消耗大。对称加密算法性能是非对称的1000倍这个数量级,而 http 的应用场景中通常端与端之间存在大量的交互,非对称加密的效率是无法接受的。
另外:在 HTTPS 的场景中只有服务端保存了私钥,一对公私钥只能实现单向的加解密,所以HTTPS 中内容传输加密采取的是对称加密,而不是非对称加密。
页面渲染
当浏览器接收到服务器响应的资源后,首先会对资源进行解析:
cookie
,解压gzip
,缓存资源等等Content-Type
的值,根据不同的资源类型采用不同的解析方式关于页面的渲染过程如下:
HTML
,构建DOM
树CSS
,生成CSS
规则树DOM
树和CSS
规则,生成render
树render
树(Layout / reflow
),负责各元素尺寸、位置的计算render
树(paint
),绘制页面像素信息GPU
,GPU
会将各层合成( composite ),显示在屏幕上参考文献
The text was updated successfully, but these errors were encountered: