浅析输入网站地址到页面呈现

前言:在浏览器中输入https://www.baidu.com/按下回车键,到百度首页出现,这个过程发生了些什么呢?

百度首页

一、先了解什么是URL和IP地址

URL正式名称为 Uniform Resource Locator (简称:URL),是统一资源定位符,用于定位互联网上的资源。如https://www.baidu.com/就是URL。URL包含多种协议,比较常见的有http,https,ftp,file。

  • http是超文本传输协议,是用于从WWW服务器传输超文本到本地浏览器的传输协议。

  • https是加密版超文本传输协定,传输的网页经过加密,信息内容不容易被破解。所以https比http协议更加安全,也更加常见。

  • ftp是文件传输协议,主要用于在本地主机和远程主机之间传送文件,需要对不同的用户设置不同的权限,一般用于局域网的文件传输。

  • file是本地文件传输协议,主要用于访问本地计算机中的文件。

url的格式一般为:协议类型://<主机名>:<端口>/<路径>/文件名,以https://www.baidu.com/为例。

  • https表示该网站服务器使用https协议。
  • 主机名是否输入没有影响,端口号没有输入则表示为默认端口号,默认情况下http服务的端口为80。ftp为21,https为443。
  • 百度的域名则是www.baidu.com,百度的URL以斜杠“/”结尾,而没有给出文件名,在这种情况下,URL引用路径中最后一个目录中的默认文件(通常对应于主页),这个文件常常被称为 index.html 或 default.htm。所以输入这个网址实际是进入该网站的主页。

IP是互联网中的每台连接到网络的计算机为实现相互通信而遵循的规则协议。每个处于互联网中的设备都有IP 地址,形如 192.168.0.1,而127.0.0.1代表本机的 IP。IP又分为局域网IP和公网IP。而局域网 IP 和公网 IP 是有差别的。每个网站就是靠IP来定位的。

那为什么不直接用IP来访问网站,而发明域名呢?
  • IP地址为一串数字,一个网站对应一串数字,当访问多个网站时,需要记忆多个IP地址,不方便记忆。
  • 域名有语义化的作用,它比IP地址更容易记忆。

二、域名解析

https://www.baidu.com/为例,浏览器实际是不知道https://www.baidu.com/到底是在互联网的哪个位置,它需要查找https://www.baidu.com/这个域名背后对应的 IP 地址,根据这个IP地址,访问网站。查找域名对应的IP地址的过程叫域名解析。

域名解析流程

  1. 浏览器缓存

如果浏览器曾经访问过该网站,浏览器会缓存DNS记录一段时间,这样就快速找到该网站对应的 IP 地址,则域名解析结束。如果没有找到,会继续进行域名解析。

  1. 系统缓存

从电脑系统中 Hosts 的文件查找该域名和对应的IP地址。如果没有找到,继续进行域名解析。

  1. 路由器缓存

如果连着同一个路由器的其他设备访问过该网站,路由器也会缓存域名信息。从该路由器的缓存中查找是否有该网站对应的 IP 地址。如果没有,域名解析继续。

  1. ISP DNS 缓存

以上还是没有,就会向网络供应商 ( ISP) 查找是否有该网站对应的 IP 地址。如果没有,域名解析继续。

  1. 查找根域名伺服器供应商

若都没有找到,则向根域名服务器查找域名对应 IP,根域名服务器把请求转发到下一级,直到找到对应IP。

三、服务器处理

服务器是一台安装系统的机器,常见的系统有Linux,Windows server 2012。每台服务器上都会安装处理请求的应用——web server。常见的web server 有“apache”,“nginx”,“IIS”、“Lighttpd”等。Web服务器接收用户的请求(requset)交给网站代码或反向代理到其他服务器,然后进行一个网站处理流程,最后产生一个html的响应(response)给浏览器。

网站处理流程

网站处理是实际后台处理。后台开发到现在有很多框架,但大部分都还是按照“MVC设计模式”进行搭建的。

MVC是一个设计模式,将应用程序分成三个核心部件:模型(model),视图(view),控制器(controller)

MVC模型

MVC的处理过程

  1. 每一个用户输入的请求

  2. 首先被路由接收,再交由控制器决定用哪个模型来进行处理

  3. 将用户输入的指令数据传给模型进行处理

  4. 进行业务逻辑判断,按需要向数据库进行存取

  5. 根据业务逻辑选择视图

  6. 控制器用业务逻辑相应的数据填入视图模型

  7. 将处理好的视图模版的HTML交回控制器

  8. 生成 HTML 字符串返给浏览器处理,并通过显示页面呈现给用户。

四、浏览器处理

浏览器处理是根据MVC模型处理返回的HTML字符串被浏览器接受后被一句句读取解析,当解析到link标签后重新发送请求获取CSS 。当解析到scrip标签后发送请求获取JS,并执行代码。当解析到img标签后发送请求获取图片资源。

浏览器是一个边解析边渲染的过程。首先浏览器解析HTML文件构建DOM树,然后解析CSS文件构建渲染树,等到渲染树构建完成后,浏览器开始布局渲染树并将其绘制到屏幕上。

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 215,012评论 6 497
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,628评论 3 389
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 160,653评论 0 350
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,485评论 1 288
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,574评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,590评论 1 293
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,596评论 3 414
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,340评论 0 270
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,794评论 1 307
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,102评论 2 330
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,276评论 1 344
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,940评论 5 339
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,583评论 3 322
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,201评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,441评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,173评论 2 366
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,136评论 2 352

推荐阅读更多精彩内容