По состоянию на 2019 год, вот что я разработал на основе приведенных выше ответов и документов Guzzle для обработки исключения, получения тела ответа, кода состояния, сообщения и других иногда ценных элементов ответа.
try {
/**
* We use Guzzle to make an HTTP request somewhere in the
* following theMethodMayThrowException().
*/
$result = theMethodMayThrowException();
} catch (\GuzzleHttp\Exception\RequestException $e) {
/**
* Here we actually catch the instance of GuzzleHttp\Psr7\Response
* (find it in ./vendor/guzzlehttp/psr7/src/Response.php) with all
* its own and its 'Message' trait's methods. See more explanations below.
*
* So you can have: HTTP status code, message, headers and body.
* Just check the exception object has the response before.
*/
if ($e->hasResponse()) {
$response = $e->getResponse();
var_dump($response->getStatusCode()); // HTTP status code;
var_dump($response->getReasonPhrase()); // Response message;
var_dump((string) $response->getBody()); // Body, normally it is JSON;
var_dump(json_decode((string) $response->getBody())); // Body as the decoded JSON;
var_dump($response->getHeaders()); // Headers array;
var_dump($response->hasHeader('Content-Type')); // Is the header presented?
var_dump($response->getHeader('Content-Type')[0]); // Concrete header value;
}
}
// process $result etc. ...
Вуаля. Вы получаете информацию об ответе в виде удобно разделенных элементов.
Боковые примечания:
С помощью catch
предложения мы перехватываем класс корневых исключений PHP в цепочке наследования,
\Exception
поскольку пользовательские исключения Guzzle расширяют его.
Этот подход может быть полезен в тех случаях, когда Guzzle используется под капотом, например, в Laravel или AWS API PHP SDK, поэтому вы не можете поймать настоящее исключение Guzzle.
В этом случае класс исключения может не совпадать с тем, который упоминается в документации Guzzle (например, GuzzleHttp\Exception\RequestException
как корневое исключение для Guzzle).
Поэтому вам нужно поймать \Exception
вместо этого, но имейте в виду, что это все еще экземпляр класса исключения Guzzle.
Хотя используйте с осторожностью. Эти оболочки могут сделать недоступными $e->getResponse()
подлинные методы объекта Guzzle . В этом случае вам нужно будет посмотреть на фактический исходный код исключения оболочки и выяснить, как получить статус, сообщение и т. Д. Вместо использования методов Guzzle $response
.
Если вы сами вызываете Guzzle напрямую, вы можете поймать GuzzleHttp\Exception\RequestException
или любой другой, упомянутый в их документации по исключениям в отношении условий вашего варианта использования.