1)HTTP的缺点

通信使用明文(不加密),内容可能会被窃听

不验证通信方的身份,因此有可能遭遇伪装

无法证明报文的完整性,所有有可能已被篡改

1.1 通信使用明文可能会被窃听

由于HTTP本身不具备加密的功能,所以无法做到对通信整体进行加密。HTTP报文使用明文方式发送

TCP/IP协议族的工作机制,通信内容在所有的通信线路上都有可能遭到窥视

加密处理防止被窃听:加密的对象如下

通信加密

将通信加密。可以通过和SSL(安全套接层)或TLS(安全传输层协议)的组合使用,加密HTTP的通信内容。与SSL组合使用的HtTP被称为HTTPS(超文本传输安全协议)

内容加密

对通信内容(报文主体)进行加密,客户端对HTTP报文进行加密处理后再进行发送请求。前提需客户端和服务器端都有加密和解密功能。(但仍有被篡改的风险)

1.2 不验证通信方的身份可能遭遇伪装

HTTP协议中的请求或响应不会对通信方进行确认。也就是“服务器是否就是发送请求中URI真正指定的主机”,“返回的响应是否真的到实际提出请求的客户端”等问题

任何人都可以发起请求

服务器接收到请求,不管对方是谁都会返回一个响应(仅限于发送端的IP和端口没有被Web服务器设定限制访问的前提下)

因此在不确认通信,会存在以下各种隐患

①.无法确定请求发送至目标的Web服务器是否是按真实意图返回响应的那台服务器。有可能是已伪装的Web服务器

②.无法确定响应返回到客户端是否是按真是意图接收响应的那个客户端,有可能是已伪装的客户端。

③.无法确定正在通信的对方是否具备访问权限。

④.无法判定请求时来自何方、出自谁手。

⑤.即使是无意义的请求也会照单全收。无法阻止海量请求下的DoS攻击(拒绝服务器攻击)

1.3 无法证明报文完整性,可能已被篡改

完整性指信息的准确度。若无法证明其完整性,意味着无法判断信息是否准确。

没有办法确认,发出请求/响应与接收到的请求/响应是前后相同的。

请求或响应在传输途中,遭到攻击者拦截并篡改内容的攻击称为中间人攻击

防止篡改:常用MD5和SHA-1等散列值校验的防范,以及用来确认文件的数字签名方法

2)HTTP+加密+认证+完整性保护=HTTPS

通常把添加了加密处理和认证等机制的HTTP称为HTTPS

2.1 https相当身披SSL外壳的HTTP

https并非是一种新的应用层协议,只是HTTP通信接口部分用SSL和TLS协议代替。

通常,http直接和TCP通信。当使用SSL时,则变成了先和SSL通信,再由SSL和TCP通信了。

SSL是独立于HTTP的协议,其他应用层协议也可以配合SSL进行使用

2.2 加密技术

SSL采用一种叫做公开秘钥加密的加密处理方式。加密方法中加密算法是公开的,但秘钥是保密的。通过这种方式得以保持加密方法安全性

共享加密

加密和解密通用一个秘钥的方式称为共享加密,也被叫做对称秘钥加密。

以共享加密方式加密时必须将秘钥也发给对方。可究竟怎么才能安全的转交?

公开秘钥加密

公开秘钥加密使用一对非对称的秘钥。一把叫做私有秘钥。另一把叫做公开秘钥。

发送密文的一方使用对方的公开秘钥进行加密,对方收到信息后,使用自己的私有秘钥进行解密。(理论上可以破解,实际很难)

HTTPS采用混合加密机制

HTTPS采用共享秘钥加密和公开秘钥加密两者并用的混合加密机制。若秘钥不能够实现安全交换,那么考虑仅使用公开秘钥加密来通信。但是公开秘钥加密比共享秘钥加密处理速度要慢。

充分利用两者各自的优势,组合起来用于通信。在交换秘钥环节使用公开秘钥加密方式(交换稍后共享秘钥加密中要使用秘钥)。之后的建立通信交换报文阶段则使用共享秘钥加密方式

2.3 证书

在使用公开秘钥加密的时候,如何证明收到的公开秘钥是原来那台服务器发行的公开秘钥

为了解决上诉问题,使用由数字证书认证机构和其他相关机关颁发的公开秘钥证书

