面试突击65:为什么要用HTTPS?它有什么优点?

说到 HTTPS 相信大部分人都是不陌生,因为目前我们使用的绝大数网站都是基于 HTTPS 的,比如以下这些:

面试突击65:为什么要用HTTPS?它有什么优点?
面试突击65:为什么要用HTTPS?它有什么优点?
面试突击65:为什么要用HTTPS?它有什么优点?
那么问题来了,他们为什么要使用 HTTPS 呢?HTTPS 有哪些过人之处呢?

1.HTTP

在说 HTTPS 之前,我们先要了解 HTTP,因为 HTTP 是 HTTPS 通讯的基础。
HTTP(HyperText Transport Protocol)超文本传输协议,它用于传输客户端和服务器端的数据。
HTTP 使用很简单也很方便,但却存在以下 3 个致命问题:

  1. 使用明文通讯,内容可以被窃听。
  2. 不验证通讯方的真实身份,可能会遭到伪装。
  3. 无法证明报文的完整性,很容易被篡改。

鉴于以上问题,所以现在的系统会使用 HTTPS 来替代 HTTP。

2.HTTPS

首先来说,HTTPS 并不是一种新的协议,而是在 HTTP 协议的基础上添加了加密机制 SSL(Secure Socket Layer)或 TLS(Transport Layer Security)。
HTTPS = HTTP + 加密 + 认证 + 完整性保护。

SSL 和 TLS

SSL(Secure Socket Layer)最早是由浏览器开发厂商网景公司开发的,此公司开发了 SSL 3.0 及 3.0 之前的版本,之后便将 SSL 交给了 IETF(Internet Engineering Task Force)Internet 工程任务组的手中,IETF 以 SSL 3.0 为基础开发了 TLS 1.0,所以可以认为 TLS 是 SSL 的”新版本”。

2.1 解决信任问题

作为 HTTPS 来说,首先要解决的就是信任问题,也就是身份效验的问题,如果不解决信任问题就会存在服务器伪装,也就是”中间人攻击”的问题。
所谓的中间人攻击指的是,正常情况下本该是客户端和服务端直接进行交互的,但此处冲出来一个”坏人”(中间人),它包含在客户端和服务器端之间,用于盗取和篡改双方通讯的内容,如下图所示:

面试突击65:为什么要用HTTPS?它有什么优点?
HTTPS 解决信任问题采用的是数字证书的解决方案,也就是服务器在创建之初,会先向一个大家都认可的第三方平台申请一个可靠的数字证书,然后在客户端访问(服务器端)时,服务器端会先给客户端一个数字证书,以证明自己是一个可靠的服务器端,而非”中间人”。
此时浏览器会负责效验和核对数字证书的有效性,如果数字证书有问题,那么客户端会立即停止通讯,如果没问题才会执行后续的流程,如下图所示:
面试突击65:为什么要用HTTPS?它有什么优点?
有了数字证书之后,就可以验证服务器端的真实身份了,这样就解决了”中间人攻击”的问题,也解决了伪装的问题。

2.2 解决明文传输和完整性问题

虽然上面我们已经解决了信任问题,然而因为通讯双方是明文通讯的,所以在通讯时依然存在通讯内容被窃听的风险,此时应该怎么办呢?
于是我们想到,使用加密来解决信息暴露的问题。

加密的分类

加密主要分为两大类:对称加密和非对称加密。

  • 在对称加密中,有一个共享秘钥,通过这把共享秘钥可以实现信息的加密和信息的解密,它的特点是加密和解密的速度很快,但因为共享秘钥的问题,一旦共享秘钥被截获,那么所谓的加密和解码也就是一纸空谈了。
  • 在非对称加密中,有一对秘钥:公钥和私钥,使用公钥可以加密信息,但不能解密信息,使用私钥可以解密信息。它的特点是服务器端保存私钥,不对外暴露,只将公钥发送给客户端,而其他人即使拿到公钥,也解密不了加密的信息,所以此方式更安全,但非对称加密的执行速度比较慢。

那在 HTTPS 中要使用对称加密还是非对称加密呢?
使用对称加密,速度快,但不安全;使用非对称加密安全,但速度慢。
只有小孩做选择,成年人都要,所以 HTTPS 中既使用了非对称加密也使用了对称加密,它的整个交互流程是这样的:

面试突击65:为什么要用HTTPS?它有什么优点?
HTTPS 执行流程如下:
  1. 客户端使用 HTTPS 访问服务器端。
  2. 服务器端返回数字证书,以及使用非对称加密,生成一个公钥给客户端(私钥服务器端自己保留)。
  3. 客户端验证数字证书是否有效,如果无效,终止访问,如果有效:
  4. 使用对称加密生成一个共享秘钥;
  5. 使用对称加密的共享秘钥加密数据;
  6. 使用非对称加密的公钥加密(对称加密生成的)共享秘钥。
  7. 发送加密后的秘钥和数据给服务器端。
  8. 服务器端使用私钥解密出客户端(使用对称加密生成的)共享秘钥,再使用共享秘钥解密出数据的具体内容。
  9. 之后客户端和服务器端就使用共享秘钥加密的内容内容进行交互了。

这样,HTTPS 既保证了安全性,同时又保证了高效性,可谓鱼和熊掌兼得。

