>  기사  >  백엔드 개발  >  ThinkPHP의 예외 처리에 대한 자세한 설명

ThinkPHP의 예외 처리에 대한 자세한 설명

不言
不言원래의
2018-06-01 11:56:271818검색

PHP의 기본 예외 처리와 달리 ThinkPHP는 단순한 오류 메시지가 아닌 인간화된 오류 페이지를 표시합니다. 다음 기사에서는 주로 ThinkPHP의 예외 처리에 대한 관련 정보를 소개합니다. 소개는 매우 자세합니다. 필요한 사람은 참조할 수 있습니다

예외란 무엇입니까

더 넓은 관점에서 예외에는 두 가지 측면이 포함됩니다. 한편, 예외는 프로그램 실행 중 구문 및 런타임 오류로 인해 발생합니다. 한편으로는 정확한 피드백이 주어지지 않는 경우가 있는데, 예를 들어 고객이 특정 제품에 대해 문의하고 싶은데 찾을 수 없는 경우에도 예외라고 생각합니다.

첫 번째 예외는 TP 프레임워크 자체가 페이지에 오류 정보를 출력하지만, 두 번째 예외는 일반적으로 아무 정보도 출력하지 않으므로 디버그하기가 매우 불편합니다.

이 기사에서는 ThinkPHP 예외 처리에 대한 관련 내용을 자세히 소개하고 모든 사람의 참고와 학습을 위해 공유합니다. 아래에서는 많은 말을 하지 않겠습니다. 자세한 소개를 살펴보겠습니다.

사전 환경

이제 PHP는 종종 프런트 엔드에 대한 인터페이스를 제공하므로 예외 처리도 이를 기반으로 합니다.

개발 단계에서 TP의 원래 예외 처리는 요구 사항을 충족할 수 있는 페이지에 예외 정보를 출력하는 것입니다. 그러나 프로덕션 환경에서는 예외를 다른 방식으로 처리해야 합니다.

이 기사는 프로덕션 환경에서의 예외 처리에 관한 모든 것입니다.

AOP 프로그래밍

요즘에는 많은 언어에서 AOP 프로그래밍 아이디어, 즉 관점 지향 프로그래밍 아이디어가 매우 인기가 있습니다. 여러 문제를 같은 방식으로 처리하는 대신 통일된 방식을 사용합니다. 예외 처리의 경우 통일된 예외 정보를 정의하고 통일된 방식으로 처리하는 것입니다. 기본 예외 처리 클래스를 다시 작성한 다음 사용자 정의 예외 처리 클래스를 사용하여 모든 예외를 처리하도록 구성합니다

코드 구현

루트 디렉터리에 예외 디렉터리를 만들고 아래에 ExceptionHandle.php를 만듭니다. 이 클래스는 핸들 클래스를 상속해야 합니다

class ExceptionHandler extends Handle
예외 정보를 정의하기 위해 여러 속성을 생성합니다

// http 错误码 
private $code; 
// 自定义异常信息 
private $msg; 
// 自定义错误码 
private $errorCode;

코드에서 throw new Exception()을 사용할 때 렌더링 메서드를 재정의합니다. 예외 정보를 발생시키는 것을 실제로는 render 메소드라고 부르므로 우리는 이 메소드를 재정의하여 우리 자신의 정보를 반환해야 합니다.

public function render(Exception $ex) 
 { 
 return json(['msg'=>"自定义异常信息"]); 
nbsp; }

아래에서 새 컨트롤러 제품을 만들고, 메소드를 추가하고, 테스트

public function getProduct($id) 
 { 
 try{ 
  3/0; 
 } 
 catch(Exception $ex){ 
  throw $ex; 
 } 
 }

그런 다음 다음 경로를 추가하세요

Route::get("product/:id","api/v1.Product/getProduct");

테스트하려면 다음 URL을 입력하세요

http://z.cn/product/2

페이지 출력은 다음과 같습니다

custom 예외 처리 기능이 실행되지 않습니다.

사용자 지정 예외 처리 사용

config.php

// 异常处理handle类 留空使用 \think\exception\Handle 
 'exception_handle' => 'app\lib\exception\ExceptionHandler',

에서 다음 구성을 수정한 다음 사용자 지정 예외 처리 클래스를 실행하세요


