当你打开一个网页的时候发生了什么

    你有没有好奇过,当你在浏览器打开一个网页的时候,从敲下回车的那一刻到看到网页展现,中间短短的几秒甚至几百毫秒里,到底发生了什么?浏览器怎么就展现出了这么个网页?来来来,让我们一步步分析~

    打开网页的第一步肯定是输入网址了,那么对于浏览器来说,这是它唯一的线索,也就是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
    本文转自网络文章,转载此文章仅为分享知识,如有侵权,请联系博主进行删除。
点赞