当前位置:首页 > 系统1 > 网络IT
网络IT

HTTPS是如何保证密文不能被篡改的?

时间:2023-04-04 00:37:04   作者:Admin   来源:互联网   阅读:273   评论:0
内容摘要:HTTP采⽤明⽂传输,中间⼈可以获取到明⽂数据(从⽽实现对数据的篡改)。这时候HTTPS就登场了!HTTPS是什么呢?HTTPS=HTTP+SSL/TLS,SSL安全套接层(SecureSocketsLayer)发展到v3时改名为TLS传输层安全(TransportLayerSecurity),主要的⽬的是提供数据的完...

HTTP 采⽤明⽂传输,中间⼈可以获取到明⽂数据 (从⽽实现对数据的篡改)。这时候 HTTPS 就登场了! HTTPS 是什么呢? HTTPS = HTTP + SSL/TLS , SSL 安全套接层(Secure Sockets Layer) 发展到 v3 时改名为 TLS 传输层安全(Transport Layer Security),主要的⽬的是提供数据的完整性和保密性

HTTPS是如何保证密文不能被篡改的? 图1

⼀、数据完整性

1.摘要算法

  • 把任意⻓度的数据压缩成固定的⻓度
  • 输⼊不同输出的结果发⽣剧烈的变化“雪崩效应”,相同的内容摘要后结果相同
  • 不能从结果反推输⼊
  • 我们可以在内容后⾯增加 hash 值进⾏传输,服务端收到后通过 hash 值来校验内容是否完整。数据是明⽂的显然不安全

⼆、数据加密

1. 对称加密

加密和解密时使⽤的密钥都是同⼀个, 通信过程使⽤秘钥加密后的密⽂传输。只有⾃⼰和⽹站才能解密。

HTTPS是如何保证密文不能被篡改的? 图2

⽬前 AES (Advanced Encryption Standard) ChaCha20 为最常⻅的对称加密算法 。

2.⾮对称加密

⾮对称加密可以解决“密钥交换”的问题。⾮对称加密有两个秘钥,公钥、私钥,所以称之为⾮对称。公钥加密私钥

解密。

并不能完全采⽤⾮对称加密算法,由于算法本身耗时远⾼于对称加密。

使⽤ RSA 、 ECDHE 算法解决秘钥交换的问题

HTTPS是如何保证密文不能被篡改的? 图3

最常听到的⾮对称加密算法是 RSA 、 ECC (⼦算法 ECDHE ⽤于密钥交换, ECDSA ⽤于数字签名)(性能和安全略胜⼀筹) HTTPS 中⽬前⼴泛使⽤ ECC 。

3. 混合加密

通信刚开始的时候使⽤⾮对称算法,交换秘钥。在客户端⽣成会话秘钥后传送给服务端,后续通信采⽤对称加密的⽅式

HTTPS是如何保证密文不能被篡改的? 图4

这⾥还并不安全,还涉及到中间⼈攻击。( 指攻击者与通讯的两端分别创建独⽴的联系,并交换其所收到的数据 )

HTTPS是如何保证密文不能被篡改的? 图5

4. 数字证书和 CA

因为谁都可以发布公钥,所以我们需要验证对⽅身份。防⽌中间⼈攻击

HTTPS是如何保证密文不能被篡改的? 图6

客户端会判断有效期、颁发者、证书是否被修改及证书是否被吊销。 每份签发证书都可以根据验证链查找到对应的根证书,操作系统、浏览器会在本地存储权威机构的根证书,利⽤本地根证书可以对对应机构签发证书完成来源验证。

  • 加密:对传输的数据进⾏加密。
  • 数据⼀致性:保证传输过程中数据不会被篡改。
  • 身份认证:确定对⽅的真实身份。

三、 HTTPS 过程

1. 第⼀阶段

  • 客户端会发送 handshake Protocol:client hello

Cipher Suites 密钥交换算法 + 签名算法 + 对称加密算法 + 摘要算法 套件列表

Random 客户端随机数

Version: TLS 1.2

  • 服务端会发送 handleshake Protocol:Server Hello
  • Version: TLS 1.2
  • Random 服务端随机数
  • Cipher Suites:选择的套件

双⽅选择 TLS 版本,确定加密算法,⽣成两个随机数

2. 第⼆阶段

  • 服务端发送证书 certificate
  • 服务端发送 ECDHE 参数,服务端 Hello 完成

Server Key Exchange

Server Hello Done

  • 客户端发送 ECDHE 参数,以后使⽤秘钥进⾏通信吧,加密握⼿消息发送给对⽅
  • Client Key Exchange
  • Change Cipher Spec
  • Encrypted HandleShake Message
  • 服务端发送会话凭证,以后使⽤秘钥进⾏通信吧,加密握⼿消息发送给对⽅
  • new Session Ticket
  • Change Cipher Spec
  • Encrypted HandleShake Message

HTTPS是如何保证密文不能被篡改的? 图7

HTTPS是如何保证密文不能被篡改的? 图8

SSL 协议组成

SSL 握⼿协议、 SSL 秘钥变化协议、 SSL 警告协议、 SSL 记录协议等

文章出自:前端餐厅ReTech,如有转载本文请联系前端餐厅ReTech今日头条号。

github:https://github.com/zuopf769

责任编辑:武晓燕来源: 今日头条

 网站不盈利不挣钱,若有侵犯你的利益请联系删除,给你带来的不便,我们非常重视版权问题 

#免责声明#

【声明】:缘北网(https://zyk8.cc)登载此文出于传递更多信息之目的,并不代表本站赞同其观点和对其真实性负责,仅适于网络安全技术爱好者学习研究使用,学习中请遵循国家相关法律法规。如有问题请联系我们,联系邮箱1665545192@qq.com,我们会在最短的时间内进行处理。

【声明】 本站提供的一切软件、教程和内容文章信息仅限用于学习和研究目的;不得将上述内容用于商业或者非法用途,否则,一切后果请用户自负。本站信息来自网络收集整理,版权争议与本站无关。您必须在下载后的24个小时之内,从您的电脑或手机中彻底删除上述内容。如果您喜欢该程序和内容,请支持正版,购买注册,得到更好的正版服务。我们非常重视版权问题,如有侵权请邮件与我们联系处理。敬请谅解!

本站资源均从互联网上收集,仅供学习和交流使用;请遵循相关法律法规;
本站一切资源不代表本站立场,如有侵权、后门、不妥,请联系删除,敬请谅解!

本站所有文章,软件,源码,来源 互联网的搬运收集,只提供学习教程,请勿非法使用,后果自负!

不得将上述内容用于商业或者非法用途,否则,一切后果请用户自负。本站信息来自网络收集整理,版权争议与本站无关。您必须在下载后的24个小时之内,从您的电脑或手机中彻底删除上述内容。敬请谅解!侵权删帖投诉投稿联系邮箱



标签:如何  不能  保证  篡改  能被  
相关评论
介绍 - 侵权处理 - 版权声明

声明: 所有软件和文章来自互联网 如有异议 请与本站联系 本站为非赢利性网站 不接受任何赞助和广告

本站资源来自互联网收集 仅供用于学习和交流 请遵循相关法律法规  立即咨询微信yigefeiren-888  立即咨询

富强、民主、文明、和谐,自由、平等、公正、法治, 爱国、敬业、诚信、友善 

琼ICP备2021009498号-2

51LA统计