> 백엔드 개발 > PHP 튜토리얼 > try/catch 블록을 사용해도 Guzzle 예외가 여전히 처리되지 않는 이유는 무엇입니까?

try/catch 블록을 사용해도 Guzzle 예외가 여전히 처리되지 않는 이유는 무엇입니까?

Barbara Streisand
풀어 주다: 2024-11-01 00:46:02
원래의
424명이 탐색했습니다.

Why Are My Guzzle Exceptions Still Unhandled Even With a try/catch Block?

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 중국어 웹사이트의 기타 관련 기사를 참조하세요!

원천:php.cn
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
저자별 최신 기사
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