1.HTTP需求背景

万维网(www)
• Http是一种网络协议,也是互联网上应用最为广泛的一种,http也叫超文本传输协议,所有的html文件都是遵循这个标准进行传输的。
• HTTP的出现是为了提供一种发布和接收HTML页面的办法。

HTTP概述

HTTP(Hypertext Transfer Protocol)中文 “超文本传输协议”,是一种为分布式,合作式,多媒体信息系统服务,面向应用层的协议,是Internet上目前使用最广泛的应用层协议,它基于传输层的TCP协议进行通信,HTTP协议是通用的、无状态的协议。

功能:用于在服务器和客户机之间传输超文本文件

HTTP工作原理 

• HTTP(Hypertext Transfer Protocol)中文 “超文本传输协议”,是一种为分布式,合作式,多媒体信息系统服务,面向应用层的协议,是Internet上目前使用最广泛的应用层协议,它基于传输层的TCP协议进行通信,HTTP协议是通用的、无状态的协议。
• URL即统一资源定位符(Uniform Resource Locator),用来唯一地标识万维网中的某一个文档。URL由协议、主机和端口(默认为80)以及文件名三部分构成。如:

• 功能:用于在服务器和客户机之间传输超文本文件

请求/响应交互模型
在用户点击URL为http://www.qq.com/index.html的链接后,浏览器和Web服务器执行以下动作:
1.浏览器分析超链接中的URL
2 .浏览器向DNS请求解析www.qq.com的IP地址
3.DNS将解析出的IP地址222.246.129.80返回浏览器HTTP over TCP
4.浏览器与服务器建立TCP连接(80端口)
5.浏览器请求文档:GET /index.html
6.服务器给出响应,将文档 index.html发送给浏览器
7.释放TCP连接
8.浏览器显示index.html中的内容

HTTP的连接方式和无状态性

1.非持久性连接
即浏览器每请求一个Web文档,就创建一个新的连接,当文档传输完毕后,连接就立刻被释放。

2.持久性连接
即在一个连接中,可以进行多次文档的请求和响应

3.无状态性
是指同一个客户端(浏览器)第二次访问同一个Web服务器上的页面时,服务器无法知道这个客户曾经访问过。HTTP的无状态性简化了服务器的设计,使其更容易支持大量并发的HTTP请求。

HTTPS需求背景 

随着网络通信的电子商务等服务和资源进入人们的生活,人们在享受网络带来的便利的同时,面临着各种各样的安全隐患。
传统的很多网站都是基于HTTP协议的。HTTP就是我们平时浏览网页时候使用的一种协议。HTTP协议传输的数据都是未加密的,也就是明文的,因此使用HTTP协议传输隐私信息非常不安全。为了保证这些隐私数据能加密传输,于是设计了SSL(Secure Sockets Layer)协议用于对HTTP协议传输的数据进行加密,从而就诞生了HTTPS。

HTTPS概述

功能介绍
• HTTPS(全称:Hyper Text Transfer Protocol over Secure Socket Layer)
• 是以安全为目标的HTTP通道,简单讲是HTTP的安全版。即HTTP下加入SSL层,HTTPS的安全基础是SSL,因此加密的详细内容就需要SSL。HTTPS存在不同于HTTP的默认端口及一个加密/身份验证层(在HTTP与TCP之间)。这个系统提供了身份验证与加密通讯方法。现在它被广泛用于万维网上安全敏感的通讯,例如交易支付方面。
• HTTP协议采用明文传输信息,存在信息窃听、信息篡改和信息劫持的风险,而协议TLS/SSL具有身份验证、信息加密和完整性校验的功能,可以避免此类问题,因此我们可以简单的认为HTTPS就是使用TLS/SSL加密的HTTP协议

HTTPS和HTTP的区别在哪里

• https协议需要到ca申请证书,一般免费证书很少,需要交费。
• http是超文本传输协议,信息是明文传输https则是具有安全性的ssl加密传输协议。
• http和https使用的是完全不同的连接方式,用的端口也不一样,前者是80,后者是443。
• http的连接很简单,是无状态的;HTTPS协议是由SSL+HTTP协议构建的可进行加密传输、身份认证的网络协议,比http协议安全。


HTTPS工作原理 

• SSL
    • SSL(Secure Socket Layer,安全套接字层),位于可靠的面向连接的网络层协议和应用层协议之间的一种协议层。SSL通过互相认证、使用数字签名确保完整性、使用加密确保私密性,以实现客户端和服务器之间的安全通讯。
该协议由两层组成:SSL记录协议和SSL握手协议。

• SSL协议的功能
   • 保证传输数据的 保密性
   • 保证传输数据的 完整性
   • 实现通信双方的互相 身份认证

SSL加密
•密码:对文本进行编码
•密钥:改变密码行为的数字化参数
• 对称密钥加密系统:编 / 解码使用相同密钥的算法
• 非对称密钥加密系统:编 / 解码使用不同密钥的算法
• 数字签名:用来验证报文未被伪造或篡改的校验和
• 数字证书(CA证书):由一个可信的组织验证和签发的识别信息

客户端先把自己拥有的一些算法一些加密的列表发给服务端,服务端收到完以后,从加密算法中挑选一个,而后双方达成一致,互相发送自己的证书,去做一个验证,协商验证。

对称加密:密钥A加密,密钥A解密,非对称加密:公钥A加密,私钥B解密

HTTPS工作原理(HTTP过程+SSL过程)

