当前位置: 首页 > 面试题库 >

在地址栏里输入一个URL,到这个页面呈现出来,中间会发生什么?

皮煜
2023-03-14
本文向大家介绍在地址栏里输入一个URL,到这个页面呈现出来,中间会发生什么?相关面试题,主要包含被问及在地址栏里输入一个URL,到这个页面呈现出来,中间会发生什么?时的应答技巧和注意事项,需要的朋友参考一下

参考回答:

这是一个必考的面试问题,

输入url后,首先需要找到这个url域名的服务器ip,为了寻找这个ip,浏览器首先会寻找缓存,查看缓存中是否有记录,缓存的查找记录为:浏览器缓存-》系统缓存-》路由器缓存,缓存中没有则查找系统的hosts文件中是否有记录,如果没有则查询DNS服务器,得到服务器的ip地址后,浏览器根据这个ip以及相应的端口号,构造一个http请求,这个请求报文会包括这次请求的信息,主要是请求方法,请求说明和请求附带的数据,并将这个http请求封装在一个tcp包中,这个tcp包会依次经过传输层,网络层,数据链路层,物理层到达服务器,服务器解析这个请求来作出响应,返回相应的html给浏览器,因为html是一个树形结构,浏览器根据这个html来构建DOM树,在dom树的构建过程中如果遇到JS脚本和外部JS连接,则会停止构建DOM树来执行和下载相应的代码,这会造成阻塞,这就是为什么推荐JS代码应该放在html代码的后面,之后根据外部央视,内部央视,内联样式构建一个CSS对象模型树CSSOM树,构建完成后和DOM树合并为渲染树,这里主要做的是排除非视觉节点,比如script,meta标签和排除display为none的节点,之后进行布局,布局主要是确定各个元素的位置和尺寸,之后是渲染页面,因为html文件中会含有图片,视频,音频等资源,在解析DOM的过程中,遇到这些都会进行并行下载,浏览器对每个域的并行下载数量有一定的限制,一般是4-6个,当然在这些所有的请求中我们还需要关注的就是缓存,缓存一般通过Cache-Control、Last-Modify、Expires等首部字段控制。 Cache-Control和Expires的区别在于Cache-Control使用相对时间,Expires使用的是基于服务器 端的绝对时间,因为存在时差问题,一般采用Cache-Control,在请求这些有设置了缓存的数据时,会先 查看是否过期,如果没有过期则直接使用本地缓存,过期则请求并在服务器校验文件是否修改,如果上一次 响应设置了ETag值会在这次请求的时候作为If-None-Match的值交给服务器校验,如果一致,继续校验 Last-Modified,没有设置ETag则直接验证Last-Modified,再决定是否返回304

 

 

 

 类似资料:
  • 本文向大家介绍在浏览器中输入url到页面显示出来的过程发生了什么?相关面试题,主要包含被问及在浏览器中输入url到页面显示出来的过程发生了什么?时的应答技巧和注意事项,需要的朋友参考一下 这是一道面试中经常能看到的题目,过程其实挺长的,总结过来就是DNS域名解析拿到对应的域名解析,然后就是服务器端和客户端的三次握手建立数据传输通道,四次挥手关闭数据传输通道,客户端根据自己拿到的数据开始渲染页面。完

  • 输入地址(URL) 1. 开启选单后,使用方向按钮选择地址列,并按下按钮。 2. 使用键盘输入欲显示之Web网页的地址后,选择[确定]并执行决定。 提示 亦可从选单列中选择[档案] > [输入地址],进行同样操作。 将输入模式变更为支持Web输入后,可简单输入[http://]、[.com]等常用文字。又,选择[履历]后,将会显示之前输入的地址。按下SELECT(选择)按钮,可更换输入模式。

  • 本文向大家介绍在浏览器中输入url地址到显示页面的过程?相关面试题,主要包含被问及在浏览器中输入url地址到显示页面的过程?时的应答技巧和注意事项,需要的朋友参考一下 百度好像最喜欢问这个问题。 打开一个网页,整个过程会使用哪些协议 图解(图片来源:《图解HTTP》): 总体来说分为以下几个过程: DNS解析 TCP连接 发送HTTP请求 服务器处理请求并返回HTTP报文 浏览器解析渲染页面 连接

  • 本文向大家介绍输入URL到页面加载显示完成发生了什么?相关面试题,主要包含被问及输入URL到页面加载显示完成发生了什么?时的应答技巧和注意事项,需要的朋友参考一下 参考回答: DNS解析 TCP连接 发送HTTP请求 服务器处理请求并返回HTTP报文 浏览器解析渲染页面 连接结束  

  • 需要基础知识方面的帮助-我集成了角形和Spring靴。我制作了Angular应用程序的生产版本,并复制了Spring boot静态资源文件夹中的6个文件。 默认情况下,当我点击localhost:8080索引时。html呈现为Spring boot自动将其注册为欢迎页面。 现在,当我在角内,我可以通过角路由器导航到不同的组件,网址也在变化。 但当我复制同一个URL,例如localhost:8080

  • 流程 解析 URL 域名解析 发送 HTTP 请求 查找缓存 接收 HTTP 响应 解析响应内容 HTML 图片 视频 音频 PDF 资料 ​浏览器输入 URL 后发生了什么?​