>백엔드 개발 >PHP 튜토리얼 >PHP 예외 처리 작업 정보

PHP 예외 처리 작업 정보

jacklove
jacklove원래의
2018-05-08 09:17:511433검색

Exception은 지정된 오류가 발생할 때 스크립트의 일반적인 흐름을 변경하는 데 사용됩니다. 이 문서에서는 php 예외 처리의 작동을 자세히 설명합니다.

예외란 무엇인가요?

PHP 5는 오류 처리에 대한 새로운 객체 지향 접근 방식을 제공합니다.

예외 처리는 지정된 오류(예외) 상황이 발생할 때 스크립트의 일반적인 흐름을 변경하는 데 사용됩니다. 이러한 상황을 예외라고 합니다.

예외가 트리거되면 일반적으로 다음과 같이 발생합니다.

현재 코드 상태가 저장됩니다.

코드 실행이 사전 정의된 예외 처리기 기능으로 전환됩니다.

상황에 따라 프로세서는 저장된 코드 상태 코드에서 실행을 다시 시작할 수 있습니다. , 스크립트 실행 종료 또는 코드의 다른 위치에서 스크립트 실행 계속

다양한 오류 처리 방법을 보여 드리겠습니다.

예외의 기본 사용

사용자 지정 예외 처리기 만들기

다중 예외

Re 예외 발생

최상위 예외 처리기 설정

예외의 기본 사용

예외가 발생하면 후속 코드는 계속 실행되지 않으며 PHP는 일치하는 "catch" 코드 블록을 찾으려고 시도합니다.

Exception이 catch되지 않고 해당 처리에 set_Exception_handler()를 사용할 필요가 없으면 심각한 오류(치명적인 오류)가 발생하고 "Uncaught Exception"이라는 오류 메시지가 출력됩니다.

잡지 않고 예외를 던져 보겠습니다.

<?php
//create function with an exception
function checkNum($number)
 {
 if($number>1)
  {
  throw new Exception("Value must be 1 or below");
  }
 return true;
 }
//trigger exception
checkNum(2);
?>

위 코드에서는 다음과 같은 오류가 발생합니다.

치명적인 오류: 포착되지 않은 예외 '예외'
C:webfoldertest에서 '값은 1 이하여야 합니다'라는 메시지가 표시됩니다. php:6
스택 추적: #0 C:webfoldertest.php(12):
checkNum(28) #1 6행의 C:webfoldertest.php에 던져진 {main}

시도하고, 던지고, 잡으세요

피하려면 위 예제의 오류를 해결하려면 예외를 처리하기 위한 적절한 코드를 만들어야 합니다.

올바른 핸들러에는 다음이 포함되어야 합니다.

Try - 예외를 사용하는 함수는 "try" 블록 내에 있어야 합니다. 예외가 트리거되지 않으면 코드는 평소대로 계속 실행됩니다. 그러나 예외가 트리거되면 예외가 발생합니다.

Throw - 예외를 트리거하는 방법을 지정합니다. 각 "throw"는 최소한 하나의 "catch"에 해당해야 합니다

Catch - "catch" 코드 블록은 예외를 포착하고 예외 정보가 포함된 객체를 생성합니다

예외를 트리거해 보겠습니다:

166ca6e0226581b0bc5215b39ea58c54getMessage()를 호출하면 예외에서 발생한 오류 메시지가 출력됩니다.

그러나 "각 투구는 캐치에 대응해야 한다"는 원칙을 따르기 위해 다음과 같이 설정할 수 있습니다. 누락된 오류를 처리하기 위해 최상위 예외 처리기를 만듭니다.

사용자 정의 예외 클래스 만들기

사용자 정의 예외 처리기를 만드는 것은 매우 간단합니다. 우리는 PHP에서 예외가 발생할 때 함수가 호출되는 특수 클래스를 만들었습니다. 이 클래스는 예외 클래스의 확장이어야 합니다.

이 사용자 정의 예외 클래스는 PHP 예외 클래스의 모든 속성을 상속하며 여기에 사용자 정의 기능을 추가할 수 있습니다.

예외 클래스를 만드는 것부터 시작합니다.

<?php
class customException extends Exception
 {
 public function errorMessage()
  {
  //error message
  $errorMsg = &#39;Error on line &#39;.$this->getLine().&#39; in &#39;.$this->getFile()
  .&#39;: <b>&#39;.$this->getMessage().&#39;</b> is not a valid E-Mail address&#39;;
  return $errorMsg;
  }
 }
$email = "someone@example...com";
try
 {
 //check if 
 if(filter_var($email, FILTER_VALIDATE_EMAIL) === FALSE)
  {
  //throw exception if email is not valid
  throw new customException($email);
  }
 }
catch (customException $e)
 {
 //display custom message
 echo $e->errorMessage();
 }
?>

이 새 클래스는 이전 예외 클래스의 복사본과 errorMessage() 함수입니다. 이전 클래스의 복사본이기 때문에 이전 클래스의 속성 및 메소드를 상속받으며, getLine(), getFile() 및 getMessage()와 같은 예외 클래스의 메소드를 사용할 수 있습니다.

예제 설명:

위 코드는 예외를 발생시키고 사용자 정의 예외 클래스를 통해 이를 포착합니다.

