Guzzle 예외 처리
API 테스트 중에 Guzzle에서 발생한 예외를 잡으려고 시도하는 중에 구현에도 불구하고 처리되지 않은 지속적인 예외 오류가 발생했습니다. try/catch 블록. 쿼리를 자세히 살펴보고 몇 가지 실용적인 솔루션을 살펴보겠습니다.
제공하신 코드 조각에는 특정 HTTP 응답 코드(401, 500 등)를 처리하기 위한 이벤트 리스너가 포함되어 있습니다. 그러나 try/catch 블록에서 포착하는 예외 유형(ClientErrorResponseException, ServerErrorResponseException, BadResponseException)은 Guzzle에서 발생할 수 있는 가능한 모든 예외를 캡슐화할 만큼 구체적이지 않습니다.
이 문제를 해결하려면 다음 중 하나를 수행하세요. 접근 방식은 Guzzle에 대한 예외를 비활성화하여 예외를 트리거하지 않고 모든 상태 코드에 액세스할 수 있도록 하는 것입니다. 이는 클라이언트에 다음 구성을 추가하여 달성할 수 있습니다.
$client = new \Guzzle\Http\Client($httpBase, array( 'request.options' => array( 'exceptions' => false, ) ));
예외를 비활성화하면 응답의 상태 코드를 수동으로 확인하고 예상치 못한 코드나 잘못된 코드를 처리할 수 있습니다.
$request = $client->get($uri); $response = $request->send(); $statuscode = $response->getStatusCode(); if ($statuscode > 300) { // Handle error conditions }
또는 예상되는 상태 코드를 명시적으로 정의하고 그에 따라 처리할 수도 있습니다.
if (200 === $statuscode) { // Handle 200 OK } elseif (304 === $statuscode) { // Handle 304 Not Modified } elseif (404 === $statuscode) { // Handle 404 Not Found } else { throw new Exception("Invalid response from API..."); }
By 예외를 비활성화하고 상태 코드를 수동으로 처리하면 오류 처리를 세부적으로 제어할 수 있으며 다양한 HTTP 응답에 적절하게 대응할 수 있습니다.
위 내용은 try/catch 블록을 사용해도 Guzzle 예외가 여전히 처리되지 않는 이유는 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!