正确的处理程序应当包括:php
让咱们触发一个异常:程序员
//建立可抛出一个异常的函数 function checkNum($number){ if($number>1) { throw new Exception("Value must be 1 or below"); } return true; } //在 "try" 代码块中触发异常 try { checkNum(2); //If the exception is thrown, this text will not be shown echo 'If you see this, the number is 1 or below'; }catch(Exception $e) { //捕获异常 echo 'Message: ' .$e->getMessage(); }
上面代码将得到相似这样一个错误:函数
Message: Value must be 1 or below
上面的代码抛出了一个异常,并捕获了它:测试
不过,为了遵循“每一个 throw 必须对应一个 catch”的原则,能够设置一个顶层的异常处理器来处理漏掉的错误。this
建立自定义的异常处理程序很是简单。咱们简单地建立了一个专门的类,当 PHP 中发生异常时,可调用其函数。该类必须是 exception 类的一个扩展。spa
这个自定义的 exception 类继承了 PHP 的 exception 类的全部属性,您可向其添加自定义的函数。code
咱们开始建立 exception 类:对象
class customException extends Exception { public function errorMessage() { //error message $errorMsg = 'Error on line '.$this->getLine().' in '.$this->getFile() .': <b>'.$this->getMessage().'</b> is not a valid E-Mail address'; 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(); }
这个新的类是旧的 exception 类的副本,外加 errorMessage() 函数。正由于它是旧类的副本,所以它从旧类继承了属性和方法,咱们可使用 exception 类的方法,好比 getLine() 、 getFile() 以及 getMessage()。blog
上面的代码抛出了一个异常,并经过一个自定义的 exception 类来捕获它:继承
能够为一段脚本使用多个异常,来检测多种状况。
可使用多个 if..else 代码块,或一个 switch 代码块,或者嵌套多个异常。这些异常可以使用不一样的 exception 类,并返回不一样的错误消息:
class customException extends Exception { public function errorMessage() { //error message $errorMsg = 'Error on line '.$this->getLine().' in '.$this->getFile() .': <b>'.$this->getMessage().'</b> is not a valid E-Mail address'; 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,牢牢捕获了 base exception,则在那里处理异常。
有时,当异常被抛出时,您也许但愿以不一样于标准的方式对它进行处理。能够在一个 "catch" 代码块中再次抛出异常。
脚本应该对用户隐藏系统错误。对程序员来讲,系统错误也许很重要,可是用户对它们并不感兴趣。为了让用户更容易使用,您能够再次抛出带有对用户比较友好的消息的异常:
class customException extends Exception { public function errorMessage() { //error message $errorMsg = $this->getMessage().' is not a valid E-Mail address.'; 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"。若是有,则再次抛出异常:
若是在其目前的 "try" 代码块中异常没有被捕获,则它将在更高层级上查找 catch 代码块。
set_exception_handler() 函数可设置处理全部未捕获异常的用户定义函数。
function myException($exception) { echo "<b>Exception:</b> " , $exception->getMessage(); } set_exception_handler('myException'); throw new Exception('Uncaught Exception occurred');
以上代码的输出应该相似这样:
Exception: Uncaught Exception occurred
在上面的代码中,不存在 "catch" 代码块,而是触发顶层的异常处理程序。应该使用此函数来捕获全部未被捕获的异常。
简而言之:若是抛出了异常,就必须捕获它。