Прежде всего, это касается Gira Homeserver, который представляет собой сервер домашней автоматизации. У него Python 2.7, и я не могу установить внешние модули.
Но для тестирования и примеров я использовал как Python 2.7.15, так и Python 3.6.8. (но попробовал и несколько других версий - тот же результат)
Я пытаюсь прочитать контент с веб-сервера моего Philips Android TV. Это отлично работает с браузером, отлично работает с Curl и отлично работает с запросами Python. Но он не работает с urllib2, и это то, что мне нужно использовать для работы с моей системой домашней автоматизации.
Телевизор предоставляет вывод json на веб-странице https. требуется дайджест-аутентификация.
Пример Urllib (Python3, для сравнения с запросами):
stianj@buick:~$ python3 stack.py
send: b'GET /6/powerstate HTTP/1.1\r\nAccept-Encoding: identity\r\nHost: 192.168.3.100:1926\r\nUser-Agent: Python-urllib/3.6\r\nConnection: close\r\n\r\n'
reply: 'HTTP/1.1 401 Unauthorized\r\n'
header: Date: Wed, 10 Jul 2019 21:36:45 GMT+00:00
header: Accept-Ranges: bytes
header: Server: Restlet-Framework/2.3.12
header: WWW-Authenticate: Digest realm="XTV", domain="/", nonce="MTU2Mjc5NDYwNTI3ODo1NTNlMTFhYzk5MjJjODQyMTYyZjAxZjRhYmYyYzNhMA==", algorithm=MD5, qop="auth"
header: Content-Length: 424
header: Content-Type: text/html; charset=UTF-8
Traceback (most recent call last):
File "/usr/lib/python3.6/urllib/request.py", line 1318, in do_open
encode_chunked=req.has_header('Transfer-encoding'))
File "/usr/lib/python3.6/http/client.py", line 1239, in request
self._send_request(method, url, body, headers, encode_chunked)
File "/usr/lib/python3.6/http/client.py", line 1285, in _send_request
self.endheaders(body, encode_chunked=encode_chunked)
File "/usr/lib/python3.6/http/client.py", line 1234, in endheaders
self._send_output(message_body, encode_chunked=encode_chunked)
File "/usr/lib/python3.6/http/client.py", line 1026, in _send_output
self.send(msg)
File "/usr/lib/python3.6/http/client.py", line 964, in send
self.connect()
File "/usr/lib/python3.6/http/client.py", line 1400, in connect
server_hostname=server_hostname)
File "/usr/lib/python3.6/ssl.py", line 407, in wrap_socket
_context=self, _session=session)
File "/usr/lib/python3.6/ssl.py", line 817, in __init__
self.do_handshake()
File "/usr/lib/python3.6/ssl.py", line 1077, in do_handshake
self._sslobj.do_handshake()
File "/usr/lib/python3.6/ssl.py", line 689, in do_handshake
self._sslobj.do_handshake()
socket.timeout: _ssl.c:835: The handshake operation timed out
During handling of the above exception, another exception occurred:
Traceback (most recent call last):
File "stack.py", line 15, in
response = urllib.request.urlopen(url,None,10)
File "/usr/lib/python3.6/urllib/request.py", line 223, in urlopen
return opener.open(url, data, timeout)
File "/usr/lib/python3.6/urllib/request.py", line 532, in open
response = meth(req, response)
File "/usr/lib/python3.6/urllib/request.py", line 642, in http_response
'http', request, response, code, msg, hdrs)
File "/usr/lib/python3.6/urllib/request.py", line 564, in error
result = self._call_chain(*args)
File "/usr/lib/python3.6/urllib/request.py", line 504, in _call_chain
result = func(*args)
File "/usr/lib/python3.6/urllib/request.py", line 1208, in http_error_401
host, req, headers)
File "/usr/lib/python3.6/urllib/request.py", line 1089, in http_error_auth_reqed
return self.retry_http_digest_auth(req, authreq)
File "/usr/lib/python3.6/urllib/request.py", line 1103, in retry_http_digest_auth
resp = self.parent.open(req, timeout=req.timeout)
File "/usr/lib/python3.6/urllib/request.py", line 526, in open
response = self._open(req, data)
File "/usr/lib/python3.6/urllib/request.py", line 544, in _open
'_open', req)
File "/usr/lib/python3.6/urllib/request.py", line 504, in _call_chain
result = func(*args)
File "/usr/lib/python3.6/urllib/request.py", line 1361, in https_open
context=self._context, check_hostname=self._check_hostname)
File "/usr/lib/python3.6/urllib/request.py", line 1320, in do_open
raise URLError(err)
urllib.error.URLError:
хотя пример запроса работает нормально (показывает выходные данные веб-страницы. Поскольку я использую одну и ту же версию Python для обоих примеров, я ожидаю, что параметры SSL, шифры и т. д. . То же самое. Что чрезвычайно интересно, так это то, что POST отлично работает с urllib. Время ожидания истекает только для GET.
Я знаю, что это В наши дни всегда рекомендовали использовать запросы, но для меня это не вариант. Кто-нибудь может объяснить ошибку рукопожатия?
Прежде всего, это касается Gira Homeserver, который представляет собой сервер домашней автоматизации. У него Python 2.7, и я не могу установить внешние модули.
Но для тестирования и примеров я использовал как Python 2.7.15, так и Python 3.6.8. (но попробовал и несколько других версий - тот же результат)
Я пытаюсь прочитать контент с веб-сервера моего Philips Android TV. Это отлично работает с браузером, отлично работает с Curl и отлично работает с запросами Python. Но он не работает с urllib2, и это то, что мне нужно использовать для работы с моей системой домашней автоматизации.
Телевизор предоставляет вывод json на веб-странице https. требуется дайджест-аутентификация.
Пример Urllib (Python3, для сравнения с запросами):
from requests.auth import HTTPDigestAuth from requests.packages.urllib3.exceptions import InsecureRequestWarning requests.packages.urllib3.disable_warnings(InsecureRequestWarning) r = requests.get(url, auth=HTTPDigestAuth(username, password), timeout=10, verify=False) print(r.status_code) print(r.content) [/code]
Пример urllib истекает из-за следующей ошибки:
[code]stianj@buick:~$ python3 stack.py send: b'GET /6/powerstate HTTP/1.1\r\nAccept-Encoding: identity\r\nHost: 192.168.3.100:1926\r\nUser-Agent: Python-urllib/3.6\r\nConnection: close\r\n\r\n' reply: 'HTTP/1.1 401 Unauthorized\r\n' header: Date: Wed, 10 Jul 2019 21:36:45 GMT+00:00 header: Accept-Ranges: bytes header: Server: Restlet-Framework/2.3.12 header: WWW-Authenticate: Digest realm="XTV", domain="/", nonce="MTU2Mjc5NDYwNTI3ODo1NTNlMTFhYzk5MjJjODQyMTYyZjAxZjRhYmYyYzNhMA==", algorithm=MD5, qop="auth" header: Content-Length: 424 header: Content-Type: text/html; charset=UTF-8 Traceback (most recent call last): File "/usr/lib/python3.6/urllib/request.py", line 1318, in do_open encode_chunked=req.has_header('Transfer-encoding')) File "/usr/lib/python3.6/http/client.py", line 1239, in request self._send_request(method, url, body, headers, encode_chunked) File "/usr/lib/python3.6/http/client.py", line 1285, in _send_request self.endheaders(body, encode_chunked=encode_chunked) File "/usr/lib/python3.6/http/client.py", line 1234, in endheaders self._send_output(message_body, encode_chunked=encode_chunked) File "/usr/lib/python3.6/http/client.py", line 1026, in _send_output self.send(msg) File "/usr/lib/python3.6/http/client.py", line 964, in send self.connect() File "/usr/lib/python3.6/http/client.py", line 1400, in connect server_hostname=server_hostname) File "/usr/lib/python3.6/ssl.py", line 407, in wrap_socket _context=self, _session=session) File "/usr/lib/python3.6/ssl.py", line 817, in __init__ self.do_handshake() File "/usr/lib/python3.6/ssl.py", line 1077, in do_handshake self._sslobj.do_handshake() File "/usr/lib/python3.6/ssl.py", line 689, in do_handshake self._sslobj.do_handshake() socket.timeout: _ssl.c:835: The handshake operation timed out
During handling of the above exception, another exception occurred:
Traceback (most recent call last): File "stack.py", line 15, in response = urllib.request.urlopen(url,None,10) File "/usr/lib/python3.6/urllib/request.py", line 223, in urlopen return opener.open(url, data, timeout) File "/usr/lib/python3.6/urllib/request.py", line 532, in open response = meth(req, response) File "/usr/lib/python3.6/urllib/request.py", line 642, in http_response 'http', request, response, code, msg, hdrs) File "/usr/lib/python3.6/urllib/request.py", line 564, in error result = self._call_chain(*args) File "/usr/lib/python3.6/urllib/request.py", line 504, in _call_chain result = func(*args) File "/usr/lib/python3.6/urllib/request.py", line 1208, in http_error_401 host, req, headers) File "/usr/lib/python3.6/urllib/request.py", line 1089, in http_error_auth_reqed return self.retry_http_digest_auth(req, authreq) File "/usr/lib/python3.6/urllib/request.py", line 1103, in retry_http_digest_auth resp = self.parent.open(req, timeout=req.timeout) File "/usr/lib/python3.6/urllib/request.py", line 526, in open response = self._open(req, data) File "/usr/lib/python3.6/urllib/request.py", line 544, in _open '_open', req) File "/usr/lib/python3.6/urllib/request.py", line 504, in _call_chain result = func(*args) File "/usr/lib/python3.6/urllib/request.py", line 1361, in https_open context=self._context, check_hostname=self._check_hostname) File "/usr/lib/python3.6/urllib/request.py", line 1320, in do_open raise URLError(err) urllib.error.URLError: [/code]
хотя пример запроса работает нормально (показывает выходные данные веб-страницы. Поскольку я использую одну и ту же версию Python для обоих примеров, я ожидаю, что параметры SSL, шифры и т. д. . То же самое. Что чрезвычайно интересно, так это то, что POST отлично работает с urllib. Время ожидания истекает только для GET.
Я знаю, что это В наши дни всегда рекомендовали использовать запросы, но для меня это не вариант. Кто-нибудь может объяснить ошибку рукопожатия?
Я пытаюсь прочитать URL-адрес изображения из Интернета и получить возможность загрузить изображение на свой компьютер через Python. Я использовал пример, использованный в этом сообщении блога -an-image-from-the-url-in-pil/, который был однако, когда...
У меня происходит сбой в системе. systemd-udev.service дает сбой, как видно из журналов ниже:
Apr 03 20:15:04 dut-3 charon-systemd : sending keep alive to 194.1.1.1
Apr 03 20:15:04 dut-3 charon-systemd : sending keep alive to 194.1.1.1
Apr 03...
Я пытался понять разницу между apicallattempttimeout и apicalltimeout. Что я мог понять, так это то, что apicalltimeout — это общее время, в течение которого клиентский запрос ожидает ответа, прежде чем отказаться от него, тогда как...
UPD: нет, связанный вопрос не тот и не отвечает на мой (если я не неграмотен).
Это скорее поверхностный вопрос о том, почему так много запросов- создание библиотек на Python и какую из них использовать. я полностью осведомлен о вариантах, и мой...
Я не программист, но я стараюсь быть как можно более полным. Основной скрипт запускает JAR, которая будет ждать, пока запросы выполнят выполнение (с помощью исполнителя ) и предоставления результата. Приложение Java создает для каждого...