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

  • 如何给表格添加框线(如何给表格添加背景)

    如何给表格添加框线(如何给表格添加背景)

  • 学习通可以上网课吗

    学习通可以上网课吗

  • 凯迪仕密码锁怎么进入管理员界面(凯迪仕密码锁怎么用密码开门)

    凯迪仕密码锁怎么进入管理员界面(凯迪仕密码锁怎么用密码开门)

  • dmov是什么指令(plc基础知识指令27个)

    dmov是什么指令(plc基础知识指令27个)

  • 表格打印预览只有一半(表格打印预览只有一列)

    表格打印预览只有一半(表格打印预览只有一列)

  • 400w电源能带rx580吗(400w电源能带rx580显卡吗)

    400w电源能带rx580吗(400w电源能带rx580显卡吗)

  • 为什么移动数据打不开(为什么移动数据关了还会产生流量费用)

    为什么移动数据打不开(为什么移动数据关了还会产生流量费用)

  • 苹果手机电池保内更换原则(苹果手机电池保护开不了机)

    苹果手机电池保内更换原则(苹果手机电池保护开不了机)

  • 手机防偷窥钢化膜原理(手机防偷窥钢化膜会影响手机听筒吗)

    手机防偷窥钢化膜原理(手机防偷窥钢化膜会影响手机听筒吗)

  • i55250u相当什么水平(i5-5250u)

    i55250u相当什么水平(i5-5250u)

  • 如何让蓝牙耳机报姓名(如何让蓝牙耳机不自动放歌)

    如何让蓝牙耳机报姓名(如何让蓝牙耳机不自动放歌)

  • vivo怎么改快捷中心(vivo怎么改快捷中心样式)

    vivo怎么改快捷中心(vivo怎么改快捷中心样式)

  • 铅酸电池和锂电池的区别(铅酸电池和锂电池哪个容易爆炸)

    铅酸电池和锂电池的区别(铅酸电池和锂电池哪个容易爆炸)

  • iphone11充一晚上电好吗(iphone11充一晚上电)

    iphone11充一晚上电好吗(iphone11充一晚上电)

  • 手机卡怎么激活(手机卡怎么激活移动卡)

    手机卡怎么激活(手机卡怎么激活移动卡)

  • 华为手机太卡怎么解决(华为手机太卡怎么清理垃圾)

    华为手机太卡怎么解决(华为手机太卡怎么清理垃圾)

  • beatsx怎么切换设备

    beatsx怎么切换设备

  • 微信怎么上传原图(微信怎么上传原视频到朋友圈)

    微信怎么上传原图(微信怎么上传原视频到朋友圈)

  • 苹果xr如何滚动截屏(苹果xr如何滚动截屏微信)

    苹果xr如何滚动截屏(苹果xr如何滚动截屏微信)

  • xsmax原装是无线耳机吗(xsmax用什么无线充电器好)

    xsmax原装是无线耳机吗(xsmax用什么无线充电器好)

  • 如何关闭小爱语音引擎(如何关闭小爱语音搜索功能)

    如何关闭小爱语音引擎(如何关闭小爱语音搜索功能)

  • 3ds充电要多久(3ds充完电是什么样的)

    3ds充电要多久(3ds充完电是什么样的)

  • 转转保卖下单能取消吗(转转保卖下单后不想卖了怎么办)

    转转保卖下单能取消吗(转转保卖下单后不想卖了怎么办)

  • 华为2340*1080是多少寸(华为2340*1080是多少分辨率)

    华为2340*1080是多少寸(华为2340*1080是多少分辨率)

  • Bert+LSTM+CRF命名实体识别pytorch代码详解(lstm crf)

    Bert+LSTM+CRF命名实体识别pytorch代码详解(lstm crf)

  • 承租承包经营所得
  • 基本账户变更说明模板
  • 资产负债表负债总额怎么看
  • 应付债券利息计入哪里
  • 工业企业辅助生产费用的分配方法
  • 可税前扣除的工资
  • 善意取得虚开专票的条件包括
  • 建筑安装工程怎么缴税
  • 合并报表时存货怎么处理
  • 购买展示样品怎么入账
  • 销售亏损原因分析范文
  • 企业在建工程如何做账
  • 因质量问题怎么赔偿
  • 抵债的货物按什么算增值税
  • 保险的月缴纳可以调整么?
  • 行政诉讼的适用情况
  • 公司报销学费属于 薪酬还是福利呢
  • 单位不发工资怎么解决要什么证据
  • 现金购入库存商品的分录
  • 房地产广告公司月费一般多少
  • 企业上月份销售收入在本月份发生销售折让时
  • 待摊费用做账
  • 以前月份个税没交怎么办
  • 个税逾期申报怎么缴纳罚款
  • 进项税发票未认证
  • 苹果mac os x 怎样打开DVD播放程序
  • 长期待摊费用转入成本分录
  • Apache+php+mysql在windows下的安装与配置图解(最新版)
  • 退多收款怎么做分录
  • php ftp功能
  • 芬迪flow
  • 交易性金融资产的交易费用计入哪里
  • 辛华达瀑布,加拿大贾斯珀国家公园 (© Schroptschop/Getty Images)
  • 在途物资什么类科目
  • 以物易物怎么写分录
  • 小规模纳税人进项票可以抵扣吗
  • 浦东森林村
  • python偏函数理解
  • 销售费用计提分录
  • 子公司减资是利好还是利空
  • 以土地使用权投资入股
  • 综合所得汇算清缴是什么意思
  • 个人住房租赁给公司如何开票
  • 无偿调入资产如何做账
  • 销售软件产品
  • 为取得借款发生的手续费
  • 其他应收款在借方怎么调账
  • 股东出资做什么科目
  • 投资损益科目
  • 赠送样品视同销售增值税该怎么做账务处理呢?
  • 印花税计入哪个会计分录
  • 旅行社代订机票发票报销
  • 供应商销售折让怎么入账
  • mysql 5.7.17 winx64免安装版配置方法图文教程
  • windows 10 build 9888
  • 轻轻松松在树枝上摘果子用什么成语
  • linux防御
  • 电脑bios怎么设置usb启动
  • win10笔记本连接不了wifi
  • win10预览设置
  • xp系统explorer.exe错误
  • rcapi.exe - rcapi是什么进程 有什么用
  • win10地理位置
  • 电子版win10怎么安装
  • html气泡效果
  • javascript教程chm
  • fflogs隐藏数据
  • linux哪些方法可以查看命令的详细信息
  • 自动检测设置 使用设置脚本
  • nodejs集成sqlite使用示例
  • 如何修改新建的内容
  • html5 树形控件
  • android教学
  • python单链表输出1到10
  • 如何使用jquery
  • 国家税务局级别排名
  • 点击电子税务局里的税务数字账户不跳转怎么回事
  • 江西自考招考办
  • 国家税务总局第17号令
  • 抄税失败是怎么回事
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设