HTTPS协议的原理和与HTTP协议的区别

HTTPS协议是什么

    https协议比http协议多了一个s,字面意思上s=secure(安全)。它跟http协议一样都是应用层协议,都是工作在TCP协议之上。

    只不过https协议在传输过程中的数据都是经过了加密。本质上HTTPS协议就是在TCP协议之上又加了一层SSL协议来实现了加密这个操作(不准确的说HTTPS就就是披着是SSL的皮的HTTP协议)

HTTPS和HTTP的区别

  • HTTP协议工作在80端口,HTTPS协议工作在443端口
  • HTTPS需要申请证书(用于验证服务器身份)
  • HTTP在TCP三次握手建立连接之后即可开始传输数据;HTTPS协议则需要在建立TCP连接之后客户端与服务器在进行SSL加密,确定对话密钥,完成加密后才开始传输数据。
  • HTTPS协议传输是密文,HTTP协议传输是明文

大致的区别就以上4点,其实最主要的就是SSL协议加密对话产生对话密钥的过程

在了解具体的SSL协议之前,先要了解两个加密概念

对称加密

    同一个密钥可以同时用作信息的加密和解密,这种加密方法称为对称加密,也被叫做共享密钥加密。这种方法在网络传输中有个问题,就是如何把密钥安全的交付给对方,因为http协议是明文传输(https协议在建立ssl加密时都是明文传输),所以密钥很容易被监听截取,从而失去密钥本身的意义了。

公开密钥加密

    假设使用者为服务端,服务端有两个密钥,一个是私钥(只能自己悄悄咪咪看的,可以比喻成钥匙),一个是公钥(随便哪个看的都行,可以比喻成锁头)。服务端将公钥发给客户端,客户端使用公钥对要发送的信息进行加密,然后发送给服务器(用锁头把数据锁在箱子里),由于该信息是通过服务端的公钥进行加密的,只有服务端使用自己的私钥才能解析出来(用钥匙打开锁头,获取信息)。因为私钥是一直保持在服务端,而又只有私钥才能解析出公钥加密的内容,所以通过该种方法实现了数据的安全传输。

    但是由于每次都要使用私钥去解析公钥,才能获取到数据,如果公钥很长的话,其中的运算量会很大,占用CPU性能,从而使得网络延迟加大。

HTTPS协议同时使用了这两种方式,即先通过公开密钥加密的方式产生一个对话密钥,在使用对话密钥进行对称加密的方式传输数据。

SSL协议

  1. 客户端向服务器发送请求

    请求中包含

     支持的SSL协议版本
     客户端生成的随机数(第一个随机数)
     支持的加密方法
     支持的压缩方法
    
  2. 服务器接收到客户端请求,并且向客户端发送响应
    响应包括

    确认协议版本
    服务器生产的随机数(第二个随机数)
    确定加密的方法
    服务器的证书(服务器的公钥在里面)
    
  3. 客户端接收到请求,对证书进行校验(校验证书的颁布机构,证书中的域名和实际域名是否一致,证书是否过期,如果不符合,浏览器会显示警告),如果通过了校验,客户端将会发送回应
    请求包括

    客户端生成一个随机数,并且该随机数通过服务器的公钥进行加密(第三个随机数)
    编码改变通知(表示之后的通信都会通过双方商定的加密算法进行通信)
    客户端握手结束通知,表示客户端的握手阶段已经结束。这一项同时也是前面发送的所有内容的hash值,用来供服务器校验。
    
  4. 服务器接收到最后的回应之后,使用服务器的私钥来解析出客户端发送过来的第三个随机数,并且使用与客户端约定好的加密算法将一共三个随机数生成对话密钥。服务器返回响应

    编码改变通知(表示之后的通信都会通过双方商定的加密算法进行通信)
    服务器握手结束通知,表示服务器的握手阶段已经结束。这一项同时也是前面发送的所有内容的hash值,用来供客户端校验。
    

    整个SSL协议的加密过程大致就是这样,加密对话的过程都是明文传输的(因为HTTPS还没带搭建起来的嘛)。

    整个加密过程的核心就是客户端与服务器产生的三个随机数,这三个随机数是用于产生后续数据传输的加密密钥的。从上面的过程可以看出,这三个随机数都是可以别窃取的,但是由于第三个随机数使用了服务器的公钥进行了公开密钥加密传输,理论上只有使用服务器的私钥才能解析出第三个随机数。所以最后使用这三个随机数生成的对话私钥是安全的,之后的数据传输都会使用这个对话私钥进行加密(对称加密),从而保证了传输的安全性又保证了数据传输的效率。

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 216,591评论 6 501
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 92,448评论 3 392
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 162,823评论 0 353
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 58,204评论 1 292
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 67,228评论 6 388
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 51,190评论 1 299
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 40,078评论 3 418
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,923评论 0 274
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 45,334评论 1 310
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,550评论 2 333
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,727评论 1 348
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,428评论 5 343
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 41,022评论 3 326
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,672评论 0 22
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,826评论 1 269
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,734评论 2 368
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,619评论 2 354

推荐阅读更多精彩内容