热门标签 | HotTags
当前位置:  开发笔记 > 后端 > 正文

理解Https

一次网络的请求,会经过很多的中间人,比如路由器,猫,网络运营商的基站等等。如果使用HTTP这协议,些中间人&#

一次网络的请求,会经过很多的中间人,比如路由器,猫,网络运营商的基站等等。如果使用HTTP这协议,些中间人,是可以直接查看浏览器和服务器之间的数据的,相当于在裸奔。
以前在网络监管没有那么严格的时候,xx公司就会在服务器返回给客户端的数据上面添油加醋,比如说返回的网页上面加入广告,让你冲话费啥的。。。
思考:怎么保证这些中间人不能查看客户端和服务器之间的数据?
加密。用一个只有客户端和服务器知道的密码对数据进行加解密。中间人不知道密码,即使截获到了数据,也是一堆乱码,也不能进行查看修改。
记得上大学的时候,到银行办理过一个网上银行的服务。银行会给你发一个类似U盘的东西,当你想要转账的时候,就把这个东西插在电脑上,然后就能进行安全的转账了。
其实,这个U盘里面包含的就是客户端和服务端用来加密数据的密码。密码只有客户端和服务端知道,保证了绝对的安全。
客户端和服务端使用的都是同一个密码,这就是对称加密。
在这里插入图片描述

思考:在互联网应用中,如果每个应用的客户都下发一个U盾,来传递密码,全世界这么多应用、这么多用户,这是一个指数级的问题,没有办法实现。那么如何在互联网上安全的传输这个对称加密的密码而不被外泄呢?
引入非对称加密,用来传输对称加密所使用的秘钥。加密和解密用的不是同一个秘钥。公钥加密只有私钥能解,私钥加密只有公钥能解。

TCP三次握手之后,https中的ssl协议还会要求一次四次握手,主要用于商量对称加密的算法以及对称加密使用的秘钥。

  1. 客户端会say一个Hi,并且将自己支持的对称加密算法集合(cipher suites)发送给服务器,服务器会从这些算法中挑选一个自己也支持的对称加密的算法,并且返回给客户端。同时将自己的public key发送给客户端。
  2. 客户端得到响应之后,知道了要使用的对称加密的算法是什么,接下来,就会和服务器商量一个对称加密的秘钥。
  3. 客户端会随机生成一串秘钥,并且用服务端的public key进行加密。发送给服务器。
  4. 服务器在收到秘钥之后,使用自己的私钥进行解密得到对称加密的秘钥。由于公钥加密只有私钥能够解密,而私钥只有服务器才有,其它的中间人是没有的,中间人无法解密,所以保证了对称加密所使用的秘钥的安全。
    在这里插入图片描述思考:上面的流程绝对安全了吗?
    并不是。中间人可以冒充服务器和客户端的。
    如果服务器在下发公钥的时候,公钥被中间人拦截。
    1)冒充服务端:我不把这个公钥传递给客户端,而是我自己生成一对公私钥,然后将自己的公钥传给客户端。这样我就能冒充服务器和客户端进行通信了。
    2)冒充客户端:我不把客户端的请求转发给服务器,而是用服务器的公钥将自己生成的对称加密的秘钥加密之后,发给服务器,这样后面我就能够冒充客户端和服务器通信了。

在这里插入图片描述

思考:如何解决中间人冒充客户端或者服务器的问题?
这时候就需要引入第三方机构CA了。

  1. Server提供一些信息,比如网站的域名、邓白氏编码、营业执照、自己的公钥给CA机构
  2. CA机构对这些信息进行一个鉴别,主要是鉴别这个网站是不是属于你的。防止有人申请同一个网站的证书。一般验证的方法是让你在网站的某个目录放一个文件,并且在文件里面写上指定的内容。
  3. 验证通过之后,CA机构会拿自己的私钥,给server提供的信息签一个名。这样就得到了一个CA证书。CA私钥签名只有CA的公钥能够解开。
  4. 获得CA证书之后,网站的管理员需要将证书部署到server上。
  5. 客户端在请求服务器的时候,服务器会将包含自己的public key的证书发送给客户端
  6. 客户端拿到证书之后,会用CA的公钥对证书进行解密。CA的公钥也是包含在证书中的,一般是内置在操作系统中。
  7. 这样一来,就得到了serverpublic key了。后面再使用这个key协商对称加密的秘钥。
    在这里插入图片描述

思考:中间人能够解开server的证书吗?
能。既然客户端的操作系统能够内置CA机构的公钥,那么中间人的操作系统也可以。所以中间人也能够解开证书得到服务器的公钥。

