位置: 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)

  • 拼多多未按约定时间发货怎么处理(拼多多未按约定时间发货对店铺有影响吗)

    拼多多未按约定时间发货怎么处理(拼多多未按约定时间发货对店铺有影响吗)

  • 小米10青春版的闪存规格是多少(小米10青春版的处理器)

    小米10青春版的闪存规格是多少(小米10青春版的处理器)

  • 抖音换手机登录会降权重吗(抖音换手机登录不上怎么办)

    抖音换手机登录会降权重吗(抖音换手机登录不上怎么办)

  • 华为mate20能装内存卡吗(华为mate20装内存卡能安装软件吗)

    华为mate20能装内存卡吗(华为mate20装内存卡能安装软件吗)

  • 芒果tv电脑客户端没有弹幕(芒果tv电脑客户端怎么调亮度)

    芒果tv电脑客户端没有弹幕(芒果tv电脑客户端怎么调亮度)

  • 怎么去掉抖音水印(怎么去掉抖音水印保存图片)

    怎么去掉抖音水印(怎么去掉抖音水印保存图片)

  • hp进bios按什么键(hp进去bios快捷键)

    hp进bios按什么键(hp进去bios快捷键)

  • 三星手机快充怎么失灵了(三星手机快充怎么变成了慢充?)

    三星手机快充怎么失灵了(三星手机快充怎么变成了慢充?)

  • 笔记本电脑home键在哪(笔记本电脑home键怎么按)

    笔记本电脑home键在哪(笔记本电脑home键怎么按)

  • 4g手机用5g卡为什么不能打电话(4G手机用5G卡为什么发烫)

    4g手机用5g卡为什么不能打电话(4G手机用5G卡为什么发烫)

  • 小米10背面是玻璃吗(小米10背面是玻璃材质吗)

    小米10背面是玻璃吗(小米10背面是玻璃材质吗)

  • 电脑键盘上徽标键是哪个(电脑键盘徽标键是哪个)

    电脑键盘上徽标键是哪个(电脑键盘徽标键是哪个)

  • qq4g在线和wifi在线有什么区别(qq的4g在线和wifi在线)

    qq4g在线和wifi在线有什么区别(qq的4g在线和wifi在线)

  • 赛扬e3400相当于i几(赛扬e3400相当于amd的什么)

    赛扬e3400相当于i几(赛扬e3400相当于amd的什么)

  • lineout是什么接口(line-out接口)

    lineout是什么接口(line-out接口)

  • 如何清除微信账单记录(如何清除微信账号阿白)

    如何清除微信账单记录(如何清除微信账号阿白)

  • 买家违规不申诉会怎样(买家账户违规申诉超时怎么办)

    买家违规不申诉会怎样(买家账户违规申诉超时怎么办)

  • 苹果xsmax屏幕是2k吗

    苹果xsmax屏幕是2k吗

  • 华为8x有没有红外线功能(华为8x红色)

    华为8x有没有红外线功能(华为8x红色)

  • 荣耀stfal10啥型号(荣耀stf-al10)

    荣耀stfal10啥型号(荣耀stf-al10)

  • dcs控制域什么意思(什么叫dcs 控制模式)

    dcs控制域什么意思(什么叫dcs 控制模式)

  • 管家婆软件怎么用(管家婆软件怎么查找销售订单)

    管家婆软件怎么用(管家婆软件怎么查找销售订单)

  • 华为自带软件怎么恢复(华为自带软件怎么下载回来)

    华为自带软件怎么恢复(华为自带软件怎么下载回来)

  • 华为p30能反向充电吗(华为p30反向充电选项找不到怎么办)

    华为p30能反向充电吗(华为p30反向充电选项找不到怎么办)

  • 如何使用 CSS 使表格居中(快速指南)(css怎么调用)

    如何使用 CSS 使表格居中(快速指南)(css怎么调用)

  • YOLOv5、v7改进之二十六:改进特征融合网络PANet为ASFF自适应特征融合网络(yolov5改进点)

    YOLOv5、v7改进之二十六:改进特征融合网络PANet为ASFF自适应特征融合网络(yolov5改进点)

  • 营业现金比率是用经营活动净流入还是经营活动流入
  • 非盈利组织免税资格文件
  • 增值税发票查询网络异常
  • 偶然所得纳税计算
  • 背书承兑分录
  • 应收保险公司赔款计入
  • 赠品要做视同销售申报纳税吗
  • 新政府会计制度下属于负债类科目的是
  • 现代服务业营改增前后税率对比表
  • 管理费用是进项还是销项
  • 房地产开发成本费用明细表
  • 营改增后应付职工薪酬如何核算个人所得税?
  • 新三板公司股东人数
  • 兼职获得员工旅游资源
  • 合同增值税如何申报
  • 股东收回投资款的现金流量
  • 废旧物资收购价目表
  • 库存商品进货价怎么算
  • linux多线程运行
  • 施工企业临时设施属于
  • 上期有留抵进项税额会计分录
  • 在win10中怎么从edge旧ie浏览器
  • 物业专项维修资金可以退还吗
  • realjbox.exe - realjbox是什么进程 作用是什么
  • 分公司吸收新股怎么办
  • 购入的无形资产
  • 广告费用计入什么会计科目
  • 现金流量套期的分录
  • php二维数组的遍历
  • php linq
  • 呆账损失是什么意思
  • 外单位承担
  • 梅林澳大利亚信号好最好吗
  • 计算利润要扣除企业所得税吗
  • 车辆维修费怎么做分录
  • 什么是非营利性养老机构
  • Video Transformer | TimeSformer 理解+ 代码实战
  • 10分钟学会万用表
  • 对标是啥
  • [深度学习] fast-reid入门教程
  • pinf命令
  • php clob
  • 以股权换股权税务问题
  • 非财政补助结转和非财政补助结余的区别
  • 上一年的进项税转出还用交企业所得税吗
  • 现金预算表中的归还借款和支付利息怎么算
  • 样品开发计划
  • 我有朋友吗朋友圈说说
  • 库存股会计处理流程
  • 租入的厂房
  • 应收账款期末余额为负数表示什么
  • 银行扣结算卡年费合理吗
  • 债权投资有哪些科目
  • 购买不良债权如何追偿
  • 现金存银行凭证
  • 自产自销免税农产品需要缴纳印花税吗
  • 专利的费用计入成本吗
  • 饭店现金账怎么记账
  • 小微企业和小规模纳税人的区别
  • windows任务管理器命令
  • ubuntu zmq
  • mac怎么安装新系统
  • apache not found
  • solaris 11.4
  • win7系统开启无线服务
  • win8系统开机启动项怎么设置
  • win10 电脑
  • win8怎么外接屏幕
  • java语言的解释器是什么
  • linux中命令行
  • 简述javascript
  • python的params
  • javascript面向对象编程指南
  • 电子税务局更改密码怎么改
  • 北京税务局网上怎么登录
  • 成都市老年公交卡年审地点
  • 企业所得税计算器在线计算
  • 房地产开发企业土地成交额与去年同期相比增长约
  • 领完发票后 怎么读取
  • 债权收购协议书
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设