热门标签 | HotTags
当前位置:  开发笔记 > 后端 > 正文

什么是Https?

Https就是为了解决Http的缺点而生的一种通讯方式。Https由Http+加密+认证+数据完整性得到。也就是说将这些信息组合到一起就是Https。Https并不是一种新的应用层

Https就是为了解决Http的缺点而生的一种通讯方式。

Https由Http+加密+认证+数据完整性得到。也就是说将这些信息组合到一起就是Https。Https并不是一种新的应用层协议,而是SSL和TLS,Http组合得到的。如下图:

《什么是Https?》

可以看到如果没有SSL,Http直接和TCP通讯,当有了SSL这一层Https相当于中间人帮我们处理这些安全的事情。这样我们就省心多了。

Https工作流程

要完全弄清楚是很复杂的,同时也违背了我们这门课程的最终目的。所有这里简单总结下,详细的大家可以参考权威的书籍:

1. 当用户访问Https网站时,服务端将自己的证书发送给浏览器,里面包含了网址,用于加密的公钥,以及证书颁发机构等信息

2. 浏览器得到证书,访问证书的颁发机构校验证书的合法性,如果合法则生成一个随机字符串用作后续通讯过程中的加密key,然后用证书的公钥加密,将随机生成的key和加密后的数据在发送到服务端

3. 服务端拿到接收的key,和加密的信息,通过私钥解密,比较是否一致,如果一致则使用该字符串作为后面的数据通讯的加密key。并且在返回一串字符和加密的字符

4. 浏览器拿到这些数据和服务端一样,解密校验是否一样,如果一样,那握手就结束了,后面就使用上面随机生成的key作为后续通讯的加密key

需要注意的是上述任何一个步骤失败都会终止该次握手。

另外上面说的是后面的加密key使用的是客户端随机生成的key,在这一步我们也可以使用预先生成的证书放到客户端,这样后面的加密使用这个公钥,而不是随机字符串。

大概流程就是这样。

如果想知道如何在Okhttp中使用Https,请点击《详解Okhttp网络框架电子书》查看完整版电子书。

本文来自《详解Okhttp网络框架电子书》,视频教程也可以通过:爱学啊官网、腾讯课堂、网易云课堂、淘宝教育学习。

《什么是Https?》


推荐阅读
  • 网络攻防实战:从HTTP到HTTPS的演变
    本文通过一系列日记记录了从发现漏洞到逐步加强安全措施的过程,探讨了如何应对网络攻击并最终实现全面的安全防护。 ... [详细]
  • 优化ListView性能
    本文深入探讨了如何通过多种技术手段优化ListView的性能,包括视图复用、ViewHolder模式、分批加载数据、图片优化及内存管理等。这些方法能够显著提升应用的响应速度和用户体验。 ... [详细]
  • 本文详细介绍了如何在Linux系统上安装和配置Smokeping,以实现对网络链路质量的实时监控。通过详细的步骤和必要的依赖包安装,确保用户能够顺利完成部署并优化其网络性能监控。 ... [详细]
  • 本文介绍如何在QT框架中使用QWebSocket和QTcpSocket实现SSL加密通信,涵盖单向认证设置。单向认证常见于Web通信场景,其中客户端验证服务端证书,而服务端不验证客户端证书。 ... [详细]
  • 深入理解OAuth认证机制
    本文介绍了OAuth认证协议的核心概念及其工作原理。OAuth是一种开放标准,旨在为第三方应用提供安全的用户资源访问授权,同时确保用户的账户信息(如用户名和密码)不会暴露给第三方。 ... [详细]
  • 本文将介绍如何编写一些有趣的VBScript脚本,这些脚本可以在朋友之间进行无害的恶作剧。通过简单的代码示例,帮助您了解VBScript的基本语法和功能。 ... [详细]
  • 深入理解Cookie与Session会话管理
    本文详细介绍了如何通过HTTP响应和请求处理浏览器的Cookie信息,以及如何创建、设置和管理Cookie。同时探讨了会话跟踪技术中的Session机制,解释其原理及应用场景。 ... [详细]
  • 本文详细介绍了Java编程语言中的核心概念和常见面试问题,包括集合类、数据结构、线程处理、Java虚拟机(JVM)、HTTP协议以及Git操作等方面的内容。通过深入分析每个主题,帮助读者更好地理解Java的关键特性和最佳实践。 ... [详细]
  • 尽管某些细分市场如WAN优化表现不佳,但全球运营商路由器和交换机市场持续增长。根据最新研究,该市场预计在2023年达到202亿美元的规模。 ... [详细]
  • 360SRC安全应急响应:从漏洞提交到修复的全过程
    本文详细介绍了360SRC平台处理一起关键安全事件的过程,涵盖从漏洞提交、验证、排查到最终修复的各个环节。通过这一案例,展示了360在安全应急响应方面的专业能力和严谨态度。 ... [详细]
  • 在现代网络环境中,两台计算机之间的文件传输需求日益增长。传统的FTP和SSH方式虽然有效,但其配置复杂、步骤繁琐,难以满足快速且安全的传输需求。本文将介绍一种基于Go语言开发的新一代文件传输工具——Croc,它不仅简化了操作流程,还提供了强大的加密和跨平台支持。 ... [详细]
  • MySQL 数据库迁移指南:从本地到远程及磁盘间迁移
    本文详细介绍了如何在不同场景下进行 MySQL 数据库的迁移,包括从一个硬盘迁移到另一个硬盘、从一台计算机迁移到另一台计算机,以及解决迁移过程中可能遇到的问题。 ... [详细]
  • 本文探讨如何设计一个安全的加密和验证算法,确保生成的密码具有高随机性和低重复率,并提供相应的验证机制。 ... [详细]
  • HTTP 请求与响应详解
    本文深入探讨了HTTP请求和响应的结构,详细解释了每个部分的作用,并提供了相关示例。通过本文,读者可以全面理解HTTP协议中请求和响应的工作原理。 ... [详细]
  • libsodium 1.0.15 发布:引入重大不兼容更新
    最新发布的 libsodium 1.0.15 版本带来了若干不兼容的变更,其中包括默认密码散列算法的更改和其他重要调整。 ... [详细]
author-avatar
赵lamarta
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有