Я пытаюсь проверить, что цель выставляет 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 "", line 2, in
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, я знаю, не получают ошибку.
Спасибо за справку все.
Python 2.x: docs.cython.org/2/library/htttplib.html :
Примечание. Поддержка HTTPS доступна только в том случае, если модуль сокета был скомпилирован с помощью поддержки SSL.
Python 3.x: : docs.cython.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>
Почему вы не пробовали 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
Использование
class httplib.HTTPSConnection
http://docs.cython.org/library/httplib.html#httplib.httpsconnection
Проверка поддержки ssl на Python 2.6+:
try:
import ssl
except ImportError:
print "error: no ssl support"
Для соединения через https:
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
Лучшая альтернатива - использовать параметризованные запросы, то вам не нужно избежать строк.
Если вы все еще хотите поставить запрос вместе, правильный способ избежать строкового литерала для SQL Server (T-SQL) - это заменить каждую апострофю (') в строку с двумя апострофами.
-121--1918176- Предполагая, что поддержка SSL включена для модуля модуля
.
connection1 = httplib.HTTPSConnection('www.somesecuresite.com')