热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

Https协议

1、背景Https并不是一个新协议,只是在Http协议的基础上使用了TLSSSL协议。TLS是一种密码学协议,保障会话的相对安全;会话是由任意数量的消

1、背景

Https并不是一个新协议,只是在Http协议的基础上使用了TLS/SSL协议。TLS是一种密码学协议,保障会话的相对安全; 会话是由任意数量的消息组成的。有点网络常识的人都知道,Http在传输中使用的是明文的方式,中间方可以通过抓包的方式获取到报文,获取到传输的信息。这样的传输方式很明显在当下的网络环境不适用,那Https做了什么优化,让会话变得相对安全呢。


1.2、密码协议


1.2.1 对称加密

待补充


1.2.2 非对称加密

待补充


1.2.3 总结

Https的使用了上述两种加密方式,保证会话安全即加密消息。那么Https是如何通信的呢?我们借助OSI网络模型来进一步探索。


2、OSI 七层网络模型

OSI 7层协议
以这种方式安排通信有以下两种好处:


  • 不同层次的协议可以加入通信或者从通信中删除
  • 一种底层协议可以服务多种上层协议
    从上图可以看出SSL/TLS协议,基于TCP协议之上,当我们不需要加密的时候 (Http),可以将TLS从模型中删除。当需要加密的时候我们可以使用TLS进行加密,就可以利用TLSHttp加密。

2.1 TLS

TLS是以记录协议实现的。记录协议负责传输连接上的交换的所有底层信息,并以配置加密。
TLS中有四个核心子协议握手协议(handshake protocol),密钥规格变更协议(change ciper spec protocol),应用数据协议(application data protocol)、警报协议(alert protocol)


2.2、握手协议

握手时 TLS协议中最精密复杂的部分。该过程中,双方协商连接参数,并且完成身份验证。根据使用的功能不同,整个过程中需要交换6~10条消息。


2.2.1 完整的握手

如果客户端此前并未和服务端建立会话,那么双方会执行一次完整的流程来协商TLS会话

此处的握手流程我们以不需要身份验证的客户端和需要身份验证的服务端开始,大致流程如下。
基于TLS的TCP连接
1、客户端发送消息,将自身支持的功能发送给服务端。
2、服务端选择连接参数
3、服务端发送证书链(仅当需要验证服务器身份的时候)
4、根据选择密钥的方式,服务器发送生成主密钥需要的额外信息
5、服务端通知客户端完成了协商过程
6、客户发送生成主密钥所需要的额外信息
7、客户端切换加密方式并通知服务端
8、客户端计算和接收的握手信息的Mac并发送
9、服务器切换加密方式并通知客户端
10、服务器计算发送和接收到的握手信息的Mac并发送


2.2.2clientHello

消息中主要包含协议版本(TLS版本号), Random(随机数1),ciper suite密码套件(支持的加密套件), sessionID(为空的回话ID)


2.2.3serverHello

消息中主要包含和协议版本(TLS版本号),Random(随机数2),指定的密码套件,sessionId会话ID


2.2.4certificate

服务器发送证书链,这是一系列证书。主要发送主证书中间证书。主证书一般是CA认证的证书,证书中包含公钥和私钥。这个是可选消息奥。并非所有客户端都需要验证服务端身份的。


2.2.5serverkeyExchange

携带密钥交换的额外数据。不同协商的算法都有差异。


2.2.6serverhelloDone

表明服务端已经将所有预计的握手信息发完


2.2.7ClientKeyExchange

ClientKeyExchange消息携带客户端为密钥交换提供的所有信息


2.2.8ChangeCipherSpec

ChangeCipherSpec消息表明发送端已取得用以生成连接参数的足够信息,已生成加密密钥,
并且将切换到加密模式


2.2.9Finished

表明握手已经完成


2.3 会话恢复


2.4 SSL其它协议等待补充。


3. 浏览器中输入一段网址究竟发生了什么?

我们这么考虑,网址和主机如何映射。那么就有了第一步DNS解析。找到了主机的ip地址后我们如何通信,我们使用何种协议通信https,http。那么协议清楚了,基于OSI7层网络模型我们就知道了,需要建立通信(TCP/UDP)此处我们使用的协议是基于TCP的,故我们有了第二步建立TCP连接,那么就有了TCP的三次握手,因https是需要加密的故基于SSL的握手过程和http不同,将上述的SSL握手的过程表述出来即可,那么关于信道连接好了,我们就可以发网络请求了。也就有了我们的第三部网络请求,然后服务端应答也就有了我们的第四步页面渲染。若页面中还包含一些其它资源又会出现网络请求,页面渲染完毕后我们将关闭通信信道,也就又了我们的第五部关闭TCP连接


3.1https 握手的过程

1、clientHellow
发送消息给服务端支持的协议版本,加密套装组件,随机数1,空sessionid。
2、clientHellow
发送消息给客户端包含协议版本,选定的加密组件方式,随机数2
3、certificate
发送能验证服务端身份的主证书和中间证书,主要表明服务器身份
4、serverKeyExchange
服务端发送,公钥给客户端
5、serverHelloDone
服务端告诉client 已收到预计需要的所有握手消息
6、clientKeyExchange
主要是客户端将随机数2用服务端提供的公钥加密,生成预主密钥。并将密钥塞在publickey字段中
7、服务端收到预主密钥后,将随机数1和随机数2和预主密钥加密过后等到回话密钥。
8、发送完成的信息。

