zoukankan      html  css  js  c++  java
  • 在浏览器地址栏中输入URL后发生了什么

    在浏览器地址栏中输入URL后发生了什么

    基本流程:

    ①查询ip地址

    ②建立tcp连接,接入服务器

    ③浏览器发起http请求

    ④服务器后台操作并做出http响应

    ⑤网页的解析与渲染

    详细步骤如下:

    查询ip地址

    ①浏览器解析出url中的域名。

    ②查询浏览器的DNS缓存。

    ③浏览器中没有DNS缓存,则查找本地客户端hosts文件有无对应的ip地址。

    ④hosts中无,则查找本地DNS服务器(运营商提供的DNS服务器)有无对应的DNS缓存。

    ⑤若本地DNS没有DNS缓存,则向根服务器查询,进行递归查找。

    ⑥递归查找从顶级域名开始(如.com),一步步缩小范围,最终客户端取得ip地址。

    tcp连接与http连接

    ①http协议建立在tcp协议之上,http请求前,需先进行tcp连接,形成客户端到服务器的稳定的通道。俗称TCP的三次握手。

    ②tcp连接完成后,http请求开始,请求有多种方式,常见的有get,post等。

    ③http请求包含请求头,也可能包含请求体两部分,请求头中包含我们希望对请求文件的操作的信息,请求体中包含传递给后台的参数。

    ④服务器收到http请求后,后台开始工作,如负载平衡,跨域等,这里就是后端的工作了。

    ⑤文件处理完毕,生成响应数据包,响应也包含两部分,响应头和相应体,响应体就是我们所请求的文件。

    ⑥经过网络传输,文件被下载到本地客户端,客户端开始加载。

    html渲染

    ①客户端浏览器加载了html文件后,由上到下解析html为DOM树(DOM Tree)。

    ②遇到css文件,css中的url发起http请求。

    ③这是第二次http请求,由于http1.1协议增加了Connection: keep-alive声明,故tcp连接不会关闭,可以复用。

    ④http连接是无状态连接,客户端与服务器端需要重新发起请求--响应。

    在请求css的过程中,解析器继续解析html,然后到了script标签。

    ⑤由于script可能会改变DOM结构,故解析器停止生成DOM树,解析器被js阻塞,等待js文件发起http请求,然后加载。这是第三次http请求。js执行完成后解析器继续解析。

    ⑥由于css文件可能会影响js文件的执行结果,因此需等css文件加载完成后再执行。

    ⑦浏览器收到css文件后,开始解析css文件为CSSOM树(CSS Rule Tree)。

    ⑧CSSOM树生成后,DOM Tree与CSS Rule Tree结合生成渲染树(Render Tree)。

    ⑨Render Tree会被css文件阻塞,渲染树生成后,先布局,绘制渲染树中节点的属性(位置,宽度,大小等),然后渲染,页面就会呈现信息。

    ⑩继续边解析边渲染,遇到了另一个js文件,js文件执行后改变了DOM树,渲染树从被改变的dom开始再次渲染。

    ⑪继续向下渲染,碰到一个img标签,浏览器发起http请求,不会等待img加载完成,继续向下渲染,之后再重新渲染此部分。

    ⑫DOM树遇到html结束标签,停止解析,进而渲染结束。

    从此可以得出网站的一些优化的方法:

    ①减少DNS查询:将服务器域名的ip信息加入本地host文件。

    ②减少http请求数量,对于图片使用雪碧图,对于html文件和css文件,js文件分别进行合并操作。

    ③减少下载时间:压缩图片,使用压缩应用压缩文档中的空格,删除文件多余的语句和注释,创造自己的js精简库和精简框架,使用本地浏览器缓存。

    ④提前渲染开始时间:将css链接放在html头部。

    ⑤减轻解析器的阻塞:将js链接放在body尾部。

     

  • 相关阅读:
    如何设置IIS程序池的回收时间,才能最大程度的减少对用户的影响?
    C#实现执行数据库事务案例
    RGB色彩对照表
    C# list.ForEach用法
    C# 实现list=list.OrderBy(q=>q.字段名).ToList(); 按多个字段排序
    IIS 7如何实现http重定向https
    Windows 2008 R2上配置IIS7或IIS7.5中的URLRewrite(URL重写)实例
    MVC网站发布到 IIS
    完美解决IE(IE6/IE7/IE8)不兼容HTML5标签的方法
    js返回上一页的实现方法
  • 原文地址:https://www.cnblogs.com/yanruizhe/p/11462462.html
Copyright © 2011-2022 走看看