【Python报错已解决】ssl_client_socket_impl.cc(992)] handshake failed; returned -1, SSL error code 1, net_er

在这里插入图片描述

🎬 鸽芷咕个人主页

 🔥 个人专栏: 《C++干货基地》《粉丝福利》

⛺️生活的理想,就是为了理想的生活!

  • 博主简介

博主致力于嵌入式、Python、人工智能、C/C++领域和各种前沿技术的优质博客分享,用最优质的内容带来最舒适的阅读体验!在博客领域获得 C/C++领域优质、CSDN年度征文第一、掘金2023年人气作者、华为云享专家、支付宝开放社区优质博主等头衔。

介绍加入链接
个人社群社群内包含各个方向的开发者,有多年开发经验的大佬,一起监督打卡的创作者,开发者、在校生、考研党、均可加入并且咱每周都会有粉丝福利放送保你有所收获,一起 加入我们 共同进步吧!
个人社区点击即可加入 【咕咕社区】 ,让我们一起共创社区内容,输出优质文章来让你的写作能力更近一步一起加油!

⛳️ 推荐

前些天发现了一个巨牛的人工智能学习网站,通俗易懂,风趣幽默,忍不住分享一下给大家。点击跳转到网站。

专栏介绍

专栏名称专栏介绍
科技杂谈本专栏主要撰写各种科技数码等的评测体验心得,带大家一起体验最前沿的科技机技术产品体验
C++干货基地本专栏主要撰写C++干货内容和编程技巧,让大家从底层了解C++,把更多的知识由抽象到简单通俗易懂。
《数据结构&算法》本专栏主要是注重从底层来给大家一步步剖析数据存储的奥秘,一起解密数据在存储中数据的基本存储结构!
《docker容器精解篇》全面深入解析 docker 容器,从基础到进阶,涵盖原理、操作、实践案例,助您精通 docker。
《linux深造日志》本专栏的标题灵感是来自linux中系统产生的系统日志。而我们也可以每天输出内容不断前进,以达到精深的境地。
《C语言进阶篇》想成为编程高手嘛?来看看《C语言进阶篇》成为编程高手的必学知识,带你一步步认识C语言最核心最底层原理。
写作技巧写作涨粉太慢?不知道如何写博客?想成为一名优质的博主那么这篇专栏你一定要去了解

在这里插入图片描述

前言

在使用SSL/TLS进行网络通信时,你可能会遇ssl_client_socket_impl.cc(992)] handshake failed; returned -1, SSL error code 1, net_error的错误。这个错误通常发生在SSL/TLS握手过程中出现问题,导致无法建立安全的连接。下面我们来分析这个问题并提供解决方案。

一、问题描述

1.1 报错示例

以下是一个可能导致ssl_client_socket_impl.cc(992)] handshake failed; returned -1, SSL error code 1, net_error错误的场景:

import socket
import ssl
context = ssl.create_default_context(ssl.Purpose.SERVER_AUTH)
with socket.create_connection(('example.com', 443)) as sock:
    with context.wrap_socket(sock, server_hostname='example.com') as ssock:
        print(ssock.version())

运行上述代码可能会抛出以下错误:

ssl.SSLError: [SSL: TLSV1_ALERT_UNKNOWN_CA] unknown ca in certificate (1)

1.2 报错分析

这个错误表明在SSL/TLS握手过程中,客户端无法验证服务器的证书,因为客户端不信任证书的颁发机构(CA)。

1.3 解决思路

为了解决这个问题,你需要确保客户端信任服务器的证书,或者配置客户端以信任证书。

二、解决方法

2.1 方法一:添加CA证书

如果你有服务器的CA证书,你可以将其添加到客户端的信任存储中:

import ssl
context = ssl.create_default_context(ssl.Purpose.SERVER_AUTH)
context.load_verify_locations('path/to/ca_cert.pem')

替换'path/to/ca_cert.pem'为你的CA证书路径。

2.2 步骤二:禁用证书验证(不推荐)

如果你在开发环境中,并且知道风险,你可以暂时禁用证书验证:

import ssl
context = ssl._create_unverified_context()

注意:禁用证书验证会降低安全性,因此不推荐在生产环境中使用。

三、其他解决方法

  • 检查服务器证书:确保服务器证书有效,并且由受信任的CA签名。
  • 更新客户端的CA证书库:确保客户端的CA证书库是最新的。
  • 检查网络配置:确保网络配置允许SSL/TLS通信,没有防火墙或代理阻止连接。

四、总结

本文介绍了如何解决ssl_client_socket_impl.cc(992)] handshake failed; returned -1, SSL error code 1, net_error错误。确保客户端信任服务器的证书是解决这个问题的关键。下次遇到类似错误时,你可以参考本文的方法来快速解决。记住,在处理SSL/TLS通信时,始终要确保证书的有效性和客户端的信任设置。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

鸽芷咕

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值