HTTPS在传输数据。握手过程的简单描述如下:
1.浏览器将自己支持的一套加密规则发送给网站。
2.网站从中选出一组加密算法与HASH算法,并将自己的身份信息以证书的形式发回给浏览器。证书里面包含了网站地址,加密公钥,以及证书的颁发机构等信息。
3.获得网站证书之后浏览器要做以下工作:
a) 验证证书的合法性
b) 生成一串随机数的密码,并用证书中提供的公钥加密。
c) 使用约定好的HASH计算握手消息,并使用生成的随机数对消息进行加密,最后将之前生成的所有信息发送给网站。

4.网站接收浏览器发来的数据之后要做以下的操作:
a) 使用自己的私钥将信息解密取出密码,使用密码解密浏览器发来的握手消息,并验证
HASH是否与浏览器发来的一致。
b) 使用密码加密一段握手消息,发送给浏览器。
5.浏览器解密并计算握手消息的HASH,如果与服务端发来的HASH一致,此时握手过程结束,之后所有的通信数据将由之前浏览器生成的随机密码并利用对称加密算法进行加密。

HTTP案例分析

案例:访问http://192.200.200.163抓包进行分析 ?

案例:访问https://www.baidu.com/网站抓包进行分析 ?

11.网络协议-HTTP及HTTPS协议相关推荐

  1. tomcat 将http协议改为https协议,Websocket请求ws协议修改为wss协议

    tomcat 将http协议改为https协议,Websocket请求ws协议修改为wss协议 一. 说明 WS协议和WSS协议两个均是WebSocket协议的SCHEM,两者一个是非安全的,一个是安 ...

  2. 网络(9)-HTTPS协议

    一.HTTPS的概念 HTTPS (全称:Hyper Text Transfer Protocol over SecureSocket Layer),是以安全为目标的 HTTP 通道,在HTTP的基础 ...

  3. 免费申请下载SSL证书与证书的安装部署教程,网站服务由网站由http协议升级为https协议

    文章目录 相关技术术语 SSL SSL证书 HTTPS 证书申请 证书安装 在Tomcat服务器安装SSL证书 示例使用 阿里云SSL证书服务 相关技术术语 SSL 安全套接层SSL(Secure S ...

  4. 云套件将http协议改为https协议

    作者:yangjl 最近很多使用云套件的小伙伴们想把http协议改为https的,但是目前imanager for k8s里面目前并未提供一键转换的功能,目前研发侧的同事正在完善此功能,争取尽快更新出 ...

  5. 给服务器弄了一个https协议,HTTP和HTTPS协议

    一.http和https的区别 1.http协议存在的问题 1)请求信息明文传输,容易被窃听截取. 2)数据的完整性未校验,容易被篡改 3)没有验证对方身份,存在冒充危险 2.https相对http协 ...

  6. 【基础协议】HTTP/HTTPS协议及其工作流程

    目录 1 HTTP协议与HTTPS协议 1.1 HTTP协议概述 1.2 HTTPS协议概述 1.3 HTTPS与HHTP区别 2 URI和URL相关知识 2.1 URI统一资源标识符 2.2 URL ...

  7. 网络篇 - https协议中的数据是否需要二次加密

    随着互联网整体的发展,https 也被越来越多的应用.甚至苹果去年还曾经放言要强制所有的 app 都使用 https,可见在如今的互联网它的重要性.前面的文章说了 OSI 七层模型,https 可以保 ...

  8. HTTPS协议原理分析

    HTTPS协议原理分析 HTTPS协议需要解决的问题 HTTPS作为安全协议而诞生,那么就不得不面对以下两大安全问题: 身份验证 确保通信双方身份的真实性.直白一些,A希望与B通信,A如何确认B的身份 ...

  9. 应用层协议:HTTP与HTTPS协议详解、二者的区别

    http协议详解 1.HTTP协议:超文本传输协议 是一种分布式.合作式.多媒体信息系统服务,面向应用层的协议.是一种通用的,不分状态的协议.是一种请求/应答协议. 1.1.HTTP/1.0和HTTP ...

最新文章

  1. 【Netty】Netty组件介绍
  2. DBA(三):MySQL主从同步、复制模式
  3. oracle字符串只截取中文,Oracle提取字符串中“汉字”串的解决办法
  4. 软件项目管理0710:招标文件准备【求助】
  5. WinForm登录模块设计开发
  6. BAT执行DOS命令查找本地浏览器
  7. Java生鲜电商平台-电商支付流程架构实战
  8. 第三:jenkins集成httpclient项目并生成在线报告(接口自动化落地)
  9. vs 2017 linux版本,vs2017 linux版
  10. Fortran的全局变量(Common blocks)
  11. (原创)巧用通道作颜色网
  12. 国家c语言计算机二级,国家计算机二级考试 C语言基本知识.pdf
  13. spring-security 实现单点登录
  14. 电脑无法显示计算机,U盘插在电脑无法显示盘符怎么办的解决办法
  15. oracle 的乘法,Oracle group by 相乘
  16. arduino密码锁代码
  17. VMware虚拟机安装Windows11(无需设置TMP密码)
  18. java 对Excel 操作 例子(下)
  19. 将windows下文件编码格式转换成UTF-8 文件编码格式
  20. 国产8mb psram推荐EMI108NA16LM

热门文章

  1. Excel表格解密大揭秘
  2. Nginx设置缓存过期时间
  3. Logistic回归做分类或预测(实战代码)
  4. 2018--8.30--招商银行信用卡IT方向--笔试
  5. WebRTC 系列(二、本地通话,H5、Android、iOS)
  6. android用户中心应用,腾讯应用中心触屏版上线 对Android开发者开放
  7. 【数据挖掘】FPgrowth算法笔记
  8. linux中文文件名长度ftp无法传输,上传ftp时文件名不能太长
  9. 黑龙江省齐齐哈尔市谷歌高清卫星地图下载
  10. 加多芬解析丨微信支付宝,两匹战狼之争,究竟谁能最终渔翁得利?