customException() 클래스는 이전 예외 클래스의 확장으로 생성됩니다. 이런 방식으로 이전 클래스의 모든 속성과 메서드를 상속합니다.

errorMessage() 함수를 만듭니다. 이메일 주소가 잘못된 경우 함수는 오류 메시지를 반환합니다

$email 변수를 잘못된 이메일 주소 문자열로 설정하세요

이메일 주소가 불법이므로 "try" 코드 블록을 실행하세요. 예외 발생

"catch" 코드 블록은 예외를 포착하고 오류 메시지를 표시합니다

다중 예외

스크립트에 여러 예외를 사용하여 여러 상황을 감지할 수 있습니다.

可以使用多个 if..else 代码块,或一个 switch 代码块,或者嵌套多个异常。这些异常能够使用不同的 exception 类,并返回不同的错误消息:

<?php
class customException extends Exception
{
public function errorMessage()
{
//error message
$errorMsg = &#39;Error on line &#39;.$this->getLine().&#39; in &#39;.$this->getFile()
.&#39;: <b>&#39;.$this->getMessage().&#39;</b> is not a valid E-Mail address&#39;;
return $errorMsg;
}
}
$email = "someone@example.com";
try
 {
 //check if 
 if(filter_var($email, FILTER_VALIDATE_EMAIL) === FALSE)
  {
  //throw exception if email is not valid
  throw new customException($email);
  }
 //check for "example" in mail address
 if(strpos($email, "example") !== FALSE)
  {
  throw new Exception("$email is an example e-mail");
  }
 }
catch (customException $e)
 {
 echo $e->errorMessage();
 }
catch(Exception $e)
 {
 echo $e->getMessage();
 }
?>

例子解释:

上面的代码测试了两种条件,如何任何条件不成立,则抛出一个异常:

customException() 类是作为旧的 exception 类的一个扩展来创建的。这样它就继承了旧类的所有属性和方法。

创建 errorMessage() 函数。如果 e-mail 地址不合法,则该函数返回一个错误消息。

执行 "try" 代码块,在第一个条件下,不会抛出异常。

由于 e-mail 含有字符串 "example",第二个条件会触发异常。

"catch" 代码块会捕获异常,并显示恰当的错误消息

如果没有捕获 customException,紧紧捕获了 base exception,则在那里处理异常。

重新抛出异常

有时,当异常被抛出时,您也许希望以不同于标准的方式对它进行处理。可以在一个 "catch" 代码块中再次抛出异常。

脚本应该对用户隐藏系统错误。对程序员来说,系统错误也许很重要,但是用户对它们并不感兴趣。为了让用户更容易使用,您可以再次抛出带有对用户比较友好的消息的异常:

<?php
class customException extends Exception
 {
 public function errorMessage()
  {
  //error message
  $errorMsg = $this->getMessage().&#39; is not a valid E-Mail address.&#39;;
  return $errorMsg;
  }
 }
$email = "someone@example.com";
try
 {
 try
  {
  //check for "example" in mail address
  if(strpos($email, "example") !== FALSE)
   {
   //throw exception if email is not valid
   throw new Exception($email);
   }
  }
 catch(Exception $e)
  {
  //re-throw exception
  throw new customException($email);
  }
 }
catch (customException $e)
 {
 //display custom message
 echo $e->errorMessage();
 }
?>

例子解释:

上面的代码检测在邮件地址中是否含有字符串 "example"。如果有,则再次抛出异常:

customException() 类是作为旧的 exception 类的一个扩展来创建的。这样它就继承了旧类的所有属性和方法。

创建 errorMessage() 函数。如果 e-mail 地址不合法,则该函数返回一个错误消息。

把 $email 变量设置为一个有效的邮件地址,但含有字符串 "example"。

"try" 代码块包含另一个 "try" 代码块,这样就可以再次抛出异常。

由于 e-mail 包含字符串 "example",因此触发异常。

"catch" 捕获到该异常,并重新抛出 "customException"。

捕获到 "customException",并显示一条错误消息。

如果在其目前的 "try" 代码块中异常没有被捕获,则它将在更高层级上查找 catch 代码块。

设置顶层异常处理器 (Top Level Exception Handler)

set_exception_handler() 函数可设置处理所有未捕获异常的用户定义函数。

<?php
function myException($exception)
{
echo "<b>Exception:</b> " , $exception->getMessage();
}
set_exception_handler(&#39;myException&#39;);
throw new Exception(&#39;Uncaught Exception occurred&#39;);
?>

以上代码的输出应该类似这样:

Exception: Uncaught Exception occurred

在上面的代码中,不存在 "catch" 代码块,而是触发顶层的异常处理程序。应该使用此函数来捕获所有未被捕获的异常。

异常的规则

需要进行异常处理的代码应该放入 try 代码块内,以便捕获潜在的异常。

每个 try 或 throw 代码块必须至少拥有一个对应的 catch 代码块。

使用多个 catch 代码块可以捕获不同种类的异常。

可以在 try 代码块内的 catch 代码块中再次抛出(re-thrown)异常。

本篇详细的讲解了对于php异常的处理,更多的学习资料清关注php中文网即可观看。

相关推荐:

关于PHP 文件打开/读取/读取相关知识

关于PHP Include 文件的讲解

关于PHP EOF(heredoc) 的使用说明

위 내용은 PHP 예외 처리 작업 정보의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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