一篇读懂HTTPS:加密原理、安全逻辑、数字证书等
本文原作者“安静的boy”,原文标题:《一篇文章读懂HTTPS及其背后的加密原理》,收录时有改动,感谢原作者。
1、引言
HTTPS(全称: Hypertext Transfer Protocol Secure,超文本传输安全协议),是以安全为目标的HTTP通道,简单讲是HTTP的安全版。本文,就来深入详情下其原理。
补充:限于篇幅,本文对于https的相关技术要点的详情尽量简明扼要,如想要详细理解HTTPS的方方面面,请阅读《即时通讯安全篇(七):假如这样来了解HTTPS,一篇就够了》。
(本文同步发布于:http://www.52im.net/thread-2446-1-1.html)
2、相关文章
《即时通讯安全篇(七):假如这样来了解HTTPS,一篇就够了》
《一文读懂Https的安全性原理、数字证书、单项认证、双项认证等》
《HTTPS时代已来,打算升级你的HTTP服务了吗?》
《苹果即将强制实施 ATS,你的APP准备好切换到HTTPS了吗?》
《一分钟了解 HTTPS 究竟处理了什么问题》
3、为什么需要https
起因其实很简单:就是由于http不安全。
当我们往服务器发送比较隐私的数据(比方说你的银行卡,身份证)时,假如使用http进行通信。那么安全性将得不到保障。
首先数据在传输的过程中,数据可能被中间人抓包拿到,那么数据就会被中间人窃取。
其次数据被中间人拿到后,中间人可能对数据进行修改或者者替换,而后发往服务器。
最后服务器收到数据后,也无法确定数据有没有被修改或者替换,当然,假如服务器也无法判断数据就真的是来源于用户端。
总结下来,http存在三个弊端:
1)无法保证消息的保密性;
2)无法保证消息的完整性和精确性;
3)无法保证消息来源的可靠性。
https就是为理解决上述问题应运而生的。
4、基本概念:加密技术、数字证书和数字签名
为理解决http中存在的问题,https采用了少量加解密,数字证书,数字签名的技术来实现。下面先详情一下这些技术的基本概念。
4.1 对称加密与非对称加密
为了保证消息的保密性,就需要用到加密和解密。加解密算法目前主流的分为对称加密和非对称加密。
(4.1.1)对称加密(共享密匙加密):
用户端和服务器公用一个密匙用来对消息加解密,这种方式称为对称加密。用户端和服务器商定好一个加密的密匙。用户端在发消息前用该密匙对消息加密,发送给服务器后,服务器再用该密匙进行解密拿到消息。
对称加密的优点:对称加密处理了http中消息保密性的问题
对称加密的缺点:对称加密尽管保证了消息保密性,但是由于用户端和服务器共享一个密匙,这样就使得密匙特别容易泄露。
由于密匙泄露风险较高,所以很难保证消息来源的可靠性、消息的完整性和精确性。
(4.1.2)非对称加密(公有密匙加密):
既然对称加密中,密匙那么容易泄露,那么我们可以采用一种非对称加密的方式来处理。
采用非对称加密时,用户端和服务端均拥有一个公有密匙和一个私有密匙。公有密匙可以对外暴露,而私有密匙只有自己可见。
使用公有密匙加密的消息,只有对应的私有密匙才能解开。反过来,使用私有密匙加密的消息,只有公有密匙才能解开。这样用户端在发送消息前,先用服务器的公匙对消息进行加密,服务器收到后再用自己的私匙进行解密。
非对称加密的优点:
1)非对称加密采用公有密匙和私有密匙的方式,处理了http中消息保密性问题,而且使得私有密匙泄露的风险降低;
2)由于公匙加密的消息只有对应的私匙才能解开,所以较大程度上保证了消息的来源性以及消息的精确性和完整性。
非对称加密的缺点:
1)非对称加密时需要使用到接收方的公匙对消息进行加密,但是公匙不是保密的,任何人都可以拿到,中间人也可以。那么中间人可以做两件事,第一件是中间人可以在用户端与服务器交换公匙的时候,将用户端的公匙替换成自己的。这样服务器拿到的公匙将不是用户端的,而是服务器的。服务器也无法判断公匙来源的正确性。第二件是中间人可以不替换公匙,但是他可以截获用户端发来的消息,而后篡改,而后用服务器的公匙加密再发往服务器,服务器将收到错误的消息;
2)非对称加密的性能相对对称加密来说会慢上几倍甚至几百倍,比较消耗系统资源。正是由于如此,https将两种加密结合了起来。
4.2 数字证书与数字签名
为理解决非对称加密中公匙来源的不安全性。我们可以使用数字证书和数字签名来处理。
(4.2.1)数字证书的申请:
在现实中,有少量专门的权威机构用来颁发数字证书,我们称这些机构为认证中心(CA Certificate Authority)。
我们(服务器)可以向这些CA来申请数字证书。
申请的过程大致是:
1)自己本地先生成一对密匙,而后拿着自己的公匙以及其余信息(比方说企业名称啊什么的)去CA申请数字证书。
2)CA在拿到这些信息后,会选择一种单向Hash算法(比方说常见的MD5)对这些信息进行加密,加密之后的东西我们称之为摘要:
单向Hash算法有一种特点就是单向不可逆的,只需原始内容有一点变化,加密后的数据都将会是千差万别(当然也有很小的可能性会重复,有兴趣的小伙伴鸽巢原理理解一下),这样就防止了信息被篡改。
3)生成摘要后还不算完,CA还会用自己的私匙对摘要进行加密,摘要加密后的数据我们称之为数字签名。
4)最后,CA将会把我们的申请信息(包含服务器的公匙)和数字签名整合在一起,由此而生成数字证书。
5)而后CA将数字证书传递给我们。
(4.2.2)数字证书怎样起作用:
服务器在获取到数字证书后,服务器会将数字证书发送给用户端,用户端就需要用CA的公匙解密数字证书并验证数字证书的合法性。那我们如何能拿到CA的公匙呢?我们的电脑和浏览器中已经内置了一部分权威机构的根证书,这些根证书中包含了CA的公匙。
之所以是根证书,是由于现实生活中,认证中心是分层级的,也就是说有顶级认证中心,也有下面的各个子级的认证中心,是一个树状结构,计算机中内置的是最顶级机构的根证书,不过不用担心,根证书的公匙在子级也是适用的。
用户端用CA的公匙解密数字证书,假如解密成功则说明证书来源于合法的认证机构。解密成功后,用户端就拿到了摘要。
此时,用户端会按照和CA一样的Hash算法将申请信息生成一份摘要,并和解密出来的那份做比照,假如相同则说明内容完整,没有被篡改。最后,用户端安全的从证书中拿到服务器的公匙即可以和服务器进行安全的非对称加密通信了。服务器想取得用户端的公匙也可以通过相同方式。
下图用图解的方式说明一般的证书申请及其使用过程:
5、https的工作原理
通过上面的学习,我们理解对称加密与非对称加密的特点和优缺点,以及数字证书的作用。https没有采用单一的技术去实现,而是根据他们的特点,充分的将这些技术整合进去,以达到性能与安全最大化。这套整合的技术我们称之为SSL(Secure Scoket Layer 安全套接层)。
所以https并非是一项新的协议,它只是在http上披了一层加密的外壳。?
先看一下https连接的建立流程图:
如上图所,这里把https连接建立到断开分为6个阶段,12过程。
下面将对12个过程一 一做解释:
1)用户端通过发送Client Hello报文开始SSL通信。报文中包含用户端支持的SSL的指定版本、加密组件(Cipher Suite)列表(所使用的加密算法及密匙长度等);
2)服务器可进行SSL通信时,会以Server Hello报文作为应答。和用户端一样,在报文中包含SSL版本以及加密组件。服务器的加密组件内容时从接收到的用户端加密组件内挑选出来的;
3)服务器发送证书报文。报文中包含公开密匙证书;
4)最后服务器发送Server Hello Done报文通知用户端,最初阶段的SSL握手协商部分结束;
5)SSL第一次握手结束之后,用户端以Client Key Exchange报文作为回应。报文包含通信加密中使用的一种被称为Pre-master secret的随机密码串。该报文已用步骤3中的公开密匙进行加密;
6)接着用户端继续发送Change Cipher Spec报文。该报文会提醒服务器,在此报文之后的通信会采用Pre-master secret密匙加密;
7)用户端发送Finished报文。该报文包含连接至今一律报文的整体校验值。这次握手协商能否能够成功,要以服务器能否能够正确解密该报文作为判定标准;
8)服务器同样发送Change Cipher Spec报文;
9)服务器同样发送Finished报文;
10)服务器和用户端的Finished报文交换完毕之后,SSL连接就算建立完成。当然,通信会收到SSL的保护。从此处开始进行应用层协议的通信,即发送HTTP请求;
11)应用层协议通信,即发送HTTP相应;
12)最后由用户端断开连接。断开连接时,发送close_notify报文。上图做了少量省略,这步之后再发送TCP FIN报文来关闭与TCP的通信。
另外,在以上流程图中,应用层发送数据时会附加一种叫做MAC(Message Authentication Code)的报文摘要。MAC能够查知报文能否遭到篡改,从而保证报文的完整性。
下面再用图解来形象的说明一下,此图比上面数字证书的图更加的详细少量(图片来源于《图解HTTP》):
经过上面的详情,我们可以看出https先是利用数字证书保证服务器端的公匙可以安全无误的到达用户端。而后再用非对称加密安全的传递共享密匙,最后用共享密匙安全的交换数据。
6、肯定要用https吗?
https那么的安全,是不是我们在什么场景下都要去使用https进行通信呢?答案能否定的。
1)https尽管提供了消息安全传输的通道,但是每次消息的加解密十分耗时,消息系统资源。所以,除非在少量对安全性比较高的场景下,比方银行系统,购物系统中我们必需要使用https进行通信,其余少量对安全性要求不高的场景,我们其实没必要使用https。
2)使用https需要使用到数字证书,但是一般权威机构颁发的数字证书都是收费的,而且价格也是不菲的,所以对于少量个人网站特别是学生来讲,假如对安全性要求不高,也没必要使用https。
7、参考资料
[1]?浅显了解数字签名,数字证书和https
[2]一个故事讲完https
[3]?图解HTTP
附录:更多安全方面的文章
《即时通讯安全篇(一):正确地了解和使用Android端加密算法》
《即时通讯安全篇(二):讨论组合加密算法在IM中的应用》
《即时通讯安全篇(三):常用加解密算法与通讯安全讲解》
《即时通讯安全篇(四):实例分析Android中密钥硬编码的风险》
《即时通讯安全篇(五):对称加密技术在Android平台上的应用实践》
《即时通讯安全篇(六):非对称加密技术的原理与应用实践》
《即时通讯安全篇(七):用JWT技术处理IM系统Socket长连接的身份认证痛点》
《传输层安全协议SSL/TLS的Java平台实现简介和Demo演示》
《理论联络实际:一套典型的IM通信协议设计详解(含安全层设计)》
《微信新一代通信安全处理方案:基于TLS1.3的MMTLS详解》
《来自阿里OpenIM:打造安全可靠即时通讯服务的技术实践分享》
《简述实时音视频聊天中端到端加密(E2EE)的工作原理》
《手机端安全通信的利器——端到端加密(E2EE)技术详解》
《Web端即时通讯安全:跨站点WebSocket劫持漏洞详解(含示例代码)》
《浅显易懂:一篇掌握即时通讯的消息传输安全原理》
《IM开发基础知识补课(四):正确了解HTTP短连接中的Cookie、Session和Token》
《快速读懂量子通信、量子加密技术》
《即时通讯安全篇(七):假如这样来了解HTTPS原理,一篇就够了》
《一分钟了解 HTTPS 究竟处理了什么问题》
《一篇读懂HTTPS:加密原理、安全逻辑、数字证书等》
>>?更多同类文章 ……
(本文同步发布于:http://www.52im.net/thread-2446-1-1.html)
1. 本站所有资源来源于用户上传和网络,如有侵权请邮件联系站长!
2. 分享目的仅供大家学习和交流,您必须在下载后24小时内删除!
3. 不得使用于非法商业用途,不得违反国家法律。否则后果自负!
4. 本站提供的源码、模板、插件等等其他资源,都不包含技术服务请大家谅解!
5. 如有链接无法下载、失效或广告,请联系管理员处理!
6. 本站资源售价只是摆设,本站源码仅提供给会员学习使用!
7. 如遇到加密压缩包,请使用360解压,如遇到无法解压的请联系管理员
开心源码网 » 一篇读懂HTTPS:加密原理、安全逻辑、数字证书等