这里面的过程值得注意,服务端交换的是公钥,此处是使用的非对称加密方式。即server 持有成对的公私钥,使用公钥加密就必须使用私钥解密,使用私钥加密就得使用公钥加密。

为什么说https使用的是非堆成和对称加密呢。其实建立tcp连接获取取会话密钥的过程是非对称称加密。成功之后就会使用,会话密钥来加密数据了。


推荐阅读
  • 本文介绍了南邮ctf-web的writeup,包括签到题和md5 collision。在CTF比赛和渗透测试中,可以通过查看源代码、代码注释、页面隐藏元素、超链接和HTTP响应头部来寻找flag或提示信息。利用PHP弱类型,可以发现md5('QNKCDZO')='0e830400451993494058024219903391'和md5('240610708')='0e462097431906509019562988736854'。 ... [详细]
  • 这是原文链接:sendingformdata许多情况下,我们使用表单发送数据到服务器。服务器处理数据并返回响应给用户。这看起来很简单,但是 ... [详细]
  • POCOCLibraies属于功能广泛、轻量级别的开源框架库,它拥有媲美Boost库的功能以及较小的体积广泛应用在物联网平台、工业自动化等领域。POCOCLibrai ... [详细]
  • 三、查看Linux版本查看系统版本信息的命令:lsb_release-a[root@localhost~]#lsb_release-aLSBVersion::co ... [详细]
  • Linux服务器密码过期策略、登录次数限制、私钥登录等配置方法
    本文介绍了在Linux服务器上进行密码过期策略、登录次数限制、私钥登录等配置的方法。通过修改配置文件中的参数,可以设置密码的有效期、最小间隔时间、最小长度,并在密码过期前进行提示。同时还介绍了如何进行公钥登录和修改默认账户用户名的操作。详细步骤和注意事项可参考本文内容。 ... [详细]
  • Android中高级面试必知必会,积累总结
    本文介绍了Android中高级面试的必知必会内容,并总结了相关经验。文章指出,如今的Android市场对开发人员的要求更高,需要更专业的人才。同时,文章还给出了针对Android岗位的职责和要求,并提供了简历突出的建议。 ... [详细]
  • sklearn数据集库中的常用数据集类型介绍
    本文介绍了sklearn数据集库中常用的数据集类型,包括玩具数据集和样本生成器。其中详细介绍了波士顿房价数据集,包含了波士顿506处房屋的13种不同特征以及房屋价格,适用于回归任务。 ... [详细]
  • 本文介绍了作者在开发过程中遇到的问题,即播放框架内容安全策略设置不起作用的错误。作者通过使用编译时依赖注入的方式解决了这个问题,并分享了解决方案。文章详细描述了问题的出现情况、错误输出内容以及解决方案的具体步骤。如果你也遇到了类似的问题,本文可能对你有一定的参考价值。 ... [详细]
  • 加密世界下一个主流叙事领域:L2、跨链桥、GameFi等
    本文介绍了加密世界下一个主流叙事的七个潜力领域,包括L2、跨链桥、GameFi等。L2作为以太坊的二层解决方案,在过去一年取得了巨大成功,跨链桥和互操作性是多链Web3中最重要的因素。去中心化的数据存储领域也具有巨大潜力,未来云存储市场有望达到1500亿美元。DAO和社交代币将成为购买和控制现实世界资产的重要方式,而GameFi作为数字资产在高收入游戏中的应用有望推动数字资产走向主流。衍生品市场也在不断发展壮大。 ... [详细]
  • Givenasinglylinkedlist,returnarandomnode'svaluefromthelinkedlist.Eachnodemusthavethe s ... [详细]
  • 本文介绍了在交换型网络环境下使用嗅探器ARPSniffer的方法,包括检测嗅探环境、设置嗅探的网卡和启动自动路由功能等步骤。同时指出ARPSniffer也可以在非交换型网络环境下使用来嗅探各种网络信息。 ... [详细]
  • OpenMap教程4 – 图层概述
    本文介绍了OpenMap教程4中关于地图图层的内容,包括将ShapeLayer添加到MapBean中的方法,OpenMap支持的图层类型以及使用BufferedLayer创建图像的MapBean。此外,还介绍了Layer背景标志的作用和OMGraphicHandlerLayer的基础层类。 ... [详细]
  • 花瓣|目标值_Compose 动画边学边做夏日彩虹
    篇首语:本文由编程笔记#小编为大家整理,主要介绍了Compose动画边学边做-夏日彩虹相关的知识,希望对你有一定的参考价值。引言Comp ... [详细]
  • php7 curl_init(),php7.3curl_init获取301、302跳转后的数据
    最近在做一个蜘蛛项目,发现在抓取数据时,有时会碰到301的页面,原本写的curl_init函数php7-远程获取api接口或网页内容&#x ... [详细]
  • 解决浏览器打开网页后提示“dns_probe_possible 怎么解决”的方法
    在使用浏览器进行网上冲浪的时候遇到故障是一件很常见的事情,很多用户都遇到过系统提示:dns_probe_possible。从提示中可以看出和DNS是有一定的关系的,经过小编测试之后 ... [详细]
author-avatar
双木子婷_893
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有