浅显了解http的SSL验证过程

本文探讨了Python中遇到的SSL证书验证失败问题,特别是针对自签名证书的情况。升级到Python 2.7.9后,系统开始默认验证SSL证书。为解决此问题,可以取消全局证书验证或创建未经验证的SSL上下文。文章详细解释了SSL验证过程,包括客户端如何检查服务器证书的合法性,并手绘图表辅助理解公钥加密和随机值R在通信安全中的作用。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

最近在进行HP打印机自动化验证的功能开发,其中有一处用到的是http请求来与打印机交互的。但测试的兄弟经常会出现”[SSL: CERTIFICATE_VERIFY_FAILED] certificate verify failed (_ssl.c:590).”的错误。经查证:这与SSL的自验证功能相关:

Python 升级到 2.7.9 之后引入了一个新特性,当使用urllib.urlopen打开一个 https 链接时,会验证一次 SSL 证书。而当目标网站使用的是自签名的证书时就会抛出一个 urllib2.URLError:(引用https://www.python.org/dev/peps/pep-0476/)

上述现象恰恰符合这边打印机的SSL验证机制。OK,按照网址中的解决办法:

1.取消全局证书验证

import ssl

ssl._create_default_https_context = ssl._create_unverified_context

2.使用ssl创建未经验证的上下文,在urlopen中传入上下文参数(略)

问题解决


但现在对上面的解决过程还有有很多疑惑:

  • “取消全局证书验证”是在干什么:
  • SSL又是怎么工作的;
  • 而当目标网站使用的是自签名的证书时就会抛出一个..”,这是什么原因。

好吧,看来我还是要把HTTPS中的SSL验证过程熟悉一遍才行,so, come on..

网上查了很多资料,写的都很教条,害的我认认真真看了1个小时的时间,现在手绘一张图一切就明白了:

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值