引言

最近上海连续下了一周雨,温度一夜之间回到解放前,穿夏装的我被冻得瑟瑟发抖,躲在家里哪也不想去。

在家百无聊赖的刷着网页,看到公众号后台的留言,有同学问我 HTTP 和 HTTPS 有啥区别?

这还用问,当然是 HTTPS 要比 HTTP 更加的安全啊,没看到后面带着个 S 呢么,带着 S 就这么 NB 。

然后同学的下一个问题把我问懵逼了,为啥带 S 的更安全呢?能详细的讲讲么。

我跟你讲嗷,不是我吹,我这么多年。。。。。。

就没见过你这么刨根究底的同学,老问这种我也不是很清楚的问题。

虽然这个问题问的我老脸一红,但是我有一种不要脸的精神 「我不会,但是我可以学」 。

HTTP

首先先来了解下 HTTP :

HTTP 协议全称为:Hyper Text Transfer Protocol ,翻译过来就是超文本传输协议,请不要质疑这个翻译,我专门用百度翻译翻了一下。

TCP/IP 四层模型应该都知道的,有数据链路层,网络层,传输层和应用层:

而 HTTP 协议就是位于 TCP/IP 四层模型的应用层上。

这里很多人都会混淆 TCP 和 HTTP ,实际上 HTTP 是基于 TCP 连接基础上的。

简单的说, TCP 就是单纯建立连接,不涉及任何我们需要请求的实际数据,简单的传输。而 HTTP 是用来收发数据,即实际应用上来的。

HTTP 协议通过请求和响应在客户端和服务端之间收发数据,进行通信:

HTTPS

HTTP 协议看起来好像没啥问题,唯一的问题就是不够安全,因为 HTTP 协议的传输方式完全是由明文传输的,不做任何加密,这就让一些不怀好意的人有了可乘之机。

这种传输方式诱发了一种经典的攻击方式:中间人攻击。

对于这种情况,最简单的我们可以使用加密方案,比如使用 AES 加密,服务端和客户端先约定一个随机生成的密钥 key ,后续的通信中,所有的信息都使用这个密钥进行 AES 加密:

这样虽然后面的通信过程安全了,但是我们在第一发送 AES 密钥的时候还是存在被中间人拦截的风险,一旦中间人拦截到我们的密钥,可用对密钥进行更换或者直接解密请求内容:

这时我们可以使用不对称加密,来专门对密钥的传输做一次额外的保护。

不对称加密会有两个密钥,一个是公钥,一个是私钥。明文可以使用公钥加密私钥解密,也可以使用私钥加密公钥解密。

现在比较通用的非对称加密算法有 RSA 。

看到这里的同学一定在奇怪,既然都使用了不对称加密,为啥只对 AES 的密钥做不对称加密,好像有多此一举,完全可以对后续所有的通信信息全都使用不对称加密。

因为不对称加密相比较对称加密性能上存在明显的劣势,可能你觉得在一个请求中多消耗几 ms 或者几 ns 无所谓,但是请求到达服务端是要进行解密,每个请求都多消耗几 ms 累计起来还是非常可观的。

上面这个方案看起来已经很安全了,中间人即使拦截到我们的公钥,由于不知道我们的私钥貌似也没办法解密。

实际上中间人完全不需要解密我们的信息,他可以生成一对新的公私钥发送给客户端进行攻击,后续客户端的通信中间人使用自己创造的私钥进行解密,然后通过服务端生成的公钥进行加密返回给服务端:

CA 证书

上面的问题我们仅通过客户端和服务端已经没办法了,这时候需要引入新的第三方机构,一个颁发 CA 证书的机构。

常见的第三方 CA 机构有:Symantec(赛门铁克),Comodo(科莫多),GeoTrust(环度网信),GoDaddy,Thawte,daoRapidSSL 等等。

在中间人攻击中,我们遇到的问题不是加密算法不够神奇,不是密钥方式不够严谨,而是我们没有办法向我们的客户端表明我们给他的公钥是我们的,是不是很像我没办法证明我是我的问题。

所以第三方机构应运而生,第三方机构只做一件事情,将服务端的公钥刻上了我们的名字(CA 证书),客户端接收到公钥之后,只需要来第三方机构这里查询,就能知道这个公钥是不是真的服务器,然后再将自己生成的 AES 密钥使用 CA 证书中解密得到的公钥进行加密后发送给服务端。

最后服务端使用私钥解密得到 AES 密钥,就可以愉快的和客户端进行通信了。

最后的最后,CA 机构验证不是每次都要去 CA 机构查询。这样做太傻了而且太耗时,尤其是很多 CA 机构的服务都在海外,这样一来一去消耗的时间太多了。

CA 机构高明的地方就在于,我们去找它注册公钥,它会使用另一个来注册的公司的私钥对我们的公钥加密,得到一个我们的公钥的指纹(全球唯一),然后将这家公司的公钥信息(其实也是证书)和我们的公钥以及我们公钥的指纹打包成一个证书。

当我们使用 HTTPS 将证书下发给客户端校验时,客户端(比如浏览器)从证书中看到了上级证书的信息,恰巧这个证书就在浏览器(或者本机)中,已经被验证过是合法的,浏览器只要使用这个证书中的公钥将我们的公钥指纹进行解密,然后比对我们的公钥信息就知道我们也是的合法的。因为假证书中的公钥签名不可能被合法的上级证书中公钥解密 。

这段稍微有点绕,慢慢看多看几次就理解了。

参考

