[Osgeo4w-trac] [osgeo4w] #715: ssl.SSLError: A failure in the SSL library occurred (_ssl.c:1129)
OSGeo4W
trac_osgeo4w at osgeo.org
Wed May 4 23:48:41 PDT 2022
#715: ssl.SSLError: A failure in the SSL library occurred (_ssl.c:1129)
------------------------+----------------------------
Reporter: andreaerdna | Owner: osgeo4w-dev@…
Type: defect | Status: closed
Priority: major | Component: Package
Version: | Resolution: fixed
Keywords: |
------------------------+----------------------------
Comment (by andreaerdna):
Replying to [comment:5 jef]:
> Grmpf, tried the patch without success. `prgcloud.com` still fails. On
a closer look this is (meanwhile?) because its certificate is for
`www.prgcloud.com`. `www.prgcloud.com` and `www.python.org` work fine.
>
> Guess the fix for #696 cured this too.
I cannot confirm the fixing of this bug.
With both the OSGeo4W v2 shell and the Python console of QGIS 3.22.6 and
3.24.2, the test.py Python scripts returns:
{{{
C:\OSGeo4W_V2>python3 test.py
ssl prgcloud.com: FAIL A failure in the SSL library occurred (_ssl.c:1129)
urllib prgcloud.com: FAIL <urlopen error A failure in the SSL library
occurred (_ssl.c:1129)>
ssl www.prgcloud.com: FAIL A failure in the SSL library occurred
(_ssl.c:1129)
urllib www.prgcloud.com: FAIL <urlopen error A failure in the SSL library
occurred (_ssl.c:1129)>
ssl www.python.org: OK
urllib www.python.org: OK
}}}
With the Python console of QGIS 3.22.6 and 3.24.2, the following script:
{{{
import ssl
import socket
socketHandler = socket.socket(socket.AF_INET, socket.SOCK_STREAM)
socketWraped = ssl.create_default_context().wrap_socket(socketHandler,
server_hostname='www.prgcloud.com')
socketWraped.connect(('www.prgcloud.com', 443))
}}}
returns:
{{{
Traceback (most recent call last):
File "C:\OSC726~1\apps\Python39\lib\code.py", line 90, in runcode
exec(code, self.locals)
File "<input>", line 1, in <module>
File "C:\OSC726~1\apps\Python39\lib\ssl.py", line 1342, in connect
self._real_connect(addr, False)
File "C:\OSC726~1\apps\Python39\lib\ssl.py", line 1333, in _real_connect
self.do_handshake()
File "C:\OSC726~1\apps\Python39\lib\ssl.py", line 1309, in do_handshake
self._sslobj.do_handshake()
ssl.SSLError: A failure in the SSL library occurred (_ssl.c:1129)
}}}
With the OSGeo4W v1 shell and the Python console of QGIS 3.16.16 (OSGeo4W
v1), the test.py Python script returns:
{{{
C:\Program Files\QGIS 3.16.16v1>python3 test.py
ssl prgcloud.com: FAIL [SSL: CERTIFICATE_VERIFY_FAILED] certificate verify
failed: Hostname mismatch, certificate is not valid for 'prgcloud.com'.
(_ssl.c:1045)
urllib prgcloud.com: FAIL <urlopen error [SSL: CERTIFICATE_VERIFY_FAILED]
certificate verify failed: Hostname mismatch, certificate is not valid for
'prgcloud.com'. (_ssl.c:1045)>
ssl www.prgcloud.com: OK
urllib www.prgcloud.com: OK
ssl www.python.org: OK
urllib www.python.org: OK
}}}
With the Python console of QGIS 3.16.16 (OSGeo4W v1), the following
script:
{{{
import ssl
import socket
socketHandler = socket.socket(socket.AF_INET, socket.SOCK_STREAM)
socketWraped = ssl.create_default_context().wrap_socket(socketHandler,
server_hostname='www.prgcloud.com')
socketWraped.connect(('www.prgcloud.com', 443))
}}}
returns no error.
--
Ticket URL: <https://trac.osgeo.org/osgeo4w/ticket/715#comment:7>
OSGeo4W <http://trac.osgeo.org/osgeo4w>
OSGeo4W is the Windows installer and package environment for the OSGeo stack.
More information about the Osgeo4w-trac
mailing list