如何使用mechanize在Python中打开SSL URL?
我正在尝试在Ubuntu上使用Python 2.7.3进行简单的页面检索,如下所示:
import mechanize
browser = mechanize.Browser()
resp = browser.open('https://mydomain.com')但是它抛出了错误:
urllib2.URLError: <urlopen error [Errno 1] _ssl.c:504: error:140773E8:SSL routines:SSL23_GET_SERVER_HELLO:reason(1000)>奇怪的是,当我在Fedora上的Python 2.6.4下运行同样的代码时,我没有得到这个错误...
据推测,这可能不是机械化的直接问题,而是urllib2和底层SSL库的问题。谷歌搜索显示的点击率很低。有解决办法吗?
编辑:我找到了这个old bug report,并提供了一个建议的解决方法(基本上,Python尝试将SSLv23用于仅支持SSLv3的站点),但该代码却导致错误httplib.BadStatusLine: ''
发布于 2014-06-12 11:11:13
此问题可能是由于web服务器上禁用了SSLv2造成的,但默认情况下,Python2.x会尝试与PROTOCOL_SSLv23建立连接。这发生在https://github.com/python/cpython/blob/master/Lib/ssl.py#L867
与复制和编辑Python库模块不同,您可以通过覆盖ssl_version关键字参数在ssl模块中修补ssl.wrap_socket()。以下代码可以按原样使用。在提出任何请求之前,请将这段代码放在程序的开头。
import ssl
from functools import wraps
def sslwrap(func):
@wraps(func)
def bar(*args, **kw):
kw['ssl_version'] = ssl.PROTOCOL_TLSv1
return func(*args, **kw)
return bar
ssl.wrap_socket = sslwrap(ssl.wrap_socket)https://stackoverflow.com/questions/11197841
复制相似问题