当你打开一个网页的时候发生了什么
你有没有好奇过,当你在浏览器打开一个网页的时候,从敲下回车的那一刻到看到网页展现,中间短短的几秒甚至几百毫秒里,到底发生了什么?浏览器怎么就展现出了这么个网页?来来来,让我们一步步分析~
打开网页的第一步肯定是输入网址了,那么对于浏览器来说,这是它唯一的线索,也就是URL。URL全称Unified Resource Locator,翻译过来就是统一资源定位符,俗称网址。打个比方,如果说网址是饭店店名,那浏览器就像外卖团队,你告诉浏览器你想吃的是哪家,它就派人去店里拿了外卖再送到你面前。
当浏览器去找网页的时候,首先需要去服务器上找网页,那么网页在哪里呢? 存储网页的地方叫做服务器(Server),服务器本身也是电脑,但是比个人电脑的性能要高很多。服务器也有多个,怎么找呢?就是根据给出的URL了。但其实,URL只是服务器地址的一个好记的名字而已,必须将URL解析为IP地址,才能找到相应的服务器。打个比方,URL好比是饭店的店名,那么IP地址就是是饭店的门牌地址。从URL到IP地址的过程叫做DNS查找,也就是DNS Lookup,这个过程所做的事情相当复杂,日后另起文章再详细介绍。
Connect & Request
根据IP找到服务器后,就可以向服务器发送请求了,请求服务器将你需要的网页发还给浏览器,浏览器和服务器传输信息的方式,就是建立连接。就像有个通道来供服务器和浏览器传递信息。
建立连接后,浏览器向服务器发起一个request请求,在请求中,需要告诉服务器想要的资源是什么,比如,我们请求google的首页:http://google.com:80/path?q=a#hash
一个URL一般由6个部分组成:协议、主机名、端口号、资源位置、queryString、hashTag;不同的path代表不同的资源,一般指页面,比较特殊的 / 是指根路径,一般会是网站的首页,和在电脑文件夹路径是同样的。
在前面所说的request请求中,包含一些数据:
GET / HTTP/1.1
Host: google.com
Accept:*/*
Pragma: no-cache
Cache-Control: no-cache
User-Agent:Mozilla/4.04[en](Win95;I;Nav)
GET / 指从服务器上请求一个资源,这个资源的位置是/。另外,Host: google.com代表请求的主机名是google.com。
Web Server
当服务器收到请求之后,经过Web Server对请求进行处理,最后将所请求的资源打包起来通过通道返回给浏览器。
每台服务器上都有Web Server用以处理请求,常见的有apache、nginx、IIS或Lighttpd等。
Web Server对于不同用户发送的请求,会结合配置文件,把不同请求委托给服务器上处理对应请求的程序进行处理(如CGI脚本,JSP脚本,servlets,ASP脚本,服务器端JavaScript等),然后返回后台程序处理产生的结果作为Response返回给浏览器。
现有后台处理程序大部分都使用了MVC框架:模型(Model) - 视图(View) - 控制器(Controller);MVC是一种设计模式,三个部分的组件各自处理自己的任务,从而将输入、处理和输出分离。
控制器接收浏览器的请求,决定应该调用哪个模型来进行处理,然后模型用业务逻辑来处理用户的请求并返回数据,最后控制器用相应的视图格式化模型返回html字符串给浏览器,这个返回的数据,叫做响应(Response)。
Response和Request是对应的,响应也包含和请求类似的数据:
HTTP/1.0200OK
Date:Mon,31Dec200104:25:57GMT
Server:Apache/1.3.14(Unix)
Content-type:text/html
Last-modified:Tue,17Apr200106:46:28GMT
Etag:"a030f020ac7c01:1e9f"
Content-length:39725426
Content-range:bytes554554-40279979/40279980
响应分为两个部分:响应头和响应主体。其中网页的代码包含在响应主体中。
浏览器处理及渲染
浏览器收到Response后,首先对其进行加载,并根据其中的代码继续向服务器请求资源(css、javascript、img等),加载完成后对页面进行解析。
解析的过程,其实就是生成解析树,即Dom树。Dom树是由Dom元素及属性节点组成,加上css解析的样式对象和js解析后的动作实现。
接下来对Dom树进行可视化表示,也就是渲染,生成一颗渲染树。
最后一步就是绘制网页,浏览器根据渲染树将元素绘制到屏幕上,同时执行js,完成整个页面的展示。
More
以上,就是从打开网页到看到网页过程的简要介绍,其中每个点拿出来说都是一本书。还需前行,还需努力!
作者:IrisYao
链接:https://www.jianshu.com/p/76d05329a420
来源:简书
简书著作权归作者所有,任何形式的转载都请联系作者获得授权并注明出处。
相关文章
- 【C#】对异步请求处理程序IHttpAsyncHandler的理解和分享一个易用性封装 【手记】走近科学之为什么明明实现了IEnumerable<T>的类型却不能调用LINQ扩展方法 【手记】手机网页弹出层后屏蔽底层的滑动响应 【手记】ASP.NET提示“未能创建类型”处理 【Web】一个非常简单的移动web消息框 【手记】解决EXCEL跑SQL遇“查询无法运行或数据库表无法打开...”
- 【学会轮播图这一篇文章就足够啦】JS 网页轮播图详解 自动播放+手动播放
- Web网页自动化实战《4.获取所有酒店的名字、价格、评分信息,并写入文件》上篇
- Highmaps网页图表教程之Highmaps第一个实例与图表构成
- wkhtmltopdf 将网页转换为PDF和图片
- django之创建第1个项目并查看网页效果
- 【快应用】网页跳转快应用测试指导
- 《提高转化率!网页A/B测试与多变量测试实战指南》一1.4 优化测试失败
- 《提高转化率!网页A/B测试与多变量测试实战指南》一2.5 勇气与责任心
- 《移动网页设计与开发 HTML5+CSS3+JavaScript》—— 2.4 微格式
- 《HTML5 开发实例大全》——1.24 在网页中显示一个文本框架
- 《HTML5 开发实例大全》——1.27 自动隐藏或显示网页中的文字
- 授予渔,从0开始搭建一个自己想要的网页
- 如何将网页挂载github上
- 零基础Unity做一个中秋诗词鉴赏网页,提前祝您中秋快乐!(DoTween动画 | WebGL视频 | 大文件上传GitHub)
- 利用cURL会话获取一个网页
- 使用Chrome保存网页为mht文件
- PS网页设计教程XXVIII——如何在PS中创建一个干净的网页布局
- PS网页设计教程XXVII——设计一个大胆和充满活力的作品集
- 开源ckplayer 网页播放器去logo去广告去水印修改