博客
关于我
面试题二十四:网络协议Https
阅读量:598 次
发布时间:2019-03-11

本文共 984 字,大约阅读时间需要 3 分钟。

一、HTTPS是什么?

HTTPS(Hyper Text Transfer Protocol Secure)并非独立的协议,而是基于SSL/TLS协议的加密HTTP协议。通过在传统HTTP之上叠加SSL/TLS层,实现了数据传输的安全性。简单而言,HTTPS = HTTP + SSL/TLS。

1. HTTPS的概念

HTTPS并非单独存在,而是建立在SSL/TLS协议之上。通过在HTTP通信中引入SSL/TLS加密层,确保数据传输过程中的安全性。这种设计使得HTTPS既保持了HTTP协议的简单性,又增加了SSL/TLS的安全性。

2. SSL/TLS协议

SSL(Secure Sockets Layer)是一种经典的安全传输协议,而TLS(Transport Layer Security)是其第三版本(SSL v3.0)的升级版。SSL/TLS协议通过在应用程序和底层网络协议之间建立安全加密层,保障数据传输的安全性。

3. HTTPS的整体架构

HTTPS采用客户端-服务器模型,通信过程遵循以下步骤:客户端发起HTTPS请求,服务器响应并提供证书,双方建立加密连接,进行数据传输,最后关闭连接。整个过程依赖于SSL/TLS协议实现安全性。

4. HTTPS的传输速度

HTTPS的传输速度主要受以下因素影响:通信延迟和SSL/TLS的加密处理。与传统HTTP相比,HTTPS由于加密过程增加了计算负担,可能略低于HTTP的传输速度。但随着技术进步,现代浏览器对SSL/TLS的实现越来越高效,传输速度差异也逐渐缩小。

二、TLS/SSL握手

1. 密码学原理

SSL/TLS协议的核心在于密码学原理。其包含以下两种加密方式:对称加密和非对称加密。对称加密使用相同密钥进行加密和解密,适合大量数据加密;非对称加密使用私有密钥和公有密钥,适合关键信息的安全传输。

2. 数字证书

数字证书在SSL/TLS握手中扮演重要角色。证书包含发送方的身份信息、公有密钥以及颁发机构的签名。通过数字证书,双方能够验证对方身份,确保通信安全。

3. SSL/TLS握手过程

SSL/TLS握手分为以下几个步骤:客户端发送证书请求,服务器响应证书,客户端验证服务器证书并生成会话密钥,双方建立加密连接。整个过程通过SSL/TLS协议确保安全性,保障数据传输的隐私和完整性。

转载地址:http://nbttz.baihongyu.com/

你可能感兴趣的文章
Ploly Dash,更新一个Dash应用程序JJJA上的实时人物
查看>>
Ploly烛台的定制颜色
查看>>
Ploly:如何在Excel中嵌入完全交互的Ploly图形?
查看>>
plotloss记录
查看>>
Plotly (Python) 子图:填充构面和共享图例
查看>>
Plotly 中的行悬停文本
查看>>
Plotly 停用 x 轴排序
查看>>
Plotly 域变量解释(多图)
查看>>
Plotly 绘制表面 3D 未显示
查看>>
Plotly-Dash 存在未知问题并创建“加载依赖项时出错“;通过使用 Python-pandas.date_range
查看>>
Plotly-Dash:如何过滤具有多个数据框列的仪表板?
查看>>
Plotly:如何为 x 轴上的时间序列设置主要刻度线/网格线的值?
查看>>
Plotly:如何从 x 轴删除空日期?
查看>>
Plotly:如何从单条迹线制作堆积条形图?
查看>>
Plotly:如何以 Root 样式绘制直方图,仅显示直方图的轮廓?
查看>>
Plotly:如何使用 Plotly Express 组合散点图和线图?
查看>>
Plotly:如何使用 plotly.graph_objects 和 plotly.express 定义图形中的颜色?
查看>>
Plotly:如何使用 Python 对绘图对象条形图进行颜色编码?
查看>>
Plotly:如何使用 updatemenus 更新一个特定的跟踪?
查看>>
Plotly:如何使用长格式或宽格式的 pandas 数据框制作线图?
查看>>