HTTPS-соединение Python

Я пытаюсь проверить, что эта цель предоставляет веб-службу https. У меня есть код для подключения через HTTP, но я не уверен, как подключиться через HTTPS. Я читал, что вы используете SSL, но я также читал, что он не поддерживает ошибки сертификата. Код, который у меня есть, взят из документации по python:

import httplib
conn = httplib.HTTPConnection("www.python.org")
conn.request("GET", "/index.html")
r1 = conn.getresponse()
print r1.status, r1.reason

Кто-нибудь знает, как подключиться к HTTPS?

Я уже пробовал HTTPSConenction, но он отвечает кодом ошибки, утверждающим, что у httplib нет атрибута HTTPSConnection. У меня также нет socket.ssl.

Я установил Python 2.6.4, и я не думаю, что в него встроена поддержка SSL. Есть ли способ интегрировать эту поддержку в более новый python без повторной установки.

Я установил OpenSSL и pyOpenSsl и попробовал приведенный ниже код из одного из ответов:

import urllib2
from OpenSSL import SSL
try: 
    response = urllib2.urlopen('https://example.com')  
    print 'response headers: "%s"' % response.info() 
except IOError, e: 
    if hasattr(e, 'code'): # HTTPError 
        print 'http error code: ', e.code 
    elif hasattr(e, 'reason'): # URLError 
        print "can't connect, reason: ", e.reason 
    else: 
        raise

У меня есть ошибка:

    Traceback (most recent call last):
  File "<stdin>", line 2, in <module>
  File "/home/build/workspace/downloads/Python-2.6.4/Lib/urllib.py", line 87, in urlopen
    return opener.open(url)
  File "/home/build/workspace/downloads/Python-2.6.4/Lib/urllib.py", line 203, in open
    return self.open_unknown(fullurl, data)
  File "/home/build/workspace/downloads/Python-2.6.4/Lib/urllib.py", line 215, in open_unknown
    raise IOError, ('url error', 'unknown url type', type)
IOError: [Errno url error] unknown url type: 'https'

Кто-нибудь знает, как заставить это работать?

-- UPDATE

Я выяснил, в чем проблема: версия Python, которую я использовал, не поддерживала SSL. В настоящее время я нашел это решение по адресу: http://www.webtop.com.au/compiling-python-with-ssl-support.

Код теперь будет работать после этого решения, что очень хорошо. Когда я импортирую ssl и HTTPSConnection, я знаю, что не получаю ошибку.

Спасибо за помощь всем.


person chrisg    schedule 27.01.2010    source источник


Ответы (8)


Python 2.x: https://docs.python.org/2/library/httplib.html:

Примечание. Поддержка HTTPS доступна только в том случае, если модуль сокета был скомпилирован с поддержкой SSL.

Python 3.x: docs.python.org/3/library/http.client. HTML:

Примечание. Поддержка HTTPS доступна только в том случае, если Python был скомпилирован с поддержкой SSL (через модуль ssl).

#!/usr/bin/env python

import httplib
c = httplib.HTTPSConnection("ccc.de")
c.request("GET", "/")
response = c.getresponse()
print response.status, response.reason
data = response.read()
print data
# => 
# 200 OK
# <!DOCTYPE html ....

Чтобы проверить, включен ли SSL, попробуйте:

>>> import socket
>>> socket.ssl
<function ssl at 0x4038b0>
person miku    schedule 27.01.2010
comment
Обратите внимание, что это не проверяет удаленный сертификат, поэтому вы не получаете безопасность таким образом (поскольку вы действительно не знаете, с каким сервером вы на самом деле разговариваете). - person Bruno; 14.09.2010
comment
Ссылка мертва. - person SwiftsNamesake; 31.08.2017
comment
Неверный адрес в теквесте - person stark; 18.04.2019
comment
как проверить IP с этим ответом? - person mahshid.r; 25.04.2019

Чтобы проверить поддержку SSL в Python 2.6+:

try:
    import ssl
except ImportError:
    print "error: no ssl support"

Чтобы подключиться через https://stackoverflow.com/questions/1935939/python-send-cmd-on-socket/1936923#1936923:

import urllib2

try:
    response = urllib2.urlopen('https://example.com') 
    print 'response headers: "%s"' % response.info()
except IOError, e:
    if hasattr(e, 'code'): # HTTPError
        print 'http error code: ', e.code
    elif hasattr(e, 'reason'): # URLError
        print "can't connect, reason: ", e.reason
    else:
        raise
person jfs    schedule 27.01.2010

с использованием

class httplib.HTTPSConnection

http://docs.python.org/library/httplib.html#httplib.HTTPSConnection

person bluszcz    schedule 27.01.2010

При использовании httplib.HTTPSConnection:

Пожалуйста, взгляните на:

Изменено в версии 2.7.9:

Этот класс теперь по умолчанию выполняет все необходимые проверки сертификатов и имен хостов. Чтобы вернуться к предыдущему непроверенному поведению, ssl._create_unverified_context() можно передать в параметр контекста. Ты можешь использовать:

if hasattr(ssl, '_create_unverified_context'):
  ssl._create_default_https_context = ssl._create_unverified_context
person gogasca    schedule 30.10.2015

Почему вы не пробовали httplib.HTTPSConnection? Он не выполняет проверку SSL, но это не требуется для подключения через https. Ваш код отлично работает с https-соединением:

>>> import httplib
>>> conn = httplib.HTTPSConnection("mail.google.com")
>>> conn.request("GET", "/")
>>> r1 = conn.getresponse()
>>> print r1.status, r1.reason
200 OK
person Piotr Czapla    schedule 27.01.2010

Предполагая, что поддержка SSL включена для модуля socket.

connection1 = httplib.HTTPSConnection('www.somesecuresite.com')
person Tendayi Mawushe    schedule 27.01.2010

У меня был некоторый код, который не работал с HTTPConnection (MOVED_PERMANENTLY error), но как только я переключился на HTTPS, он снова заработал без каких-либо других изменений. Это очень простое решение!

person user3014653    schedule 14.11.2016
comment
Чем это отличается от других ответов? Может быть, попытаться уточнить немного больше. - person mpaskov; 14.11.2016

person    schedule
comment
@notilas, этот код работает. Если вы просто напечатаете r, вы получите строковую версию самого объекта ответа, а не содержание ответа, которое вы ввели выше, <Resposne [200]>. Это просто говорит о том, что запрос был успешным (200 — это HTTP-код успеха). Попробуйте посмотреть на r.content или r.text (или r.json(), если вас устраивает JSON), чтобы получить фактический результат запроса. - person bjg222; 27.03.2019
comment
@ bjg222 Спасибо за любезное объяснение. - person notilas; 27.03.2019