使用加密的方式也间接的保证了数据的完整性问题,如果是不完整的数据或有多余的数据,那么在解密时会报错,这样就能间接的保证数据的完整性了。

总结

使用 HTTP 协议存在明文通讯和中间人攻击等问题,但这些问题在 HTTPS 中得到了有效的解决,HTTPS 通过数字证书解决了中间人攻击的问题,使用加密手段解决了明文通讯和数据完整性的问题。

参考 & 鸣谢

《图解HTTP》

《图解TCP/IP网络知识轻松入门》

是非审之于己,毁誉听之于人,得失安之于数。
公众号:Java面试真题解析
面试合集:https://gitee.com/mydb/interview

Original: https://www.cnblogs.com/vipstone/p/16472508.html
Author: Java中文社群
Title: 面试突击65:为什么要用HTTPS?它有什么优点?

原创文章受到原创版权保护。转载请注明出处:https://www.johngo689.com/539332/

转载文章受原作者版权保护。转载请注明原作者出处!

(0)

大家都在看

  • 【一】pig4cloud项目一键build — 容器中安装build环境

    容器基础配置 1、安装centos 容器 docker-compose.yaml 文件内容,指定一个映射目录 version: ‘3’ services: centos-build…

    Java 2023年6月8日
    078
  • Java序列化和反序列化

    在我们实际使用中,我们经常会遇到对象需要序列化的问题。我将通过下面几个问题,理解序列化的相关问题 什么是序列化和反序列化 序列化:把Java内存对象转换为字节序列的过程称为对象的序…

    Java 2023年6月7日
    063
  • 使用SLF4J和LOGBACK (一 : 基本使用)

    上边两行代码中的Logger和LoggerFactory对象均来自SLF4J包中。 具体的日志实现框架,我们可以选择LOG4J,LOGBACK等作为日志的具体实现,但是日志的打印输…

    Java 2023年6月16日
    088
  • linux开放8080等其他端口命令

    防火墙中配置开放 8080端口 注:以下命令只针对 CentOs 7 以上版本,CentOS升级到7之后,无法使用iptables控制Linux的端口,原因是Centos 7使用f…

    Java 2023年6月6日
    094
  • Nginx

    是一个高性能的 HTTP 和反向代理服务器,特点是占有内存少,并发能力强,事实上 nginx 的并发能力确实在同类型的网页服务器中表现较好。 Nginx 可以作为静态页面的 web…

    Java 2023年6月8日
    075
  • 如何使用 RSA 加密 JWT

    <dependency> <groupid>com.nimbusds</groupid> <artifactid>nimbus-jo…

    Java 2023年6月7日
    083
  • SSM整合过程中遇到的BUG 数据库连接的问题

    SSM整合过程中遇到的BUG 数据库连接的问题service调用mybatis时报异常 org.springframework.web.util.NestedServletExce…

    Java 2023年6月5日
    090
  • Java简介

    J2SE:平台标准版,可以做桌面程序开发 他是整个java技术的基础和核心 J2EE:平台企业版,可以做网站 J2ME:平台微型版,可以做移动端程序开发 简单性:舍弃了c++中难以…

    Java 2023年5月29日
    066
  • Day9

    package array;public class ArrayDemo1 { //变量类型 变量的名字 = 变量的值 //数组类型 public static void main…

    Java 2023年6月5日
    045
  • mysql

    一:什么情况下设置了索引但无法使用1.以%开头的like语句,模糊匹配2.or语句前后没有同时使用索引3.数据类型出现隐式转化 二:优化数据库的方法1.选取最适用的字段属性2.使用…

    Java 2023年6月5日
    095
  • 枚举.Java学习

    今天复习一下Java里面的 枚举 。 枚举简介 使用enum关键字开发一个枚举类的时候,这个类会默认继承Enum系统类。而且是一个final类。 当多个枚举存在时候。需要逗号分隔,…

    Java 2023年6月9日
    052
  • rabbitmq安装

    rabbitmq简介 rabbitmq安装 rabbitmq是erlang语言开发的,rabbitmq安装需要先安装erlang,再安装rabbitmq; ​ 官方网址: 双击安装…

    Java 2023年6月16日
    061
  • JVM内存模型和结构详解(五大模型图解)

    JVM内存模型和Java内存模型都是面试的热点问题,名字看感觉都差不多,实际上他们之间差别还是挺大的。 通俗点说,JVM内存结构是与JVM的内部存储结构相关,而Java内存模型是与…

    Java 2023年6月15日
    061
  • Java 大后端各种架构图汇总(建议收藏!!)

    来源:https://blog.csdn.net/qq_37651267/article/details/95244623 1. java 类加载器架构 2. JVM 架构 3. …

    Java 2023年5月29日
    080
  • Swagger学习

    Swagger学习 笔记记录 B站狂神说一小时掌握Swagger技术 https://www.bilibili.com/video/BV1Y441197Lw?p=4&spm…

    Java 2023年6月14日
    079
  • Thymeleaf小记

    最近学习javaweb 之前将很多的学习时间都用在了jsp 和 JQREY 的学习上,但是最近发现已经过时了,本来想学好后做项目的但是发现过时后很伤心,想做项目的心已经凉了,作为代…

    Java 2023年6月8日
    063
亲爱的 Coder【最近整理,可免费获取】👉 最新必读书单  | 👏 面试题下载  | 🌎 免费的AI知识星球