Web开发系列(一):从输入网址到最后,这个过程经历了什么?

这个问题,其实非常非常非常的大,涉及到的知识点和细节非常的多。不过我们适度的抛去一些无关紧要的细节, 例如在PC上用键盘输入还是在手机上用触屏输入这种。

首先,我们要进行一定的假设,用条件来限定我们的想象范围。

假设我们使用一台连着网线的PC,用键盘输入 http://jiajunhuang.com,从按下回车键开始,到最后我们看到了 页面,都经历了哪些过程?

DNS查找地址

首先浏览器看到输入的内容是 http://jiajunhuang.com,则会把 jiajunhuang.com 提取出来,通过DNS查找, 获得一个ip地址,然后http协议默认使用80端口,拼在一起去访问服务器。

而此处的DNS,全称是 Domain Name Servers,作用是记录IP地址和域名的映射关系,为什么需要这样一个东西呢? 因为IP地址不好记,可能你会觉得,IP地址很好记呀,那么试试记一个IPv6地址呢?而查找DNS的过程大概是这样:

  • 查找本地hosts文件,看是否有对应记录 - 所以有时候我们可以通过更改hosts文件浏览其它网站
  • 如果hosts文件查找不到,就会找本地的缓存,一般都会缓存一些常用的域名,以加快访问速度,当然,据说Chrome自己 也有缓存DNS,如果是这样的话,应该在第一步之前,Chrome就会先查找自己缓存的记录
  • 如果本地没有缓存,那么会向计算机所在网络的DNS服务器询问
  • 如果计算机所在网络的DNS服务器也没有,则会向再上一级询问,依次递归下去
  • 。。。
  • 当向上第n级找到,或者顶级未找到时,就会返回结果,然后这个结果依次传递回去

通常DNS会使用UDP协议。

DNS协议有一个缺点就是其协议不带加密,所以会有一种攻击叫做”DNS污染”。

请求服务器

浏览器获得IP地址之后,因为协议是HTTP,所以默认端口就是80,因此,向对应的服务器发起请求,HTTP协议如何发起请求我们 会在下一篇博客中讲述。

服务器响应

服务器接到请求之后,对请求进行响应,并且输出内容或者断掉连接。

浏览器渲染

浏览器收到服务器输出的内容之后,执行js脚本,根据css和浏览器自身默认的css渲染页面,然后呈现在用户前面。

那么,如果是HTTPS呢?

那么,如果是HTTPS呢?SSL会在TCP和HTTP协议之间发挥作用,SSL成功握手之后开始传输HTTP请求。


更多文章
  • 密码技术简明教程(一):对称加密和非对称加密
  • Kubernetes 笔记
  • go mod 和 logrus 路径大小写的问题
  • Flask自动加载Blueprint
  • 在KVM里安装Minikube
  • 搞定面试中的系统设计题
  • Crontab + Sendmail实现定时任务并且通知
  • Nginx设置Referer来防止盗图
  • Graphviz dot简明教程
  • jQuery简明教程
  • Python RQ(Redis Queue)添加gevent支持
  • 读《超级运营术》- 如何做社区?
  • 技术人,光有技术是不行的
  • 使用shairport-sync搭建airplay音频服务器
  • 搭建aria2服务器