https://www.jianshu.com/p/691b8ba3a70f

https://blog.csdn.net/u010144805/article/details/80803059

https://blog.csdn.net/caofengtao1314/article/details/87912078

我终于搞清了啥是 HTTPS 了相关推荐

  1. 终于搞清前端和后端的区别啦!

    众所周知,程序开发领域的技术更新迭代速度是非常快的,而且开发方式也会随着新技术的出现不断调整.因此,想要从事工程师岗位,前后端开发知识都应该掌握.但如果一定要将前端和后端开发做一个比较,可以从这几方面 ...

  2. 终于搞清前端和后端的区别啦!原来是这样的

    众所周知,程序开发领域的技术更新迭代速度是非常快的,而且开发方式也会随着新技术的出现不断调整.因此,想要从事工程师岗位,前后端开发知识都应该掌握.但如果一定要将前端和后端开发做一个比较,可以从这几方面 ...

  3. 手写LinKedList双向链表 终于搞清了什么是链表结构

    之前对Collection这块底层实现和异同点一直模糊不清,最近手动写了个链表结构实现LinKedList ,发现很多知识还是要不断去实践,专研,才能不断提升. LinKedList 实现 List接 ...

  4. Https是如何工作的?

    Https这个名词在日常编程中已经是习以为常了,写代码的时候也会涉及到相关的概念,那么,为什么相关的代码要那样写,所以来讲下Https. 密码系统(Cipher) 众所周知,如果我们要加密解密一些信息 ...

  5. AI换脸技术再创新高度,DeepMind发布的VQ-VAE二代算法有多厉害?

    作者 | beyondma 转载自CSDN网站 近日DeepMind发布VQ-VAE-2算法,也就是之前VQ-VAE算法2代,这个算法从感观效果上来看比生成对抗神经网络(GAN)的来得更加真实,堪称A ...

  6. JS日期函数getMonth()的值域是0--11

    好久没用JS写代码了,结果在计算日期时,出现了一个问题,困扰了我半天.最后终于搞清了问题的根源. 我选择月份列表项后,获得年份值和月份值,计算获得当月1号日期值和当月最后一天的日期值. 正确代码如下: ...

  7. 《寂静岭》完全资料手册

    寂静岭系列完全背景资料,新手可以参考 寂静岭剧情简介 一代:游戏发生前14年,在美国中部的临湖小镇寂静岭,一个阴谋正在酝酿当中.由于寂静岭自南北战争起就有崇拜邪恶的堕落天使samael的传统--所以当 ...

  8. 因为没有网关,我的服务器被 DDoS 了

    每天早上七点三十分,准时推送干货 大家好,我是鸭血粉丝,想起来之前生产发生的事故,阿粉我的内心到现在都还很忐忑不安,今天我们来学习一个 Kong 以及跟你们聊聊做好网关限流控制的重要性. 背景 事情是 ...

  9. NOIp2015酱油酱油记

    NOIp(据说正确写法是这样的..唔..)2015结束了...发生了很多事...也有许多小伙伴要暂时和oi说再见了... 今天本蒟蒻来打个酱油...希望不要被人追着打... 2015.11.6(星期五 ...

  10. 28位世界名人得到过的最佳忠告(仔细体味,获益匪浅)

    沃伦·巴菲特 Warren Buffett 74 岁 伯克希尔-哈撒韦公司 (Berkshire Hathaway)首席执行官 你之所以正确,并不是因为别人赞同你的观点,而是因为你依据的事实正确无误. ...

最新文章

  1. 三维空间平面拟合MATLAB
  2. 短波通信为何经久不衰?
  3. 微信小程序,是不是一盘可口的菜!
  4. python local variable_python学习笔记 - local, global and free variable
  5. ImageField,FileField上传文件命名问题
  6. Java内存模型常见问题
  7. 阿里巴巴Java开发手册——速读记录
  8. 小米公寓,年轻人的第一套公寓?回应来了
  9. 计算机合计功能,Javascript自动求和,Javascript自动合计
  10. bochs运行xp_bochs xp 镜像下载|bochs xp精简版下载_ - 极光下载站
  11. 目前域名防封的新知识
  12. 如何正确撰写sci论文中的作者信息
  13. 阿里云RDS金融数据库(三节点版) - 案例篇
  14. CSAPP bomblab
  15. 参加第一届“SLAM技术及应用”暑期学校暨研讨会和全国SLAM技术论坛有感
  16. 独家思维导图!让你秒懂李宏毅2020机器学习(二)—— Classification分类
  17. 腾讯云学生服务器官网地址(附用途指南)
  18. 给笔记本添加第二块显示屏
  19. OD:修改 navicat 试用期
  20. Matlab中axis函数用法总结

热门文章

  1. qr码生成_在PHP中生成QR码
  2. 【机器视觉】二维码检测(QR 码)
  3. 计算机科学与技术名言,关于科学的名言(20个最值得一读的科技名言)
  4. 巨杉数据库 java,巨杉Tech|SequoiaDB 巨杉数据库高可用容灾测试
  5. 电商后台管理4-商品列表及添加商品(list.vue和add.vue)
  6. Xposed小白入门,动态修改IMEI实例代码
  7. [摘]广义企业级PDM系统下的PPM(工艺规划管理)
  8. 企业债和公司债的四点区别
  9. 昼夜系统-游戏中的时间
  10. exxi6.7如何传文件到win7_iPhone 如何用跨平台 AirDrop+给安卓和 PC 秒传文件?