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

  • 怎样玩转免费网页游戏(如何用免费网络)

    怎样玩转免费网页游戏(如何用免费网络)

  • 抖音可以删除浏览别人的痕迹吗(抖音可以删除浏览主页记录吗)

    抖音可以删除浏览别人的痕迹吗(抖音可以删除浏览主页记录吗)

  • 华为荣耀20s可以隐藏应用吗(华为荣耀20s可以加nfc功能)

    华为荣耀20s可以隐藏应用吗(华为荣耀20s可以加nfc功能)

  • 怎样查看用过的微信头像(怎样查看用过的wifi)

    怎样查看用过的微信头像(怎样查看用过的wifi)

  • 用了红包商家知道吗(商家看到使用红包的订单)

    用了红包商家知道吗(商家看到使用红包的订单)

  • 手机充不进去电该怎么办(手机充不进去电如何恢复正常)

    手机充不进去电该怎么办(手机充不进去电如何恢复正常)

  • windows ssd是什么意思(windows—ssd)

    windows ssd是什么意思(windows—ssd)

  • 公司打印机能看到别人的打印记录吗(公司打印机能看到别人的打印名称吗)

    公司打印机能看到别人的打印记录吗(公司打印机能看到别人的打印名称吗)

  • 陌陌用微信登录好友会知道吗(陌陌用微信登录后好友都能看到)

    陌陌用微信登录好友会知道吗(陌陌用微信登录后好友都能看到)

  • 声卡的主要组成部分 (声卡的主要组成包括)

    声卡的主要组成部分 (声卡的主要组成包括)

  • cad修改文字的快捷键(cad修改文字的快捷键命令)

    cad修改文字的快捷键(cad修改文字的快捷键命令)

  • 英文字母E的ASCII码是什么(英文字母E的ascll码)

    英文字母E的ASCII码是什么(英文字母E的ascll码)

  • 读取手机状态和身份是什么意思(读取手机状态和身份关闭)

    读取手机状态和身份是什么意思(读取手机状态和身份关闭)

  • 电子计算器清除键是什么(电子计算器清除建)

    电子计算器清除键是什么(电子计算器清除建)

  • 怎么查安卓手机电池实际容量(怎么查安卓手机的激活日期)

    怎么查安卓手机电池实际容量(怎么查安卓手机的激活日期)

  • 华为nemaloo是什么型号(华为nebo是什么)

    华为nemaloo是什么型号(华为nebo是什么)

  • 参考文献的标注怎么弄(参考文献的标注怎么弄在右上角)

    参考文献的标注怎么弄(参考文献的标注怎么弄在右上角)

  • obb文件要怎么打开(obobj文件怎么打开)

    obb文件要怎么打开(obobj文件怎么打开)

  • word竖排文字间距(word文字竖着排)

    word竖排文字间距(word文字竖着排)

  • 苹果手机的云相册在哪(苹果手机的云相册怎么能看到照片)

    苹果手机的云相册在哪(苹果手机的云相册怎么能看到照片)

  • 微博怎么把经常访问删掉(微博怎么把经常访问放在功能卡片)

    微博怎么把经常访问删掉(微博怎么把经常访问放在功能卡片)

  • 天猫帮助中心在哪里(手机天猫帮助中心怎么进入)

    天猫帮助中心在哪里(手机天猫帮助中心怎么进入)

  • 显卡延长线影响性能吗(显卡延长线影响显卡吗)

    显卡延长线影响性能吗(显卡延长线影响显卡吗)

  • 过了汇算清缴期后发现错误
  • 报验户与正常户的区别
  • 经营活动现金流量公式
  • 劳务公司涉及的税收
  • 新公司利润表怎么填
  • 开发票利润
  • 上年城市维护建设税退税怎么记账
  • 电子发票红字发票怎么开
  • 认缴出资股权转让的法律责任
  • 工业企业辅助生产费用的分配方法
  • 未交增值税金额公式
  • 新准则前期差错更正
  • 工资发多了需要退回吗
  • 递延收益在资产负债表哪里列示
  • 增值税电子发票怎么作废
  • 防伪税控维护费会计分录
  • 预收账款与预付账款均属于负债
  • 小微企业利润亏损原因
  • 批发行业增值税税负率是多少呢
  • 开发项目未竣工前土地使用税怎么缴纳
  • 企业所得税年报和增值税收入不一致
  • 内部存货交易的抵消分录例题讲解
  • 设备的折旧率是什么意思
  • 主营业务成本净额计算公式
  • thinkpad x230笔记本
  • 债券利息计算表
  • 营业利润,利润总额的计算公式是
  • php去除空格和换行符
  • 初品官网
  • 营改增后固定资产报废处置收入计税
  • 高新技术企业如何在电子税务局备案
  • 存货核算的会计分录怎么写
  • php操作mysql数据库
  • thinkphp自定义标签
  • xa 事务
  • 商品流通企业物流成本的具体构成包括()
  • 融资租入固定资产的账务处理
  • 收到返利冲成本还是记收入
  • c语言typedef的用法
  • 扣除公积金分录
  • 公司注销持股1%的股东需要他签字吗
  • 往来会计和应收应付有什么区别
  • 工会经费是按应付职工薪酬贷方计提吗
  • 无票收入怎么计算
  • 广交会展务
  • 会计凭证中的数字怎么填
  • 流转税怎么核算
  • 电费应收和实收怎么算
  • 上年度漏提折旧
  • 报表的应付账款怎么算
  • 开办幼儿园的流程图
  • 已付款未收到发票
  • 承兑个人贴现如何操作
  • 公司买护肤品发票如何入账
  • sqlserver界面
  • mysql索引命令
  • windows自带安全
  • centos 命令大全
  • 为快捷方式建立快捷方式
  • xp默认详细信息
  • OS X10.10.5 Yosemite beta2发布 os x10.10.5yosemite beta2官网下载地址
  • 电脑跳出windows 许可
  • win10预览版21301bug
  • js判断密码强弱
  • 安卓炫酷壁纸
  • 如何删除命令
  • Python实现Mysql数据库连接池实例详解
  • android内存机制
  • os模块 python
  • JavaScript中的变量名不区分大小写
  • python二叉树的遍历算法
  • 淄博市税务局投诉电话
  • 重庆国家电子税务总局怎样开电子税票
  • 软件开发交流平台
  • 资源税选矿和原油的区别
  • 慈善组织可能会出现哪些问题
  • 税务注销后发现报表报错的怎么办
  • 免抵税额在增值税申报表附表
  • 河南省优秀班主任2022
  • 房屋租赁税房东不承担怎么办理
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设