https和http的区别,及HTTPS的工作流程

news2024/11/29 10:45:59

HTTP(HyperText Transfer Protocol)和HTTPS(HyperText Transfer Protocol Secure)都是超文本传输协议,但它们之间的关键区别在于安全性。

  1. 安全性

    • HTTP:数据以明文传输,没有加密,容易被第三方截获和篡改。
    • HTTPS:在HTTP的基础上加入了SSL/TLS加密层,数据在传输过程中是加密的,可以有效保护用户隐私。
  2. 端口

    • HTTP:使用的是80端口。
    • HTTPS:使用的是443端口。
  3. 证书

    • HTTP:不需要证书。
    • HTTPS:需要SSL/TLS证书来验证服务器的身份,确保用户连接到的是可信的服务器。
  4. 速度

    • HTTP:由于没有加密和解密过程,相对速度更快。
    • HTTPS:需要加密和解密,速度相对慢一些,但现代浏览器和服务器已优化了HTTPS性能,速度差异很小。
  5. SEO优先级

    • HTTPS:被搜索引擎(如Google)优先考虑,更有利于SEO优化。

总之,HTTPS在传输安全性方面优于HTTP,更适用于需要保护用户数据的场景,例如在线支付、登录系统等。

htttps的原理

HTTPS(HyperText Transfer Protocol Secure)是一种在HTTP协议基础上,通过SSL/TLS加密来保证通信安全的协议。它通过加密、数据完整性验证和身份验证,来保护用户与服务器之间的数据传输。以下是HTTPS的工作原理和详细流程:

1. 加密协议:SSL/TLS

  • HTTPS采用SSL(Secure Sockets Layer)或TLS(Transport Layer Security)协议进行加密。TLS是SSL的升级版,更安全、更高效,目前大多数网站使用TLS。

2. HTTPS的工作流程

HTTPS的整个工作流程可以分为几个关键步骤:

2.1 客户端与服务器握手
  1. 客户端请求连接:客户端(如浏览器)向服务器发起HTTPS连接请求,并发送一个“Client Hello”消息,其中包含客户端支持的加密算法和TLS版本。

  2. 服务器响应:服务器收到请求后,回复“Server Hello”消息,包含服务器选择的加密算法、TLS版本以及服务器的SSL证书(包含公钥)。

2.2 验证服务器身份
  1. 验证证书:客户端收到服务器证书后,通过证书颁发机构(CA)验证该证书的合法性。如果证书无误,继续进行下一步;如果证书有问题,浏览器会发出警告。

  2. 检查域名:客户端还会验证证书中的域名是否与服务器的域名匹配,以确保连接的是合法的服务器。

2.3 生成会话密钥
  1. 生成会话密钥:客户端生成一个“会话密钥”,并用服务器的公钥对该会话密钥加密后发送给服务器。

  2. 服务器解密会话密钥:服务器用其私钥解密出会话密钥。此时,客户端和服务器都拥有相同的会话密钥,用于后续的数据传输。

2.4 建立加密通信
  • 加密传输:通过会话密钥,客户端和服务器之间的通信内容都将以对称加密的方式进行传输,加密算法由双方协商确定。
  • 数据完整性验证:每次发送数据时,会添加一个消息验证代码(Message Authentication Code, MAC),用于验证数据的完整性,防止数据在传输过程中被篡改。

3. HTTPS的核心机制

HTTPS的核心机制包括身份验证加密数据完整性

  • 身份验证:通过SSL/TLS证书,客户端可以确认服务器的身份,确保用户访问的是真实的服务器,而不是伪造的钓鱼网站。
  • 加密:利用对称加密和非对称加密的组合来确保传输的数据是安全的。
    • 对称加密(如AES)用于加密实际数据,因为对称加密速度较快。
    • 非对称加密(如RSA)用于传输会话密钥,因为非对称加密速度慢但安全性高。
  • 数据完整性:每次传输的数据都会附加MAC,以防数据被篡改,确保数据完整性。