One Class 예외는 사용자 동작으로 인해 발생하는 예외입니다. 예를 들어, 조건을 충족하는 데이터가 없습니다(다른 관점에서 보면 이는 실제로 예외가 아닙니다). 클래스 I 오류는 런타임 오류입니다. 사용자에 의해 발생한 예외는 여러 가지 유형으로 나눌 수 있으므로 관련 클래스를 맞춤화해야 합니다.

먼저 상위 클래스를 정의합니다

class BaseException extends Exception 
{ 
 //http 状态码 
 public $code; 
//错误具体消息 
 public $msg; 
//自定义错误码 
 public $errorCode; 
 
 //构造函数用于接收传入的异常信息,并初始化类中的属性 
 public function __construct($params) 
 { 
  if (!is_array($params)) { 
   return; 
  } 
  if (array_key_exists('code', $params)) { 
   $this->code = $params['code']; 
  } 
  if (array_key_exists('msg', $params)) { 
   $this->msg = $params['msg']; 
  } 
  if (array_key_exists('errorCode', $params)) { 
   $this->errorCode = $params['errorCode']; 
  } 
 } 
}

그런 다음 찾을 수 없는 제품 정보를 처리하는 예외 처리 클래스를 정의합니다. 이는 상위 클래스의 각 속성을 재정의하는 데 사용되며 이 클래스의 속성 정보도 msg

class ProductNotFoundException extends BaseException 
{ 
 //http 状态码 
 public $code = 404; 
//错误具体消息 
 public $msg = "请求的产品不存在"; 
//自定义错误码 
 public $errorCode = 40000; 
}

다른 예외 처리

렌더링 메서드에서 다른 예외에 따라 별도로 처리합니다.

//分别处理两种不容类型异常:1、用户错误 2.代码与运行时错误 
  if ($ex instanceof BaseException) { 
 
  } else { 
  
  }

참고: 예외가 다음과 같은 경우 Throw되면 렌더링 함수가 실행되며, 던져진 예외 객체를 $ex 매개변수에 복사하므로 이 매개변수를 기준으로 예외 유형을 판단할 수 있습니다

이제 핵심은 프로덕션 환경이므로 반환된 예외 정보가 반환되기를 바랍니다. 위와 같은 내용이 아닌 프런트 엔드 담당자가 이해할 수 있습니다. 그러면 스택 정보 등을 포함하여 페이지에 오류 정보가 출력됩니다.

그러면 프런트엔드와 백엔드 담당자 모두 이해할 수 있는 정보는 json이어야 합니다(물론 xml일 수도 있음). 렌더링 방법을 수정하고

if ($ex instanceof BaseException) { 
   $this->code = $ex->code; 
   $this->msg = $ex->msg; 
   $this->errorCode = $ex->errorCode; 
  } else { 
//这里是在运行时产生的各种异常,所以无法准确输出异常信息,所以只能统一输出是服务器错误信息 
   $this->code = 500; 
   $this->msg = "服务器内部错误"; 
   $this->errorCode = 999; 
  }

오류 메시지를 json 형식으로 반환합니다.

$result = [ 
   'msg' => $this->msg, 
   'error_code' => $this->errorCode, 
   'request_url' => request()->url() 
  ]; 
  return json($result,$this->code);

이 시점에서 전역 예외 처리가 작성되었습니다. 테스트용으로 product.php에 코딩해 보겠습니다.

public function getProduct($id) 
 { 
  //处理程序运行时错误 
  /*try{ 
   3/0; 
  } 
  catch(Exception $ex){ 
   throw $ex; 
  }*/ 
  //处理用户行为产生的错误 
  $error=[ 
   'msg'=>'没有找到合适的产品' 
  ]; 
  $ex=new ProductNotFoundException($error); 
  throw $ex; 
 }

팁:

app_debug를 false로 변경하는 것을 잊지 마세요. 생산 환경을 위한

관련 추천:

tp 프레임워크(thinkPHP)는 3번의 잘못된 로그인 비밀번호 후 계정을 잠그는 기능을 구현합니다.

Thinkphp5의 사용자 정의 라벨

위 내용은 ThinkPHP의 예외 처리에 대한 자세한 설명의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.