Сбой запроса GET, работающего из POSTMAN, при использовании python - PullRequest
0 голосов
/ 10 июля 2019

Я пытаюсь получить статус сканирования сонара, используя запрос get, когда использую почтальона для проверки статуса. Я получаю вывод, что ожидал. Но когда я пытаюсь использовать python3.6.3. Это ниже исключения

Traceback (most recent call last):
 File "C:\Python37\lib\site-packages\urllib3\response.py", line 331, in 
_error_catcher
   yield
 File "C:\Python37\lib\site-packages\urllib3\response.py", line 413, in read
    data = self._fp.read(amt)
 File "C:\Python37\Lib\http\client.py", line 447, in read
    n = self.readinto(b)
 File "C:\Python37\Lib\http\client.py", line 491, in readinto
    n = self.fp.readinto(b)
 File "C:\Python37\Lib\socket.py", line 589, in readinto
    return self._sock.recv_into(b)
 File "C:\Python37\Lib\ssl.py", line 1049, in recv_into
    return self.read(nbytes, buffer)
 File "C:\Python37\Lib\ssl.py", line 908, in read
    return self._sslobj.read(len, buffer)
ConnectionResetError: [WinError 10054] An existing connection was 
 forcibly closed by the remote host

During handling of the above exception, another exception occurred:

Traceback (most recent call last):
   File "C:\Python37\lib\site-packages\requests\models.py", line 749, in generate
for chunk in self.raw.stream(chunk_size, decode_content=True):
   File "C:\Python37\lib\site-packages\urllib3\response.py", line 465, in stream
data = self.read(amt=amt, decode_content=decode_content)
  File "C:\Python37\lib\site-packages\urllib3\response.py", line 430, in read
raise IncompleteRead(self._fp_bytes_read, self.length_remaining)
  File "C:\Python37\Lib\contextlib.py", line 130, in __exit__
self.gen.throw(type, value, traceback)
  File "C:\Python37\lib\site-packages\urllib3\response.py", line 349, in _error_catcher
raise ProtocolError('Connection broken: %r' % e, e)
urllib3.exceptions.ProtocolError: ("Connection broken: ConnectionResetError(10054, 'An existing connection was forcibly closed by the remote host', None, 10054, None)", ConnectionResetError(10054, 'An existing connection was forcibly closed by the remote host', None, 10054, None))

During handling of the above exception, another exception occurred:

Traceback (most recent call last):
  File "C:/Users/vjannapureddy/Documents/testing/testingsonarapi.py", line 11, in <module>
   response = requests.request("GET", url, headers=headers, params=querystring)
   File "C:\Python37\lib\site-packages\requests\api.py", line 58, in request
return session.request(method=method, url=url, **kwargs)
  File "C:\Python37\lib\site-packages\requests\sessions.py", line 512, in request
   resp = self.send(prep, **send_kwargs)
   File "C:\Python37\lib\site-packages\requests\sessions.py", line 662, in send
r.content
   File "C:\Python37\lib\site-packages\requests\models.py", line 827, in content
self._content = b''.join(self.iter_content(CONTENT_CHUNK_SIZE)) or b''
   File "C:\Python37\lib\site-packages\requests\models.py", line 752, in generate
raise ChunkedEncodingError(e)
requests.exceptions.ChunkedEncodingError: ("Connection broken: 
 ConnectionResetError(10054, 'An existing connection was forcibly closed by the remote host', None, 10054, None)", ConnectionResetError(10054, 'An existing connection was forcibly closed by the remote host', None, 10054, None))

Я попытался запустить Python 3.7, который не работал, затем я попытался в среде Linux с Python3.6.3, который не работал.

Мы используем корпоративную версию SonarQube, и она имеет проверку безопасности MFA.

import requests

url = "https://xxxsonarqube.xx.com/api/qualitygates/project_status"

querystring = {"analysisId" : "AWu4CtcA08Z7GjqNo7V6"}

headers = {
    'Authorization': "Basic xxxxxxxxxxxxxxxxxxxxxxxxxxxxxx"
    }

response = requests.request("GET", url, headers=headers, 
params=querystring)

print(response.text)
print(response.status_code)

Это ожидаемый вывод, который работает при использовании почтальона.

{
    "projectStatus": {
        "status": "ERROR",
        "conditions": [
            {
                "status": "OK",
                "metricKey": "bugs",
                "comparator": "GT",
                "errorThreshold": "0",
                "actualValue": "0"
            },
            {
                "status": "OK",
                "metricKey": "vulnerabilities",
                "comparator": "GT",
                "errorThreshold": "0",
                "actualValue": "0"
            },
            {
                "status": "ERROR",
                "metricKey": "code_smells",
                "comparator": "GT",
                "errorThreshold": "0",
                "actualValue": "72"
            }
        ],
        "periods": [],
        "ignoredConditions": false
    }
}

1 Ответ

0 голосов
/ 10 июля 2019

Вы пытались погуглить ошибку?Кажется, что ошибка заключается в следующем:

python: [Errno 10054] Существующее соединение было принудительно закрыто удаленным хостом

Таким образом, ошибка сервера к клиентуваш скрипт на python выглядит нормально.

...