4. HTTPS握手中的关键概念

  • 会话密钥(Session Key):由客户端生成的用于会话期间的数据加密的密钥,确保通信效率和安全性。
  • 数字证书:由CA签发,证书包含服务器的公钥、域名和签名信息,用来证明服务器的身份。
  • 非对称加密和对称加密的结合:初始握手阶段用非对称加密传递会话密钥,后续数据传输使用对称加密提高效率。

5. HTTPS性能优化

尽管HTTPS增加了一些额外的计算和网络开销,但现代HTTPS协议通过一些技术优化来提升性能:

  • 会话复用:如果客户端和服务器之前已有过TLS连接,可以复用之前的会话参数,减少握手次数。
  • HTTP/2协议:支持多路复用和头部压缩,提升了HTTPS的传输效率。
  • 证书透明度:通过证书透明度机制,浏览器可以快速检验证书的合法性,减少延迟。

6. HTTPS的优缺点

  • 优点

    • 提供加密保护、防止数据被窃听;
    • 验证服务器身份、防止用户访问虚假网站;
    • 增强SEO排名,有助于网站可信度。
  • 缺点

    • 需要SSL/TLS证书,成本较高;
    • 增加握手过程和加解密开销,稍微影响传输速度。

总结

HTTPS通过SSL/TLS协议实现加密通信,利用非对称加密来验证身份,生成会话密钥,通过对称加密确保数据传输的安全和完整性。握手流程虽然复杂,但确保了用户数据的机密性和完整性,在现代网络安全中是不可或缺的部分。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/2227243.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

Docker | 将本地项目发布到阿里云的实现流程

发布到阿里云 本地镜像发布到阿里云流程具体流程1. docker commit 生成新镜像文件2. 查看镜像3. 阿里云开发者平台选择控制台,进入容器镜像服务,选择个人实例创建命名空间仓库名称进入管理界面获得脚本推送到阿里云 补充: docker tag 命令基本…

基于Pyecharts的数据可视化开发(二)调用通义千问api分析爬虫数据

上一篇博客做了关于“广州市2023年天气情况”的数据爬取,并保存为.csv文件。下一步是想用生成的.csv文件,直接调用大模型api进行分析,得出结论。通过调研,阿里云的通义千问大模型qwen-long可以实现对文件数据的分析。 通义千问大模…

【C++】入门C++

1.C的第一个程序 之前写的C语言文件都是后缀为.c的文件,进入C后就要把后缀改为.c了,vs编译器看到是.cpp就会调⽤C编译器编译。C兼容C语言的绝大多数语法,所以C语言的 hallo word 依旧可以在C下使用。 //test.cpp //c语言的hallo world #inc…

快速上手机器学习-朴素贝叶斯

朴素贝叶斯 引言:本文通过介绍先验概率,后验概率,条件概率计算和贝叶斯定理等概率论内容引入朴素贝叶斯分类算法的基本思路,朴素贝叶斯的最终分类思想是将输入分类给概率最大的类,这也是概率模型算法的共有思想。本文专…

【测试平台】打包 子节点android环境配置

背景 本文记录不是安卓Gradle打包,因为我们google play提审,为了规避跟下架包的相似度避免马甲包封号,使用混淆逻辑。 打包环境部署 申请对应虚拟机会有两个账号root和admin,主要避免root账号权限过高造成脚本误操作。这里面问题…

模型融合新趋势!Transformer领域专家纷纷布局,高分成果轻松达成!

今天给大家分享一个能发A会且不卷的方向:模型融合! 光是ICLR2025的投稿,其增长就跃升至前30,可见热度很高!但相比其他领域,总量还不大,相对蓝海,创新空间很大。 其所以这么热门&am…

1.机器人抓取与操作介绍-深蓝学院

介绍 操作任务 操作 • Insertion • Pushing and sliding • 其它操作任务 抓取 • 两指(平行夹爪)抓取 • 灵巧手抓取 7轴 Franka 对应人的手臂 6轴 UR构型去掉一个自由度 课程大纲 Robotic Manipulation 操作 • Robotic manipulation refers…

spark豆瓣书籍推荐系统-计算机毕业设计源码53447

