在浏览器地址栏中输入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尾部。

转载于:https://www.cnblogs.com/yanruizhe/p/11462462.html

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

  1. 面试 地址栏中输入网址后发生了什么 url 生成网页 三次握手 四次挥手 ctp http ip

    title: [重识前端]地址栏中输入网址后发生了什么 date: 2020-10-09 10:08:31 tags: [浏览器] category: [重拾前端] cover: /image/cov ...

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

    文章目录 前言 一.DNS查询 二.TCP连接 三.发送HTTP请求 四.服务器处理HTTP请求并返回HTTP报文 五.浏览器解析并渲染页面 六.HTTP连接断开 前言 当我们向浏览器的地址栏中输入一 ...

  3. 如何向学妹解释在地址栏中输入网址后发生了什么?

    前几天有个学妹问我为什么在浏览器里面输了网址就会显示出来页面,虽然这个现象很常见,但是要想解释清楚确实有些小困难,当时也只是简单的回答了她,现在想趁着这个机会好好整理下相关知识.整理完才觉得其实就和我 ...

  4. 地址栏中输入网址后发生了什么?

    本文公众号来源:01二进制  作者:雇个城管打天下 记得在面试的时候也被问到这题,当时答得并不好,这道题目其实可以挖掘很多的知识点出来,建议阅读! 前几天有个学妹问我为什么在浏览器里面输了网址就会显示 ...

  5. 网络中典型协议--(DNS,输入url后, 发生的事情. ,ICMP,NAT)

    DNS(Domain Name System) DNS是一整套从域名映射到IP的系统 域名服务器发展背景 TCP/IP中使用IP地址和端口号来确定网络上的一台主机的一个程序. 但是IP地址不方便记忆. ...

  6. HTTP浏览器输入URL后发生了什么

    原文:"天龙八步"细说浏览器输入URL后发生了什么   慕课大神 本文摘要: 1.DNS域名解析: 2.建立TCP连接: 3.发送HTTP请求: 4.服务器处理请求: 5.返回响应 ...

  7. 浏览器输入url后发生了什么?

    浏览器输入url后发生了什么? 转载于:https://www.cnblogs.com/hellogiser/p/what-happened-after-url-was-typed-in-browse ...

  8. 在浏览器输入URL后发生了什么?

    摘录部分一:https://www.cnblogs.com/kongxy/p/4615226.html 从输入URL到浏览器显示页面发生了什么 当在浏览器地址栏输入网址,如:www.baidu.com ...

  9. 前端——在浏览器输入url后发生了都发生了什么

    一个页面从输入 URL 到页面加载显示完成,这个过程中都发生了什么? 主要包括以下几个基本步骤: 浏览器的地址栏输入URL并按下回车. 浏览器查找当前URL是否存在缓存,并比较缓存是否过期. DNS解 ...

最新文章

  1. 品友互动入榜“AI First——2017-2018年中国人工智能先行企业榜TOP10”
  2. Lua面向对象利用metamethod重载运算符
  3. idl文件生成java_IDL和生成代码分析
  4. php js鼠标滚动刷新,利用php和js实现页面数据刷新
  5. php floatval_php floatval()函数的用法详解
  6. 测试可变字符序列stringBuilder
  7. php 字符串循环替换字符串,php – 替换字符串中的重复字符串
  8. Jenkins + Docker 简单部署 node.js 项目
  9. python 图片对比文件夹_Python挑选文件夹里宽大于300图片的方法
  10. Java泛型通配符T,E,K,V
  11. java实验报告_java实验报告完整版.pdf
  12. Unity3D 在 UI TextMeshPro (TMP) 中显示中文
  13. MacOS下DockerCE的使用方式
  14. java程序员专业技能_java程序员简历专业技能怎么写
  15. 【AR优秀开源项目】ARCore项目工程汇总
  16. python获取网页数据判断并提交_python3爬虫无法通过网页内容判断存在与否?
  17. 姿态估计4-06:voxelpose(多视角3D人体姿态估算)-源码无死角解析(1)-训练代码总览
  18. 【渝粤教育】电大中专金融与税收 (2)作业 题库
  19. [坑]微信支付首次支付成功,第二次调用失败
  20. html图片后边自动底部对齐,css实现图片与文字底边对齐

热门文章

  1. 用SQL语句添加删除修改字段、一些表与字段的基本操作、数据库备份等
  2. iGrimace IG 各版本区别
  3. 批处理命令 For循环命令详解!
  4. 理解AppDomain
  5. nodejs 向mongodB获取指定数目的数据
  6. ViewPager onPageChangeListener总结
  7. 我发现一个新的软件,用自然语言编程!非常酷!
  8. 如何成为一个卓越的程序员
  9. 框架:Spring的自动装配
  10. Vue怎么将后台(springboot)中的图片显示到前端表格中