数字证书认证机构是处于客户端与服务器双方都可信赖的第三方机构。对通过申请的服务器公开秘钥做数字签名,将已签名的公开秘钥放入公钥证书后绑定在一起。服务器会将这份公钥证书传给客户端,以进行公开秘钥加密方式通信。

收到证书的客户端可使用数字证书认证机构的公开秘钥,对那张证书上的数字签名进行验证,验证通过后

①.认证服务器的公开秘钥是真实有效的数字证书认证机构

②.服务器的公开秘钥是值得信赖的

证书的作用

①.证明作为通信一方的服务器是否规范

②.确认对方服务器背后运营的企业是否真实存在。拥有该特性的证书是EV SSL证书(浏览器地址栏会是绿色背景显示)

ps:但是这都是建立在认证机构的信誉之上,2011年7月,荷兰的一名叫做DigiNotar的认证机构曾遭黑客不法入侵,办法了google.com和twitter.com等网站的伪造证书时间。撼动了SSL的可信度

2.4HTTPS的安全通信机制

①.客户端通过发送Client Hello报文开始SSL通信。报文中包含客户端支持的SSL的指定版本、加密组件列表(所使用的加密算法及秘钥长度等)

②.服务器可进行SSL通信时,会以Server Hello报文作为应答。和客户端一样。在报文中包含SSL版本以及加密组件。服务器的加密组件内容是从接收到的客户端加密组件内筛选出来的。

然后服务器发送Certificate报文。报文中包含公开秘钥证书。

最后服务器发送Server Hello Done报文通知客户端,最初阶段的SSL握手协商结束。

③.SSL第一次握手结束之后,客户端以Client Key Exchange报文作为回应。报文中包含通信加密中使用的一种被称为Pr-master secret的随机密码串。该报文已用步骤三中的公开秘钥进行加密

接着客户端继续发送Change Cipher Spec报文。该报文会提示服务器,在此报文之后的通信会采用Pre-master secret秘钥加密

客户端发送Finished报文。该报文包含连接至今全部报文的整体校验值,这次握手协商是否能够成功,要以服务器是否能够正确解密该报文作为判断标准。

④.服务器同样发送Change Cipher Spec报文。

服务器同样发送Finished报文

⑤.服务器和客户端的Finished报文交换完毕之后,SSL连接就算建立完成。通信收到SSL保护。开始发送http请求

⑥.最后由客户端断开连接。并发送close_notify报文。再发送TCP FIN报文来关闭与TCP的通信

在上面通信流程中,应用层发送数据时会附件一种叫做MAC的报文摘要。可查知报文是否遭到篡改,保护报文完整性

流程图(使用服务器端的公开秘钥证书建立HTTPS通信的整个过程)

使用HTTPS时,和HTTP相比速度会变慢。这里慢分两种,一种是通信慢。另一种是处理慢

通信慢:因为必须进行SSL通信,网路负载会变慢2到100倍

处理慢:因为需要加密和解密运算处理,消耗更多的服务器和客户端的硬件资源,导致负载增强。

使用SSL加速器这种专用服务器来改善该问题,为SSL通信专用硬件,提高数倍SSL计算速度。仅在SSL处理时发挥SSL加速器的功效,以负担负载。

