第一步、在浏览器输入URL
URL是什么: 统一资源定位符(Uniform Resource Locator,常缩写为URL),用于定位互联网上的资源(文字,视频,图片,网页,css等等)
http //明文传输的协议
https //加密传输的协议
file 协议 //访问本地计算机中的文件协议,如同在Windows资源管理器中打开文件
ftp //文件传输协议,用于从一台主机到另一台传送文件的协议
第二步、域名解析
对于http://baidu.com的URL,浏览器实际上不知道 baidu.com到底是什么东西,需要查找baidu.com网站所在服务器的IP地址,才能找到目标。
为什么要发明域名,不直接用IP?
方便记忆,具有语义化作用
域名是什么
http://baidu.com/8080中,baidu.com就是域名,
IP地址是什么
- 每个处于互联网中的设备都有IP地址,形如 192.168.0.1
- 局域网IP和公网IP是有差别的
- 局域网IP,比如只装了路由器,还没有交网费,只建立了本地网络,无法访问外网
- 公网IP,由于局域网IP可能是一样的,所以真正接入互联网的都有一个公网IP,任何人访问你的公网IP,都可以访问到服务器
- 127.0.0.1代表本机的IP,对应的本机域名是localhost
解析域名的流程
浏览器缓存 → 浏览器会缓存DNS记录一段时间,指曾经访问过这个地址
系统缓存 → 从Hosts文件查找是否有该域名和对应IP,第一次访问新的地址
路由器缓存 → 一般路由器也会缓存域名信息
ISP DNS缓存 → 比如到电信的DNS上查找缓存
如果都没有找到,则向根域名服务器查找域名对应IP,根域名服务器把请求转发到下一级,直到找到IP
第三步、服务器处理
服务器是一台安装系统的机器,常见的系统如Linux、windows server 2012
系统里安装的处理请求的应用叫 Web server
Web服务器:
常见的 web服务器有 Apache、Nginx、IIS、Lighttpd
web服务器接收用户的Request 交给网站代码,或者接受请求反向代理到其他 web服务器
web服务器.:就是一个管理的入口,工具,或者是一个管理者。可以去处理各种请求
第四步、网站处理流程
MVC 模型(model)-视图(view)-控制器(controller)
用户通过浏览器,发送请求,经过路由器和DNS域名解析,找到服务器上的网站后,通过控制器拿到数据和视图模板,然后把数据交给模板,再组成HTML页面,然后发给前台。
第五步、浏览器处理
HTML字符串被浏览器接受后被一句句读取解析
解析到link 标签后重新发送请求获取css
解析到 script标签后发送请求获取 js,并执行代码
解析到img 标签后发送请求获取图片资源
绘制网页
浏览器根据 HTML 和 CSS 计算得到渲染树,绘制到屏幕上,js 会被执行
总结
从最初的输入URL,然后DNS解析成IP,然后通过IP连接到服务器,服务器判断IP对应的域名是什么,然后交给不同的网站去处理,网站收到请求后,根据路由,交给不同的控制器,控制器从模型里面请求数据,模型就和数据库进行交互,获得数据,同时在拿到对应的视图模板,然后数据填入模板,经过浏览器的渲染绘制,就呈现到屏幕上了。