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


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

        打开网页的第一步肯定是输入网址了,那么对于浏览器来说,这是它唯一的线索,也就是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# 时间戳转日期
    用robotframework框架搭建自动化测试框架示例一
    Spring MVC中静态资源处理的源码解析
    压缩sql server 数据库的空间,清理日志.ldf
    windows 玩转 nginx
    uniapp的获取token,移除token
    js获取confirm的返回值
    uniapp富文本复制文字内容
    uniapp使用richtext,对后台传入数据进行处理
    uniapp处理后台传入的html代码
  • 原文地址:https://www.cnblogs.com/feng9exe/p/11239752.html
Copyright © 2020-2023  润新知