0

0

Python SSL 握手过程解析

冰川箭仙

冰川箭仙

发布时间:2026-01-19 17:03:08

|

242人浏览过

|

来源于php中文网

原创

SSL/TLS握手的核心目标是安全协商共享密钥并验证身份,发生在TCP连接后、应用数据传输前;Python ssl模块自动处理,但需理解四步流程及配置影响以排查证书、协议、套件等问题。

python ssl 握手过程解析

SSL/TLS 握手的核心目标

SSL/TLS 握手不是为了“加密数据”,而是为了在通信双方之间安全地协商出一组共享密钥,并确认对方身份。整个过程发生在 TCP 连接建立之后、应用层协议(如 HTTP)传输数据之前。Python 中的 ssl 模块(底层基于 OpenSSL)会自动完成大部分握手逻辑,但理解其步骤有助于排查连接失败、证书错误或兼容性问题。

典型四步握手流程(TLS 1.2 及以上)

以客户端主动发起 HTTPS 请求为例,实际交互包含以下关键环节:

  • ClientHello:客户端发送支持的 TLS 版本、加密套件列表(如 TLS_ECDHE_RSA_WITH_AES_128_GCM_SHA256)、随机数(client_random),以及可选的 SNI(Server Name Indication)扩展(用于虚拟主机场景)
  • ServerHello + Certificate + ServerKeyExchange + ServerHelloDone:服务端选择一个加密套件,返回自己的随机数(server_random),发送证书链(含公钥),若使用 ECDHE 等临时密钥交换算法,还会附带签名后的临时公钥参数
  • ClientKeyExchange + ChangeCipherSpec + Finished:客户端验证证书有效性(包括链式信任、域名匹配、有效期等),生成预主密钥(premaster secret),用服务端公钥加密后发送;随后双方基于 client_random、server_random 和 premaster secret 计算出相同的会话密钥(master secret → key block);最后发送加密的 Finished 消息,验证密钥是否一致
  • ChangeCipherSpec + Finished:服务端同样切换为加密通信,并发送自己的 Finished 消息。双方确认无误后,握手完成,开始传输加密的应用数据

Python 中影响握手的关键配置

使用 ssl.create_default_context() 或手动构建 SSLContext 时,以下设置会直接改变握手行为:

MaxAI
MaxAI

MaxAI.me是一款功能强大的浏览器AI插件,集成了多种AI模型。

下载
  • 证书验证开关context.check_hostname = True 启用主机名检查(默认开启);context.verify_mode = ssl.CERT_REQUIRED 强制验证服务端证书(生产环境必须);设为 CERT_NONE 会跳过全部验证(仅测试用,不安全)
  • 自定义 CA 证书:通过 context.load_verify_locations(cafile="ca-bundle.pem") 指定信任的根证书文件,适用于私有 PKI 或内网服务
  • 协议版本限制:调用 context.minimum_version = ssl.TLSVersion.TLSv1_2 可禁用老旧不安全版本(如 SSLv3、TLS 1.0)
  • 加密套件筛选:用 context.set_ciphers("ECDHE+AESGCM:!ECDSA") 显式指定优先使用的算法组合,避免协商到弱套件

常见握手失败原因与调试方法

ssl.SSLError 抛出时,错误信息往往指向具体阶段。例如:

立即学习Python免费学习笔记(深入)”;

  • red">[SSL: CERTIFICATE_VERIFY_FAILED]:证书不可信 —— 检查系统/Python 是否缺少根证书,或服务端证书链不完整(需补全中间证书)
  • [SSL: UNKNOWN_PROTOCOL]:服务端未启用 TLS,或客户端发了 HTTP 请求却期望 TLS 响应 —— 确认 URL 是 https://,且服务监听在 TLS 端口(如 443)
  • [SSL: HANDSHAKE_FAILURE]:加密套件不匹配、协议版本不兼容、SNI 未提供导致虚拟主机路由错误 —— 用 openssl s_client -connect example.com:443 -servername example.com 手动测试可辅助定位
  • 超时或连接重置:可能因防火墙拦截 TLS 流量、服务端 TLS 配置异常(如只支持 TLS 1.3 但客户端太旧),或网络中间设备(如某些代理)不支持 ALPN 扩展

相关专题

更多
python开发工具
python开发工具

php中文网为大家提供各种python开发工具,好的开发工具,可帮助开发者攻克编程学习中的基础障碍,理解每一行源代码在程序执行时在计算机中的过程。php中文网还为大家带来python相关课程以及相关文章等内容,供大家免费下载使用。

760

2023.06.15

python打包成可执行文件
python打包成可执行文件

本专题为大家带来python打包成可执行文件相关的文章,大家可以免费的下载体验。

639

2023.07.20

python能做什么
python能做什么

python能做的有:可用于开发基于控制台的应用程序、多媒体部分开发、用于开发基于Web的应用程序、使用python处理数据、系统编程等等。本专题为大家提供python相关的各种文章、以及下载和课程。

763

2023.07.25

format在python中的用法
format在python中的用法

Python中的format是一种字符串格式化方法,用于将变量或值插入到字符串中的占位符位置。通过format方法,我们可以动态地构建字符串,使其包含不同值。php中文网给大家带来了相关的教程以及文章,欢迎大家前来阅读学习。

619

2023.07.31

python教程
python教程

Python已成为一门网红语言,即使是在非编程开发者当中,也掀起了一股学习的热潮。本专题为大家带来python教程的相关文章,大家可以免费体验学习。

1285

2023.08.03

python环境变量的配置
python环境变量的配置

Python是一种流行的编程语言,被广泛用于软件开发、数据分析和科学计算等领域。在安装Python之后,我们需要配置环境变量,以便在任何位置都能够访问Python的可执行文件。php中文网给大家带来了相关的教程以及文章,欢迎大家前来学习阅读。

549

2023.08.04

python eval
python eval

eval函数是Python中一个非常强大的函数,它可以将字符串作为Python代码进行执行,实现动态编程的效果。然而,由于其潜在的安全风险和性能问题,需要谨慎使用。php中文网给大家带来了相关的教程以及文章,欢迎大家前来学习阅读。

579

2023.08.04

scratch和python区别
scratch和python区别

scratch和python的区别:1、scratch是一种专为初学者设计的图形化编程语言,python是一种文本编程语言;2、scratch使用的是基于积木的编程语法,python采用更加传统的文本编程语法等等。本专题为大家提供scratch和python相关的文章、下载、课程内容,供大家免费下载体验。

709

2023.08.11

PHP WebSocket 实时通信开发
PHP WebSocket 实时通信开发

本专题系统讲解 PHP 在实时通信与长连接场景中的应用实践,涵盖 WebSocket 协议原理、服务端连接管理、消息推送机制、心跳检测、断线重连以及与前端的实时交互实现。通过聊天系统、实时通知等案例,帮助开发者掌握 使用 PHP 构建实时通信与推送服务的完整开发流程,适用于即时消息与高互动性应用场景。

11

2026.01.19

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
最新Python教程 从入门到精通
最新Python教程 从入门到精通

共4课时 | 5万人学习

Django 教程
Django 教程

共28课时 | 3.2万人学习

SciPy 教程
SciPy 教程

共10课时 | 1.2万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号