位置: IT常识 - 正文

https是如何保证安全的

编辑:rootadmin
https是如何保证安全的

推荐整理分享https是如何保证安全的,希望有所帮助,仅作参考,欢迎阅读内容。

文章相关热门搜索词:,内容如对您有帮助,希望把文章链接给更多的朋友!

在学习http与https的区别的时候,我们通常从以下几点出发:

http是超文本传输协议,是明文传输,有安全风险,https在TCP和http网络层之间加入了SSL/TLS安全协议,使得报文能够加密传输

http连接简单,三次握手后即可传输,但是https在三次握手之后还要进行SSL/TLS的握手过程,才能加密报文传输

两者端口号不一样,http默认端口号是80,HTTPS默认端口号是443

https需要申请CA证书,需要付费

从上面的区别我们可以看出,我们使用https就是看中了他比较安全,但是他是如何确保安全的呢?

你可能会说,它不止进行TCP三次握手还要进行SSL/TLS握手,这样确保了它的安全性。

但是SSL/TLS是什么呢?它们又是怎样加密的呢?

SSL和TLS

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

TLS:(Transport Layer Security,传输层安全协议),用于两个应用程序之间提供保密性和数据完整性。

SSL和TLS是一种能够在服务器,machines和通过网络运行的应用程序(例如,客户端连接到web服务器)之间提供身份认证和数据加密的加密协议。SSL是TLS的前世。多年来,新版本的发布用来解决漏洞,提供更强大支持,更安全的密码套件和算法。

为什么要使用SSL/TLS?

因为HTTP是明文传输,所谓明文,就是说客户端和服务端通信的信息都是肉眼可见的,随意使用一个抓包工具都可以截获通信的内容

所以会存在以下三个风险“

窃听风险,第三方可以获取通信内容

篡改风险,第三方可以修改通信内容,比如强制植入垃圾广告

冒充风险,第三方冒充他人身份进行通信

HTTPS在HTTP与TCP之间加入了TLS协议,来解决上述风险。

https是如何保证安全的

TLS是如何解决上述风险的呢?

信息加密:HTTP交互信息是被加密的,第三方就无法被窃取

校验机制:校验信息传输过程中是否有被第三方篡改过,如果被篡改过,则会有警告提示;

身份证书:验证所要访问网站的证书,判断其真实性

TLS的握手过程加密方式

传统的TLS握手基本上都是使用RSA算法来实现密钥交换的,服务端将自己的公钥在TLS的握手阶段 传递给客户端,服务端的私钥一直留在自己这,一定要确保私钥不能被窃取。

在RSA密钥协商算法中,客户端会生成随机密钥,并使用服务端的公钥加密后再传给服务端。根据非对称加密算法,公钥加密的消息仅能通过私钥解密,这样服务器解密后,双方就得到了相同的密钥,再用它加密应用消息。

那么如何确保自己的公钥不被篡改的呢?这就是我们前面所说的CA证书,将公钥放在数字证书中。只要证书是可信的,公钥就是可信的。

TLS第一次握手

客户端会先向服务器打个招呼【Client Hello】,消息里面有客户端使用的TLS版本号、支持的密码套件列表,以及生成的随机数1,这个随机数会被服务端保留,它是生成对称加密密钥的材料之一。

TLS第二次握手

当服务器收到客户端的【Client Hello】消息后,会确认TLS版本号是否支持,和从密码套件列表中选择一个密码套件,以及生成随机数。然后返回【Server Hello】消息,消息里面有服务器确认的TLS版本号,也给出了随机数2,然后从客户端的密码套件列表选择一个合适的密码套件。

然后,服务端为了证明自己的身份,会发送【Server Certificate】给客户端,这个消息里含有数字证书。

接着,服务端发送【Server Hello Done】给客户端,目的是,我已经把该给你的东西都发给你了,本次打招呼完毕。

TLS第三次握手

客户端验证完成证书后,认为是可信的,就会生成一个新的随机数,用服务器的RSA公钥加密该随机数3,通过【Client Key Exchange】消息传给服务端。