HTTP协议12-HTTPS的更多相关文章

  1. 网络协议 13 - HTTPS 协议:加密路上无尽头

    系列文章传送门: 网络协议 1 - 概述 网络协议 2 - IP 是怎么来,又是怎么没的? 网络协议 3 - 从物理层到 MAC 层 网络协议 4 - 交换机与 VLAN:办公室太复杂,我要回学校 网 ...

  2. HTTP协议与HTTPS的区别

    permike 原文 HTTP协议与HTTPS的区别 HTTP协议 HTTP协议主要应用是在服务器和客户端之间,客户端接受超文本. HTTP是在七层网络模型中的应用层的协议,由发送请求和接受响应构成, ...

  3. http协议与https协议

    1.前言 在介绍 HTTP 协议之前,先简单说一下TCP/IP协议的相关内容.TCP/IP协议是分层的,从底层至应用层分别为:物理层.链路层.网络层.传输层和应用层,如下图所示: 2.http协议简介 ...

  4. ylbtech-协议-网络-安全协议:HTTPS

    ylbtech-协议-网络-安全协议:HTTPS HTTPS(全称:Hyper Text Transfer Protocol over Secure Socket Layer 或 Hypertext ...

  5. 03 HTTP协议与HTTPS协议

    一.HTTP协议 1.官方概念: HTTP协议是Hyper Text Transfer Protocol(超文本传输协议)的缩写,是用于从万维网(WWW:World Wide Web )服务器传输超文 ...

  6. 安全超文本传输协议(HTTPS)详解

    一.概念与摘要 HTTPS (Secure Hypertext Transfer Protocol)安全超文本传输协议,是一个安全通信通道,它基于HTTP开发用于在客户计算机和服务器之间交换信息.它使 ...

  7. 【转】SSL协议、SET协议、HTTPS简介

    一.SSL协议简介 SSL是Secure Socket Layer的缩写,中文名为安全套接层协议层.使用该协议后,您提交的所有数据会首先加密后,再提交到网易邮箱,从而可以有效防止黑客盗取您的用户名.密 ...

  8. HTTP协议与HTTPS协议区别

    HTTPS(Secure Hypertext Transfer Protocol)安全超文本传输协议:   它是一个安全通信通道,它基于HTTP开发,用于在客户计算机和服务器之间交换信息,它使用安全套 ...

  9. 【HTTP协议】---HTTPS协议

    HTTPS协议 一.为什么需要https 1.HTTP是明文传输的,也就意味着,介于发送端.接收端中间的任意节点都可以知道你们传输的内容是什么.这些节点可能是路由器.代理等. 举个最常见的例子,用户登 ...

  10. #WEB安全基础 : HTTP协议 | 0x16 HTTPS:加密的秘密

    公开秘钥加密&&共享秘钥加密 这两个冗长的短语,让我拿什么理解? 我们知道HTTPS有加密功能,以上的两个短语很常用.先摆在这,接下来开始尝试理解它们. 共享秘钥加密(对称秘钥加密): ...

随机推荐

  1. Linux命令(五)创建文件或修改文件时间 touch

    Linux中 touch 命令可以改变文档或目录时间, 包括存取时间或更改时间, 也可以用于创建新文件. 命令格式: touch [选项] [参数] 选项: -a   只更改文件的读取时间. -m   ...

  2. CMS Collector and G1 Collector

    Understanding the CMS Collector CMS has three basic operations: CMS collects the young generation (s ...

  3. Building Forms with PowerShell – Part 1 (The Form)

    For those of you familiar with Scripting languages you are probably used to using alternate applicat ...

  4. pymysql模块

    一.pymysql模块 1.说明: 想在python代码中连接上mysql数据库,就需要使用pymysql模块, pymysql是在 Python3.x 版本中用于连接 MySQL 服务器的一个库,在 ...

  5. 4.6 并发编程/IO模型

    并发编程/IO模型 背景概念 IO模型概念 IO模型分类 阻塞IO  (blocking IO) 特点: 两个阶段(等待数据和拷贝数据两个阶段)都被block 设置 server.setsockopt ...

  6. 使用js获取页面参数

    方法一 function GetUrlParam (name) { return decodeURIComponent((new RegExp('[?|&]' + name + '=' + ' ...

  7. [NOI2018]屠龙勇士

    题目描述 题解 考虑增量法. 假设我们已经做完了前k个条件,前面的模数连乘起来的结果为M,答案为X,当前的攻击力为x,龙的血量为a. 那么我们这一次的答案的表达形式是X+t*M的. 这一次需要满足的是 ...

  8. CF809E Surprise me!(莫比乌斯反演+Dp(乱搞?))

    题目大意: 给你一棵树,树上的点编号为\(1-n\).选两个点\(i.j\),能得到的得分是\(\phi(a_i*a_j)*dis(i,j)\),其中\(dis(i,j)\)表示\(a\)到\(b\) ...

  9. nuxt.js实战之window和document对象的使用

    在开发nuxt项目的时候,我们难免会使用到document来获取dom元素.如果直接在文件中使用就会报错.这是因为document是浏览器端的东西服务端并没有. 解决方法: 我们只需要在使用的地方通过 ...

  10. python之路day05--字典的增删改查,嵌套

    字典dic 数据类型划分:可变数据类型,不可变数据类型 不可变数据类型:元组,bool,int str -->可哈希可变数据类型:list,dict,set --> 不可哈希 dict k ...