【转】网络安全——一图看懂HTTPS创建过程

阅读目录html

关于网络安全加密的介绍能够看以前文章:算法

1. 网络安全——数据的加密与签名,RSA介绍
2. Base64编码、MD五、SHA1-SHA5十二、HMAC(SHA1-SHA512)
3. When I see you again(DES、AES、RSA、Base6四、MD5加密原理介绍,代码实现)编程

HTTPS创建过程至关复杂,下图为示意图,能够有总体认识,通常咱们编程知道这些已足够。浏览器

https创建过程

若是你想仿照HTTPS实现相似加密,能够阅读下具体过程,做为参照缓存

准备工做(对应图中prepare1234)

能够看到,在客户端向服务器发起请求前,还有一些准备工做要作,或者说是有一些工做已经作好了。安全

  • 从CA证书颁发机构,获取数字证书。
    • 服务器:生成一对公私钥S.pub,S.pri,私钥本身保留,用于解密和签名,不能外泄。将公钥S.pub,身份信息,传给CA(Certificate Authority)机构;
    • CA机构:也有公私钥C.pub,C.pri;由S.pub,身份信息另外附加CA签名生成数字证书(签名使用C.pri进行签名)
    • 将数字证书颁发给申请者(服务器)
  • 客户端(好比咱们常用的浏览器),为了安全性,会内置一份CA根证书,它包含公钥C.pup,用于对数字证书验证

发起连接

https使用的是443端口,而http使用的是80端口服务器

TCP端口号是一个2字节的整型,处于TCP报文段的前四个字节(2字节源端口号,2字节目的端口号)。网络

很明显范围是0~65535。其中0~1023具备特殊意义,已经被绑定,好比上面说的443,80,还有ftp的21端口。从1024~49151也具备特殊含义,可是尚未被用完,好比8080端口重定向。剩下的咱们就能够随便使用,自定义了。session

其实以前在嵌入式开发中,没有链接外网,也没有使用浏览器等等这些。因此端口彻底自定义随便用,不用担忧冲突:)。dom

下面的过程为具体详细一点的过程,若是不想看,能够彻底只看示意图便可,对咱们平时开发用处并不大。或者你在用wireshark相似的抓包工具时看的抓狂不认识,能够看看(反正我用Charles抓包):

1 客户端发起请求(对应图中1)

一样须要三次握手,创建TCP链接(毫无疑问HTTPS也是基于TCP的)

2 客户端发送Client Hello包(对应图中2)

  • 随机数

里面有1970年1月1日到如今的秒数,后面还有一个客户端发来的随机数Client.random

  • Session ID

若是客户端与服务器费尽周折创建了一个HTTPS连接,刚建完就断了,也太惋惜,因此用Session ID将其保存,若是下次再来能够直接使用以前的连接进行对话(对称密钥)。

  • 密文族

告诉服务器,本身支持的加密算法种类

  • Server_name

3 Server Hello(对应图中2)

  • 随机数:对应服务器时间,服务器sever.random
  • Seesion ID,若是客户端发给服务器的session ID在服务端有缓存,服务端会尝试使用这个session;不然服务器会启用新的并返回给客户端;
  • 服务器挑选一个密文族

4 Certificate(对应图中2)

服务器终于发来咱们想要的数字证书,包含了:签发机构、过时时间、主题名称、公共密钥信息、指纹信息等等

证书信息

5 Server Hello Done(对应图中2)

服务器发送结束

6 客户端验证(对应图中3)

客户端从内置的CA根证书获取C.pub,对服务器发送来的数字证书进行验签,若是一致,说明证书是CA颁发的(前提是C.pub是真实的,确实是CA机构的公钥)。而后看看证书是否过时,域名是否匹配

7 生成对称密钥(对应图中四、五、6)

客户端根据以前的:Client.random + sever.random + pre-master生成对称密钥

通过S.pub加密发送给服务器,以后便可经过对称密钥进行通信。(就是以前咱们熟悉的http)

最后

在整个过程当中,一共涉及2对公私密钥对,一对由服务器产生,主要用于加密,一对由CA产生,主要用于签名。

为何要多一个CA呢?

假设没有CA,那么若是服务器返回的包含公钥的包被hack截取,而后hack也生成一对公私钥,他将本身的公钥发给客户端。hack获得客户端数据后,解密,而后再经过服务器的公钥加密发给服务器,这样数据就被hack获取。

有了CA后,客户端根据内置的CA根证书,很容易识别出hack的公钥不合法,或者说hack的证书不合法。

from:http://www.cnblogs.com/mddblog/p/6948980.html

相关文章
相关标签/搜索