服务端收到之后,用RSA私钥解密,得到客户端发送的随机数

到这,双方都已经得到了三个随机数,生成会话密钥,它是对称加密,用于对后续的HTTP请求/响应的数据加解密。

生成完会话密钥后,然后客户端发一个【Change Cipher Spec】,告诉服务端开始使用加密方式发送消息。

然后,客户端再发一个【Encrypted Handshake Message(Finished)】消息,把之前所有发送的数据做个摘要,再用会话密钥加密一下,让服务器做个验证,验证加密通信是否可用和之前握手信息是否有被中途篡改过

在【Change Cipher Spec】之前握手数据都是明文传输的,之后都是对称密钥加密的密文。

TLS第四次握手

服务器也是同样的操作,发【Change Cipher Spec】和【Encrypted Handshake Message】消息,如果双方都验证加密和解密没问题,那么握手正式完成。

最后,就会用【会话密钥】加解密HTTP请求和响应了。

参考1

参考2

本文链接地址:https://www.jiuchutong.com/zhishi/300165.html 转载请保留说明!

上一篇:Pytorch中的广播机制(Broadcast)(pytorch广播相乘)

下一篇:PointNet解读(point network)

  • 小米11支持的哪些传感器(小米11支持哪些快充协议)

    小米11支持的哪些传感器(小米11支持哪些快充协议)

  • 华为nova7可以指关节截屏吗(华为nova7可以屏幕指纹解锁吗)

    华为nova7可以指关节截屏吗(华为nova7可以屏幕指纹解锁吗)

  • 苹果手机不显示蓝牙标志怎么办(苹果手机不显示app图标不见了)

    苹果手机不显示蓝牙标志怎么办(苹果手机不显示app图标不见了)

  • 苹果11通讯录怎么按字母查找(苹果11通讯录怎么导入卡里)

    苹果11通讯录怎么按字母查找(苹果11通讯录怎么导入卡里)

  • 拼多多二级惩罚是什么(拼多多二级惩罚3个月)

    拼多多二级惩罚是什么(拼多多二级惩罚3个月)

  • 删除评论对方能看见吗(删除对方的评论会通知对方吗)

    删除评论对方能看见吗(删除对方的评论会通知对方吗)

  • 表格中的文字怎么调行距(表格中的文字怎么靠下)

    表格中的文字怎么调行距(表格中的文字怎么靠下)

  • 小米10和小米10pro都是曲面屏吗(小米10和小米10pro钢化膜通用吗)

    小米10和小米10pro都是曲面屏吗(小米10和小米10pro钢化膜通用吗)

  • 手机没有移动信号怎么回事(手机没有移动信号是什么原因)

    手机没有移动信号怎么回事(手机没有移动信号是什么原因)

  • cims一般由什么组成(cims有什么用)

    cims一般由什么组成(cims有什么用)

  • 华为平板m6支持otg吗(华为平板m6支持内存扩展吗)

    华为平板m6支持otg吗(华为平板m6支持内存扩展吗)

  • 苹果x屏幕失灵怎么解决(苹果x手机屏幕失灵解决方法)

    苹果x屏幕失灵怎么解决(苹果x手机屏幕失灵解决方法)

  • 微信号能改几次(多个微信登录)

    微信号能改几次(多个微信登录)

  • 发朋友圈如何不折叠(发朋友圈如何不配图)

    发朋友圈如何不折叠(发朋友圈如何不配图)

  • 计算机二级excel常用函数公式(计算机二级excel真题)

    计算机二级excel常用函数公式(计算机二级excel真题)

  • vivox27怎么设置计步(vivox27怎么设置返回键在桌面)

    vivox27怎么设置计步(vivox27怎么设置返回键在桌面)

  • ps如何分解图层(ps怎样分解图层)

    ps如何分解图层(ps怎样分解图层)

  • 手机变成繁体字怎么改回来(手机变成繁体字怎么改回来vivo)

    手机变成繁体字怎么改回来(手机变成繁体字怎么改回来vivo)

  • opporeno什么意思(opporeno是什么意思中文翻译)

    opporeno什么意思(opporeno是什么意思中文翻译)

  • 电脑系统激活密钥(电脑系统激活密码)

    电脑系统激活密钥(电脑系统激活密码)

  • 在Linux下确定网卡所使用驱动程序的方法(linux怎么检查网络状态)

    在Linux下确定网卡所使用驱动程序的方法(linux怎么检查网络状态)

  • uniapp页面跳转的几种方式(uniapp跳转页面没反应)

    uniapp页面跳转的几种方式(uniapp跳转页面没反应)

  • win11 KB5023774更新后无法打开荒野大镖客2怎么办? 微软提供临时且唯一的解决方案(win11更新22468)

    win11 KB5023774更新后无法打开荒野大镖客2怎么办? 微软提供临时且唯一的解决方案(win11更新22468)

  • 城建税的征税范围不包括农村对不对
  • 企业季度所得税计算公式
  • 免税合并和应税合并商誉
  • 国企的注册资本也很少吗
  • 运动会奖品有什么
  • 特许经营权转让合同
  • 支付一次性劳务报酬怎么做账
  • 开发成本属于什么类账户
  • 公司抬头的发票
  • 个体工商户办税务
  • 收回多缴税金会计分录
  • 承租人融资租赁设备长期应付款包括租赁资产担保余值
  • 无形资产特许权使用费怎么做账
  • 预收账款和预付账款什么时候用
  • 已认证未付款分录
  • 联营扣点方案
  • 货物赔偿款会计分录
  • 出售股票会计怎么做分录
  • 一般纳税人汽车修理费可以抵扣吗
  • 个税手续费返还会计分录
  • 所得税费用税率规定
  • 银行处置以物抵债违法吗
  • 加盟费返款怎么入账
  • 金融服务收入怎么算
  • 污水处理服务费用交印花税吗
  • 工业企业销售管理制度
  • 什么叫二类费用
  • 副调基金的会计分录怎么做?
  • 普通支票如何转账
  • 华为鸿蒙系统超级终端怎么用
  • 股东以无形资产投资,撤资时怎么算
  • 外贸收汇怎么处理
  • windows10自带桌面时钟
  • u盘中毒症状
  • windows 11 正式
  • macos big sur 怎么样
  • linux模块的概念
  • 其他应付款不用付了怎么处理
  • php面向对象面试题
  • 新英格兰的秋天
  • 购买二手车要缴税吗
  • 华硕自带win10系统
  • js数组方法filter
  • 买货没发票如何入账?
  • 专家咨询费比例不能超过多少
  • 未开票收入如何做账
  • 进项税额在贷方怎么办
  • 成本核算分摊方法总结
  • 金税四期能监控到公户吗
  • 服务费的增值税可以抵扣吗
  • 企业选择的短期调整
  • 发票开具流程是?
  • 施工企业机械租赁费用
  • 处置固定资产会计处理
  • 费用科目可以在借方吗
  • 建筑设计行业收费标准
  • 2021年财务报表申报
  • 公司活动费用分录
  • xp字体无法安装
  • xp系统玩英雄联盟出现win32
  • 如何安装windowsxp
  • win10浏览器没有网络连接
  • 更新win8
  • win7电脑无限蓝屏怎么解决
  • node管理工具
  • 多媒体播放器使用方法
  • opengl中点画圆算法
  • Node.js中的事件循环是什么
  • 教你三招让电脑打字
  • bash脚本加密
  • 基于javascript的论文题目
  • jquery.css
  • nodejs+ts
  • bootstrap要学吗
  • 用shell脚本创建用户
  • jquery网页
  • 即将发布的新能源汽车
  • JavaScript charCodeAt方法入门实例(用于取得指定位置字符的Unicode编码)
  • 广东etc政策
  • 为构建和谐企业
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

    网站地图: 企业信息 工商信息 财税知识 网络常识 编程技术

    友情链接: 武汉网站建设