摘要 本论文主要论述了如何基于Spark开发一个豆瓣书籍推荐系统,本系统将严格按照软件开发流程进行各个阶段的工作,面向对象编程思想进行项目开发。在引言中,作者将论述豆瓣书籍推荐系统的当前背景以及系统开发的目的,后续章节将严…

macOS开发环境配置与应用开发教程

macOS开发环境配置与应用开发教程 引言 macOS是一个强大的操作系统,广泛应用于软件开发,尤其是iOS和macOS应用开发。本文将详细介绍如何配置macOS开发环境,并通过实例演示如何进行应用开发。希望通过这篇文章,帮助读者快速上手m…

Unity吃鸡背包系统笔记

功能需求 查看玩家拥有的所有物品,可以放下其中的任意物品;查看已死的他人背包的物品,可以拿起其中的任意物品;查看附近的物品,可以拿起其中的任意物品(暂时不考虑背包容量); 难点 …

《Linux系统编程篇》fork函数——基础篇

文章目录 引言fork() 函数概述父子进程 fork函数fork() 的常见问题fork() 的优势与限制 结论 命为志存。 —— 朱熹 引言 《Linux系统编程篇》——基础篇首页传送门 本节我们正式进入Linux的进程代码编写。 fork() 是 Unix 系统中一个重要的系统调用,用于创建一个…

MySQL 8 下载与安装攻略

MySQL是一个流行的关系型数据库管理系统,目前MySQL属于Oracle公司的,关于MySQL的详细介绍可以参考: MySQL 的完整介绍 本篇主要关注MySQL 的下载和安装。 MySQL 下载 官方下载 进入MySQL 的下载页面 :https://dev.mysql.com/do…

HarmonyOS 鸿蒙开发 路由跳转报错this uri is empty, not support in route push.

检查方案1: 工程目录下 entry > src > main > resources > base > profile > main_pages.json中检查是否配置了NextPage 检查方案2: 在路由跳转的代码中检查是否路径配置错误 这里要注意,url的路径一定要和main_pages.json…

芯片上音频相关的验证

通常芯片设计公司(比如QUALCOMM)把芯片设计好后交由芯片制造商(比如台积电)去生产,俗称流片。芯片设计公司由ASIC部门负责设计芯片。ASIC设计的芯片只有经过充分的验证(这里说的验证是FPGA(现场…

【VSCode】配置

安装插件 C vscode-icons gdb调试 https://www.bilibili.com/video/BV15U4y1x7b2/?spm_id_from333.999.0.0&vd_sourcedf0ce73d9b9b61e6d4771898f1441f7f https://www.bilibili.com/video/BV1pU4y1W74Z?spm_id_from333.788.recommend_more_video.-1&vd_sourcedf0…

springboot使用枚举作为接口的参数

1.定义枚举类 2.定义接口 3.具体实现方法 4.apifox传入参数 枚举的具体’名称’就可以了 5.调试 6.进入断点,这样我们发现在接口的参数就映射到应的枚举类上了

数据结构(8.4_3)——堆的插入删除

在堆中插入新元素 在堆中删除元素 总结:

《计算机网络网络层:连接虚拟世界的关键桥梁》

一、网络层概述 网络层在计算机网络中占据着至关重要的地位,它作为连接不同网络的关键层次,起着承上启下的作用。网络层的主要任务是实现网络互连,将数据设法从源端经过若干个中间节点传送到目的端,为分组交换网上的不同主机提供通…

【linux】fdisk磁盘分区管理

介绍 fdisk是一个磁盘分区管理工具,可以用来创建、删除、修改和查看磁盘分区。 fdisk一般都是交互式使用,基础语法: fdisk /dev/sdd。进入交互窗口后,有一些选项,需要了解下: 选项含义n创建新分区p查看磁盘的分区情…

项目成本管理系统有哪些功能?9款工具详解

本文推荐的9大主流项目成本管理工具有: 1. PingCode;2. Worktile;3. 用友U8项目管理;4. 金蝶K3 Cloud;5. 泛微e-Project;6. 亿方云项目管理; 7. SAP Project System; 8. Trello; 9. …