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.
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!