当前位置:首页HTTPS究竟是啥?这篇文章带你快速了解HTTPS 举报文章

HTTPS究竟是啥?这篇文章带你快速了解HTTPS

作者:admin    来源:用户投稿    时间:2019.1.6   

今天接到个活儿,让我科普 HTTPS 。讲 HTTP 我都“方”,想要通俗易懂的说完 HTTPS, 我有点“圆”。在讲什么是 HTTPS 之前,我们先来看个漫画。

HTTPS究竟是啥?这篇文章带你快速了解HTTPS 域名 网站 数据分析 好文分享 第1张

HTTPS究竟是啥?这篇文章带你快速了解HTTPS 域名 网站 数据分析 好文分享 第2张

△ 图片来源于阮一峰的网络日志

漫画中其实就是 HTTPS 的握手过程,但是我相信大段的英文你看着也不怎么流畅,下面就由我简单讲解下吧。

HTTPS 是在 HTTP 的基础上增加了 SSL 或 TLS 安全协议,这些协议有众多的套件,这些套件则是由加密算法和哈希算法组成,而这些算法最后则涉及到了数学。

数学是我上学时期最头痛的学科,还记得上数学课时,我传纸条给坐在我后面的班花……咦,好像有点跑偏了,拉回来,坐好了,开始我们的 HTTPS 之旅。

HTTPS 是什么

HTTPS 是为了安全的使用 HTTP ,缩写展开:Hyper Text Transfer Protocol over Secure Socket Layer 。从英文释义可以看出,HTTPS 就是 HTTP + SSL 或者 HTTP + TLS 。

“我读书少,你可不要骗我,上面的英文缩写不是 HTTP over SSL 吗?”呃...是这样的,HTTPS 最初使用的加密协议的确是 SSL,SSL 最近的三个版本是:SSL 1.0 、SSL 2.0 、SSL 3.0 ,不过随着加密算法的发展和人们对传安全性要求的提高。

截止目前已经长江后浪推前浪依次推出了 TLS 的四个版本,分别是:TLS 1.0 、TLS 1.1 、TLS 1.2 以及前不久刚推出的 TLS 1.3 。实际上,业内也有人把 TLS 1.0 叫做 SSL 3.1 ,事实上,TLS 是在 SSL 的基础上发展起来的更安全的加密协议。

为什么要使用 HTTPS

这个问题要从为什么逐渐的抛弃 HTTP 说起。

HTTP 从 1991 年的 HTTP/0.9 一直发展到 1999 年的 HTTP/1.1 ,虽然功能不断增加,性能也不断提高,但是随着互联网技术和网络设备的迅速普及,导致信息大爆炸,众多的网民们对网络传的速度和安全性有了越来越高的要求。

2012 年,谷歌推出了 SPDY 方案,优化了 HTTP/1.x 的请求延迟和安全性问题,进一步普及了 HTTPS,截止到 2015 年,HTTP/2 已经成为标准,更是进一步推动了全网 HTTPS 的进程。

全网 HTTPS 是大势所趋,那么为什么抛弃 HTTP 呢?最重要的原因就是安全问题,因为 HTTP 是明文传的,这对于目前从娃娃就开始玩智能手机,学习 python 编程的新一代来说,抓个包估计是不在话下,更别提浸淫网络多年的“黑客”了。是时候跑步进入 HTTPS 加密时代的了。

HTTPS 为什么安全

上文已经有提到,HTTPS 就是 HTTP + SSL or TLS ,除了 HTTPS 传标准严格和规范外,主要是 SSL 或者 TLS 对传的信息有一整套的加解密和校验方案。这套方案主要从下面三个方面确保传的安全。

1. 身份认证

传之前首先通过数字证书来确认身份,各大 CA 厂商干的就是这个事情。这里涉及到一个名词:数字证书。数字证书分为公钥和私钥,CA 厂商会用自己的私钥来给证书申请者签发一套包含私钥和公钥的客户证书,客户的公钥证书谁都可以获取,里面包含了客户站点和证书的基本信息,用来确保访问者访问的就是他想要访问的站点。

这个证书不可以伪造吗?答案是真的不可以。

原因一:系统早已内置了各大 CA 厂商的公钥来校验证书是否是对应的站点的证书,如果不是,就会给出证书不匹配的提示,除非你给别人的设备强行植入假的 CA 公钥。

原因二:这个证书是 CA 厂商通过哈希并加密得到的,基本无法逆向破解并伪造一个新的,除非是你黑进 CA 获取了 CA 的私钥,那这家 CA 也基本可以倒闭了。

2. 数据保密

数据保密包括对话秘钥传时候的保密和数据的加密传送。

对话秘钥:以 TLS 1.2 使用的套件之一 DHE-RSA-AES256-SHA256 为例:该套件是以 DHE 、RSA 作为秘钥交换算法,这两种秘钥交换算法都是使用的非对称加密,数学原理分别依赖于计算离散对数的难度和大数分解的难度。

也就是在建立 HTTPS 链接的过程中,刚开始是有一些明文出现的,不过想要根据这些已知的明文推算出“对话秘钥”却非常困难。

对话加密:客户端和和服务端协商并成功获取到对话秘钥后就开始用对话秘钥进行对称加密会话,上面的套件我们可以看到使用的是 AES256 加密算法。

那么为什么“对话秘钥”的交换使用非对称加密,正式对话数据的传使用对称加密?因为非对称加密虽然安全性比较高,但是它的效率比较低,速度比较慢,所以我们一般只使用它们来交换一下对话秘钥,后面的对话加密则使用速度更快,效率更高的对称加密。

3. 数据完整

身份认证成功后,到了数据加密传的阶段,所有数据都以明文(HTTP)收发,只不过收发的是加密后的明文。这时候也遇到了一个问题,虽然中间人很难破解加密后的数据,但是如果他对数据进行了篡改,那该怎么办?

此时加密套件验证数据一致性的哈希算法就派上用场了,哈希算法有多种,比如 MD5 ,SHA1 或者 SHA2 等,上面举例的加密套件使用的是 SHA2 中的 SHA256 来对数据进行哈希计算。这样就使得任何的数据更改都会导致通信双方在校验时发现问题,进而发出警报并采取相应的措施。

以上主要从使用 HTTPS 的必要性及 HTTPS 能安全传的原理进行了简单的阐述,HTTPS 的实现不仅仅是网络技术的集中应用,底层还涉及到了大量的算法以及密码学的众多知识,小编也无法一下子概述完整(笑哭)。

另外,不论是 PFS,或是国际互联网组织正在推行的 HSTS 安全传协议,他们的主要目的就是避免中间人攻击,使信息在传过程中更安全,更快速

作者昵称:又拍云

好文打赏,给Ta鼓励
扫一扫用手机阅读本文
Tags:究竟  究竟是  竟是  是啥  这篇  这篇文章  文章  带你  快速  了解  
  • 相关搜索
图片推荐
    SEO排名因素之——被忽视的网站受众

    SEO排名因素之——被忽视的网站受众

    SEO 已经存在很多年了,内容为皇,外链为王的时代已经过去了。不是说内容和外链不重要,而是搜索引擎在发展,要想做出更大的效果必须进一步学习其他的知 识。我认为百度官方的权威资料是个非常好的切入点。百度
    技术派创业者必须克服的4大短板

    技术派创业者必须克服的4大短板

    初创互联网公司很多主导创业的都是技术出身,一方面是技术人员普遍关注新技术及产业变革,更容易发现创业机会,另一方面技术人员本身具备开发能力,能将自己的想法独立实现出来,这是其他工种的创业者望尘莫及的。技
    QQ和微信不再使用,手把手教你注销QQ及微信账号

    QQ和微信不再使用,手把手教你注销QQ及微信账号

    QQ号不想要了,换了以前只能让号荒废在那里,现在有了更好的解决方式,那就是可以把号注销了,那么怎么样才能注销QQ号呢?跟着小编来看看如何操作吧。需要注意的是,这里的注销并不是指退出账号,而是销户的意思
    站长工具:爱站、去查站长工具哪个更好?

    站长工具:爱站、去查站长工具哪个更好?

    站长工具、爱站、去查站长工具哪个更好?很多人都会问这个问题,在百度上一搜此类相关的问题一大把的。我自己在怀化网络公司从事网络工作的这几年每天一直都是在接触站长工具,收集的站长工具平台也比较多,个人感觉
    从360浏览器卸载体验看互联网用户的情感营销

    从360浏览器卸载体验看互联网用户的情感营销

    谈起目前拥有大量用户的360浏览器大家都十分熟悉,但不知道大家有没有注意到,360浏览器都有哪些优点而受广大用户的喜欢,当然除了浏览器本身的功能之外,是否还有其他值得我们学习和借鉴的地方。下图是360
    如何从一个想法变成靠谱的创业项目

    如何从一个想法变成靠谱的创业项目

    大部分的创业想法一开始都是十分不靠谱的,都是满怀对理想中的未来充满瞳景,觉得所有人未来应该是这样,客户对这个需求庞大甚至超出预估值,自己找到了新蓝海,自己在改变世界,那么理想与现实差距到底有多大呢?这
    企业找代运营不得不知的秘密

    企业找代运营不得不知的秘密

    一直以来都是建议大家不要找代运营公司,只有企业自己参与进来,投入时间,精力和情感,才是真正的互联网营销。你不投入时间、精力和情感,那么互联网营销一定玩不好。守护袁昆今天和大家谈谈代运营的那点事。  互
    微信营销:内容运营的八种风格 时刻关注使用微信的人

    微信营销:内容运营的八种风格 时刻关注使用微信的人

    最近网上有很多关于微信营销的文章,有唱盛的,有唱衰的,我还是那句话,你没听说的没看到过的,并不代表没有发生过,不管别人如何说,我还是会继续把大鸟说微信营销系列文章写完。  另外微信营销是个技术活,不是
你是怎么知道非凡网赚网的?
  •   
  • 联系QQ 邮箱:976382653@qq.com 微信:976382653
    在线留言
    发布软文
    广告自助购
    文章调用
    常见问题
    保存到桌面