Maison  >  Article  >  développement back-end  >  Comment gérer les exceptions non gérées dans Guzzle lors du test des API ?

Comment gérer les exceptions non gérées dans Guzzle lors du test des API ?

Patricia Arquette
Patricia Arquetteoriginal
2024-11-02 06:27:02917parcourir

How to Handle Unhandled Exceptions in Guzzle When Testing APIs?

Résoudre les exceptions non gérées avec Guzzle

Détecter les exceptions lors du test des API avec Guzzle peut être difficile. Cet article résout ce problème et propose des solutions pour récupérer des réponses avec des codes HTTP autres que 200.

Dans l'exemple de code, les écouteurs d'événements sont utilisés pour gérer des codes HTTP spécifiques, mais des exceptions sont toujours levées. Pour résoudre ce problème, une option consiste à gérer les exceptions par code d'état HTTP.

Gérer les exceptions par code d'état HTTP

Pour Guzzle 3 et Guzzle 5.3, la désactivation des exceptions permet une gestion manuelle de tous les statuts. codes. Définissez simplement 'exceptions' => false dans les options du client.

Guzzle 3

$client = new \Guzzle\Http\Client($httpBase, array(
  'request.options' => array(
     'exceptions' => false,
   )
));

Guzzle 5.3

$client = new \GuzzleHttp\Client(['defaults' => [ 'exceptions' => false ]] );

Avec exceptions désactivées, le code d'état HTTP peut être obtenu directement à partir de la réponse.

$response = $request->send();
$statuscode = $response->getStatusCode();

Les codes d'état attendus peuvent être traités en conséquence :

if (200 === $statuscode) {
 // Do something
}
elseif (304 === $statuscode) {
  // Nothing to do
}
elseif (404 === $statuscode) {
  // Clean up DB or something like this
}
else {
  throw new MyException("Invalid response from api...");
}

Guzzle 6

Dans Guzzle 6, utilisez 'http_errors' => false dans les options client :

$client = new \GuzzleHttp\Client(['http_errors' => false]);

Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

Déclaration:
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn