PHP代码信息

运行结果
教程手册
代码仓库
极速运行
交互输入
极速运行模式,不支持键盘输入语句但是拥有更高的运行速度,输出简洁明了 。 点击编辑器上方的运行按钮即刻体验吧。
以下是用户最新保存的代码
doReg-get.php 发布于:2021-01-20 00:04 秒换算为剩余天小时分秒 发布于:2021-01-19 10:56 柯里化函数的使用 发布于:2021-01-15 09:41 正则解析测试 发布于:2021-01-06 10:26 in 转sql 发布于:2021-01-05 15:45 echo var_dump 区别 发布于:2020-12-29 10:19 正则表达式排除单词里面的baidu 发布于:2020-12-28 18:54 php快速排序 发布于:2020-12-28 15:21 php二分查找 发布于:2021-01-03 16:24 工厂设计模式测试 发布于:2020-12-17 17:17 自定义强化 substr() 方法,以适用中文字符 发布于:2020-12-15 10:38 PHP 字符串变量 发布于:2020-12-11 14:44 PHP 常量 发布于:2020-12-11 14:38 PHP 5 数据类型 发布于:2020-12-11 14:31 斐波那契数列 发布于:2020-11-25 00:24 获取 url 参数 urlargs($str, $aname) 发布于:2020-11-19 16:56 人员人与人 发布于:2020-10-31 13:36 测试学习代码 发布于:2020-10-30 16:58 数组转换php 发布于:2020-10-28 17:02 魔术方法php 发布于:2020-10-19 20:07 echo语句 发布于:2020-10-14 15:31 网页数据处理 发布于:2020-10-14 13:47 session_destroy()的执行会销毁session_id() 发布于:2020-10-07 15:21 session_destroy()的执行会销毁session_id() 发布于:2020-09-28 09:45 网页数据处理 发布于:2020-09-17 08:49 PHP静态变量的使用 发布于:2020-09-16 16:26 php md5 运算 发布于:2020-09-03 14:07 获取订单编号 发布于:2020-08-28 16:54 控制台的输入和输出 发布于:2020-08-22 13:07 依赖注入,控制翻转,ICO容器 发布于:2020-08-16 16:37 指定日期时间段过滤不可用时间段 发布于:2020-07-31 00:37 PHP常量 发布于:2020-07-30 02:06 PHP正则表达式零宽度 发布于:2020-07-29 18:36 PHP正则表达式 发布于:2020-07-29 18:27 pengzhile md4 亿次 发布于:2020-07-29 17:47 PHP字符串 发布于:2020-07-28 19:57 php数组 发布于:2020-07-30 02:56 php数据类型 发布于:2020-07-28 16:51 php变量 发布于:2020-07-28 18:12 echo语句 发布于:2020-07-28 10:02 教程-变量实例 发布于:2020-07-28 09:34 小程序项目定价估算方案 发布于:2020-07-26 19:06 将ASCII码和GB2312码混合字符串中的全角大写字母转成半角大写字母。 Turn SBC case capital letters into DBC case capital letters in ASCII and GB2312 encoded strings. 发布于:2020-07-09 09:30 算法-排序-冒泡排序 发布于:2020-07-04 12:20 计算复利。 发布于:2020-11-18 19:02 单例模式(一个类只有一个对象),并封装数据库连接 发布于:2020-06-23 08:34 mongodb aggregate sample 的使用 发布于:2020-06-19 23:34 1 4-17 phc 发布于:2020-06-17 11:27 php测试 发布于:2020-06-15 16:10 百度面试题 PHP重新排列数组的数,使得负数都排在正数的前 发布于:2020-06-04 23:16 [更多]
显示目录

错误处理

PHP 错误处理

在使用 PHP 的过程中也会遇到错误,那么我们该怎么处理这些错误呢?一起来通过本节的内容进行了解。

在 PHP 中,默认的错误处理很简单。一条错误消息会被发送到浏览器,这条消息带有文件名、行号以及描述错误的消息。

PHP 错误处理

在创建脚本和 Web 应用程序时,错误处理是一个重要的部分。如果您的代码缺少错误检测编码,那么程序看上去很不专业,也为安全风险敞开了大门。

本教程介绍了 PHP 中一些最为重要的错误检测方法。

我们将为您讲解不同的错误处理方法:

  • 简单的 "die()" 语句
  • 自定义错误和错误触发器
  • 错误报告

基本的错误处理:使用 die() 函数

第一个实例展示了一个打开文本文件的简单脚本:

 <?php
 $file=fopen("welcome.txt","r");
 ?>

如果文件不存在,您会得到类似这样的错误:

 Warning: fopen(welcome.txt) [function.fopen]: failed to open stream:
 No such file or directory in C:webfoldertest.php on line 2

为了避免用户得到类似上面的错误消息,我们在访问文件之前检测该文件是否存在:

<?php
 if(!file_exists("welcome.txt"))
 {
 die("File not found");
 }
 else
 {
 $file=fopen("welcome.txt","r");
 }
 ?>

现在,如果文件不存在,您会得到类似这样的错误消息:

 File not found

相比之前的代码,上面的代码更有效,这是由于它采用了一个简单的错误处理机制在错误之后终止了脚本。

然而,简单地终止脚本并不总是恰当的方式。让我们研究一下用于处理错误的备选的 PHP 函数。


创建自定义错误处理器

创建一个自定义的错误处理器非常简单。我们很简单地创建了一个专用函数,可以在 PHP 中发生错误时调用该函数。

该函数必须有能力处理至少两个参数 (error level 和 error message),但是可以接受最多五个参数(可选的:file, line-number 和 error context):

语法

 error_function(error_level,error_message,
 error_file,error_line,error_context)
参数 描述
error_level 必需。为用户定义的错误规定错误报告级别。必须是一个数字。参见下面的表格:错误报告级别。
error_message 必需。为用户定义的错误规定错误消息。
error_file 可选。规定错误发生的文件名。
error_line 可选。规定错误发生的行号。
error_context 可选。规定一个数组,包含了当错误发生时在用的每个变量以及它们的值。

错误报告级别

这些错误报告级别是用户自定义的错误处理程序处理的不同类型的错误:

常量 描述
2 E_WARNING 非致命的 run-time 错误。不暂停脚本执行。
8 E_NOTICE run-time 通知。在脚本发现可能有错误时发生,但也可能在脚本正常运行时发生。
256 E_USER_ERROR 致命的用户生成的错误。这类似于程序员使用 PHP 函数 trigger_error() 设置的 E_ERROR。
512 E_USER_WARNING 非致命的用户生成的警告。这类似于程序员使用 PHP 函数 trigger_error() 设置的 E_WARNING。
1024 E_USER_NOTICE 用户生成的通知。这类似于程序员使用 PHP 函数 trigger_error() 设置的 E_NOTICE。
4096 E_RECOVERABLE_ERROR 可捕获的致命错误。类似 E_ERROR,但可被用户定义的处理程序捕获。(参见 set_error_handler())
8191 E_ALL 所有错误和警告。(在 PHP 5.4 中,E_STRICT 成为 E_ALL 的一部分)

现在,让我们创建一个处理错误的函数:

 function customError($errno, $errstr)
 {
 echo "<b>Error:</b> [$errno] $errstr<br>";
 echo "Ending Script";
 die();
 }

上面的代码是一个简单的错误处理函数。当它被触发时,它会取得错误级别和错误消息。然后它会输出错误级别和消息,并终止脚本。

现在,我们已经创建了一个错误处理函数,我们需要确定在何时触发该函数。

设置错误处理程序 PHP 的默认错误处理程序是内建的错误处理程序。我们打算把上面的函数改造为脚本运行期间的默认错误处理程序。

可以修改错误处理程序,使其仅应用到某些错误,这样脚本就能以不同的方式来处理不同的错误。然而,在本例中,我们打算针对所有错误来使用我们自定义的错误处理程序:

