Поскольку ответ Алекса ссылку, и код на этой странице, плохо отформатирован, я просто хочу, чтобы поставить это здесь для потомства: ответ
import urllib2, httplib
class HTTPSClientAuthHandler(urllib2.HTTPSHandler):
def __init__(self, key, cert):
urllib2.HTTPSHandler.__init__(self)
self.key = key
self.cert = cert
def https_open(self, req):
# Rather than pass in a reference to a connection class, we pass in
# a reference to a function which, for all intents and purposes,
# will behave as a constructor
return self.do_open(self.getConnection, req)
def getConnection(self, host, timeout=300):
return httplib.HTTPSConnection(host, key_file=self.key, cert_file=self.cert)
opener = urllib2.build_opener(HTTPSClientAuthHandler('/path/to/file.pem', '/path/to/file.pem.'))
response = opener.open("https://example.org")
print response.read()
Большое вам спасибо за это! Я отслеживал ошибку в течение нескольких дней с помощью частного сертификата и центра сертификации для подключения к серверу Apache, используя библиотеку запросов в python. Я мог проверить, работает ли мой сертификат в браузере, однако он каждый раз терпел неудачу с «ошибкой рукопожатия». Я закончил использование класса выше, чтобы доказать, что клиентский сертификат работает и проверяет подлинность. Оказалось, что в версии библиотеки запросов я использовал ошибку 1.2.3, если быть точным. Надеюсь, этот комментарий поможет другим людям, которые сталкиваются с одной и той же проблемой. – ihatecache
Я новичок в Python, поэтому хотел бы знать, когда здесь называется функция https_open()? Если возможно, опишите, каков поток выполнения этого кода? – rrsuj
Итак, я следил за этими инструкциями, и я получаю ошибку urlopen: «ssl certificate verify failed» при использовании python 2.7.9 или выше. Я считаю, что мне нужно добавить SSLContext со своей собственной цепочкой сертификатов, но я не уверен на 100%, не возражаете ли вы давать какие-либо советы или подсказки для работы в этом примере. Благодаря! – macguru2000