思考:既然中间人能解开证书得到server的公钥,那么它还能冒充服务器吗?
不能。中间人如果需要冒充服务器,它需要创建一个伪证书。它不可能从CA再去申请一个相同域名的证书了,因为CA机构会进行验证(如果真的申请成功了怎么办?CA机构会为你的损失给你赔钱)。既然不能申请证书,那么可不可以自己伪造一个?
即使伪造了也没啥用。因为中间人需要拿自己的私钥签名一个伪证书,而客户端现在会用内置的CA机构的公钥去解密收到的证书。中间人发过来的伪证书,客户端是没有办法使用内置的公钥解开的。(当然如果你的系统受到了攻击导入了一些包含公钥的不正常的证书话,就不能避免这个问题,所以我们不能随便给系统导入证书)

思考:中间人现在能够冒充客户端吗?
这时候是可以的。因为中间人能够得到server的公钥。中间人不把客户端的请求发给服务器,而是用服务器的公钥将自己生成的对称加密的秘钥加密之后发给服务器,这样后面就能够冒充客户端和服务器通信了。
解决办法:到这里,都是客户端去验证server端是不是真正的server,这就是https的单向认证。HTTPS还有一个双向认证,server端也去验证下是不是真正的客户端在和自己通信。既然server端能够申请证书,那么客户端能不能也去CA申请一个证书?证明自己是真正的客户端。可以的。
双向认证可以参考这篇文章:https://www.jianshu.com/p/2b2d1f511959?utm_campaign=haruki


推荐阅读
  • 深入解析Java虚拟机(JVM)架构与原理
    本文旨在为读者提供对Java虚拟机(JVM)的全面理解,涵盖其主要组成部分、工作原理及其在不同平台上的实现。通过详细探讨JVM的结构和内部机制,帮助开发者更好地掌握Java编程的核心技术。 ... [详细]
  • 本文详细介绍了网络存储技术的基本概念、分类及应用场景。通过分析直连式存储(DAS)、网络附加存储(NAS)和存储区域网络(SAN)的特点,帮助读者理解不同存储方式的优势与局限性。 ... [详细]
  • PyCharm下载与安装指南
    本文详细介绍如何从官方渠道下载并安装PyCharm集成开发环境(IDE),涵盖Windows、macOS和Linux系统,同时提供详细的安装步骤及配置建议。 ... [详细]
  • 本文详细介绍了如何在Linux系统上安装和配置Smokeping,以实现对网络链路质量的实时监控。通过详细的步骤和必要的依赖包安装,确保用户能够顺利完成部署并优化其网络性能监控。 ... [详细]
  • 本文介绍了Java并发库中的阻塞队列(BlockingQueue)及其典型应用场景。通过具体实例,展示了如何利用LinkedBlockingQueue实现线程间高效、安全的数据传递,并结合线程池和原子类优化性能。 ... [详细]
  • 本文详细介绍了Java编程语言中的核心概念和常见面试问题,包括集合类、数据结构、线程处理、Java虚拟机(JVM)、HTTP协议以及Git操作等方面的内容。通过深入分析每个主题,帮助读者更好地理解Java的关键特性和最佳实践。 ... [详细]
  • 高效解决应用崩溃问题!友盟新版错误分析工具全面升级
    友盟推出的最新版错误分析工具,专为移动开发者设计,提供强大的Crash收集与分析功能。该工具能够实时监控App运行状态,快速发现并修复错误,显著提升应用的稳定性和用户体验。 ... [详细]
  • 本文探讨了 Spring Boot 应用程序在不同配置下支持的最大并发连接数,重点分析了内置服务器(如 Tomcat、Jetty 和 Undertow)的默认设置及其对性能的影响。 ... [详细]
  • 解决网站乱码问题的综合指南
    本文总结了导致网站乱码的常见原因,并提供了详细的解决方案,包括文件编码、HTML元标签设置、服务器响应头配置、数据库字符集调整以及PHP与MySQL交互时的编码处理。 ... [详细]
  • 优化局域网SSH连接延迟问题的解决方案
    本文介绍了解决局域网内SSH连接到服务器时出现长时间等待问题的方法。通过调整配置和优化网络设置,可以显著缩短SSH连接的时间。 ... [详细]
  • 阿里云ecs怎么配置php环境,阿里云ecs配置选择 ... [详细]
  • Nginx 反向代理与负载均衡实验
    本实验旨在通过配置 Nginx 实现反向代理和负载均衡,确保从北京本地代理服务器访问上海的 Web 服务器时,能够依次显示红、黄、绿三种颜色页面以验证负载均衡效果。 ... [详细]
  • 优化ListView性能
    本文深入探讨了如何通过多种技术手段优化ListView的性能,包括视图复用、ViewHolder模式、分批加载数据、图片优化及内存管理等。这些方法能够显著提升应用的响应速度和用户体验。 ... [详细]
  • 本文将介绍如何编写一些有趣的VBScript脚本,这些脚本可以在朋友之间进行无害的恶作剧。通过简单的代码示例,帮助您了解VBScript的基本语法和功能。 ... [详细]
  • 本文介绍了如何使用PHP代码实现微信平台的媒体素材上传功能,详细解释了API接口的使用方法和注意事项,确保文件路径正确以避免常见的错误。 ... [详细]
author-avatar
意华嘉泰6
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有