我在使用Python通过SNI代理服务器连接时遇到问题,以下代码片段显示了连接,执行脚本会导致不同的连接错误(握手,错误版本),具体取决于使用的ssl版本:
#!/usr/bin/python
import requests
import ssl
from requests.adapters import HTTPAdapter
try:
from requests.packages.urllib3.poolmanager import PoolManager
except:
from urllib3.poolmanager import PoolManager
class SSLAdapter(HTTPAdapter):
def init_poolmanager(self, connections, maxsize, block=False):
ssl_version=ssl.PROTOCOL_TLSv1
#ssl_version=ssl.PROTOCOL_SSLv23
#ssl_version=ssl.PROTOCOL_SSLv3
assert_hostname = 'netflix.com'
self.poolmanager = PoolManager(num_pools=connections,maxsize=maxsize,block=block,ssl_version=ssl_version,assert_hostname=assert_hostname)
def newSession():
s = requests.Session()
s.mount('https://', SSLAdapter())
s.headers.update({'User-Agent': 'User-Agent: Mozilla/5.0 (Macintosh; Intel Mac OS X 10_9_5) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/40.0.2214.6 Safari/537.36'})
return s
urlMain = "https://www.netflix.com"
session = None
session = newSession()
session.get(urlMain, verify=False).text这将导致:
requests.exceptions.SSLError: [Errno 1] _ssl.c:510: error:14094410:SSL routines:SSL3_READ_BYTES:sslv3 alert handshake failure查看来自sniproxy服务器的日志,您可以看到省略了servername None[];
2015-02-22 08:25:23 000.000.73.222:59288 -> 000.00.77.145:443 -> NONE [] 0/0 bytes tx 0/0 bytes rx 20.179 seconds如何修改脚本以使其将服务器名称与请求一起发送?
发布于 2015-02-22 18:41:23
me:您使用的是哪个版本的python?我认为2.7.9以下的版本没有SNI可用。
刚检查过是2.7.6,你确定吗?
可以,参见https://www.mnot.net/blog/2014/12/27/python_2_and_tls_sni。这意味着您的问题是您使用的python版本不支持SNI。因此,您需要按照urllib3 on python 2.7 SNI error on Google App Engine中的说明升级python本身或部分python。
https://stackoverflow.com/questions/28656418
复制相似问题