set_error_handler("customError"); 由于我们希望我们的自定义函数能处理所有错误,set_error_handler() 仅需要一个参数,可以添加第二个参数来规定错误级别。

实例 通过尝试输出不存在的变量,来测试这个错误处理程序:

<?php
 //error handler function
 function customError($errno, $errstr)
 {
 echo "<b>Error:</b> [$errno] $errstr";
 }

 //set error handler
 set_error_handler("customError");

 //trigger error
 echo($test);
 ?>

以上代码的输出如下所示:

 Error: [8] Undefined variable: test

触发错误

在脚本中用户输入数据的位置,当用户的输入无效时触发错误是很有用的。在 PHP 中,这个任务由 trigger_error() 函数完成。

实例 在本例中,如果 "test" 变量大于 "1",就会发生错误:

<?php
 $test=2;
 if ($test>1)
 {
 trigger_error("Value must be 1 or below");
 }
 ?>

以上代码的输出如下所示:

 Notice: Value must be 1 or below
 in C:webfoldertest.php on line 6

您可以在脚本中任何位置触发错误,通过添加的第二个参数,您能够规定所触发的错误级别。

可能的错误类型:

  • E_USER_ERROR - 致命的用户生成的 run-time 错误。错误无法恢复。脚本执行被中断。
  • E_USER_WARNING - 非致命的用户生成的 run-time 警告。脚本执行不被中断。
  • E_USER_NOTICE - 默认。用户生成的 run-time 通知。在脚本发现可能有错误时发生,但也可能在脚本正常运行时发生。

    实例

    在本例中,如果 "test" 变量大于 "1",则发生 E_USER_WARNING 错误。如果发生了 E_USER_WARNING,我们将使用我们自定义的错误处理程序并结束脚本:

    <?php
    //error handler function
    function customError($errno, $errstr)
    {
    echo "<b>Error:</b> [$errno] $errstr<br>";
    echo "Ending Script";
    die();
    }
    
    //set error handler
    set_error_handler("customError",E_USER_WARNING);
    
    //trigger error
    $test=2;
    if ($test>1)
    {
    trigger_error("Value must be 1 or below",E_USER_WARNING);
    }
    ?>
    

    以上代码的输出如下所示:

    Error: [512] Value must be 1 or below
    Ending Script
    

    现在,我们已经学习了如何创建自己的 error,以及如何触发它们,接下来我们研究一下错误记录。


错误记录

在默认的情况下,根据在 php.ini 中的 error_log 配置,PHP 向服务器的记录系统或文件发送错误记录。通过使用 error_log() 函数,您可以向指定的文件或远程目的地发送错误记录。

通过电子邮件向您自己发送错误消息,是一种获得指定错误的通知的好办法。

通过 E-Mail 发送错误消息

在下面的例子中,如果特定的错误发生,我们将发送带有错误消息的电子邮件,并结束脚本:

 <?php
 //error handler function
 function customError($errno, $errstr)
 {
 echo "<b>Error:</b> [$errno] $errstr<br>";
 echo "Webmaster has been notified";
 error_log("Error: [$errno] $errstr",1,
 "someone@example.com","From: webmaster@example.com");
 }

 //set error handler
 set_error_handler("customError",E_USER_WARNING);

 //trigger error
 $test=2;
 if ($test>1)
 {
 trigger_error("Value must be 1 or below",E_USER_WARNING);
 }
 ?>

以上代码的输出如下所示:

 Error: [512] Value must be 1 or below
 Webmaster has been notified

接收自以上代码的邮件如下所示:

 Error: [512] Value must be 1 or below

这个方法不适合所有的错误。常规错误应当通过使用默认的 PHP 记录系统在服务器上进行记录。

由JSRUN为你提供的PHP在线工具
        JSRUN提供的PHP在线运行,PHP 在线编译工具,基于linux操作系统环境提供线上编译和线上运行,具有运行快速,运行结果与常用开发、生产环境保持一致的特点。

title

使用此草稿 删除草稿

皮肤:

运行模式:

嵌入代码 iframe嵌入: