• 注册
  • 经验分享 经验分享 关注:4 内容:15179

    php常见报错级别

  • 查看作者
  • 打赏作者
  • Lv.10
    封号会员

    PHP的错误处理机制允许开发者在代码执行出错时获得提示信息,这些错误信息根据严重程度被划分为不同的级别,PHP的错误级别主要分为以下几种:

    php常见报错级别
    (图片来源网络,侵删)

    1、通知(E_NOTICE):

    这是最低级别的错误,表示脚本遇到一些可能会引起问题的情况,但并非错误,访问一个未定义的变量或者给未声明的数组索引赋值,默认情况下,E_NOTICE级别的错误不会显示给用户,因为它们通常是脚本正常执行过程中的预期行为。

    “`php

    $var = $undefinedVar; // E_NOTICE: Undefined variable

    “`

    2、警告(E_WARNING):

    这类错误通常表示脚本遇到一些问题,但PHP会继续执行,警告错误应该被注意,因为它们可能会在将来的PHP版本中变成更严重的错误,包含或要求一个不存在的文件,或者传递错误的数据类型给函数。

    “`php

    include(‘nonexistentfile.php’); // E_WARNING: include(): Failed opening ‘nonexistentfile.php’ for inclusion

    “`

    3、错误(E_ERROR):

    这是严重的错误,当脚本遇到此类错误时,将无法继续执行,试图调用一个不存在的函数,或者内存分配失败。

    “`php

    unknownFunction(); // E_ERROR: Call to undefined function unknownFunction()

    “`

    4、解析错误(E_PARSE):

    这类错误发生在脚本编译阶段,通常是由于语法错误导致的,解析错误是非常严重的,因为它们阻止了脚本的执行。

    “`php

    if ($condition) // E_PARSE: syntax error, unexpected ‘)’

    “`

    5、致命错误(E_FATAL):

    这个级别实际上是E_ERROR的一个子集,表示在错误发生后脚本无法继续执行,从PHP 5.2.0开始,所有的E_ERROR级别的错误都被认为是致命错误。

    6、用户提示(E_USER_ERROR、E_USER_WARNING、E_USER_NOTICE):

    这些错误是由用户触发的,通过使用trigger_error()函数,它们可以用来给开发者或用户提供自定义的警告、错误和通知。

    “`php

    trigger_error(‘User error’, E_USER_ERROR); // E_USER_ERROR: User error

    “`

    以下是关于这些错误级别的更多详细信息:

    E_STRICT:

    这个级别用于指明代码中潜在的不好的实践或与将来PHP版本不兼容的代码,使用已废弃的函数或特性。

    E_DEPRECATED:

    当代码使用了不建议使用(已废弃)的特性或函数时,会触发这个级别的错误。

    E_USER_DEPRECATED:

    与E_DEPRECATED相似,但这是由用户触发的废弃警告。

    E_ALL:

    这个特殊的级别包括了所有错误和警告,除了E_STRICT,在实际开发中,通常不会在生产环境中使用E_ALL,因为它会输出所有错误,包括不太重要的通知。

    对于错误处理,PHP提供了几种机制:

    1、错误报告指令:

    可以使用error_reporting()函数来设置哪些级别的错误应该被报告,也可以在php.ini文件中使用error_reporting指令进行设置。

    2、错误日志:

    可以通过ini_set()或php.ini中的log_errors指令,将错误日志记录到服务器上的文件中。

    3、错误显示:

    display_errors指令决定是否将错误信息作为输出的一部分显示给用户。

    4、自定义错误处理:

    可以使用set_error_handler()和set_exception_handler()函数来定义自定义的错误处理函数。

    5、错误捕获:

    可以使用try和catch块捕获异常。

    在开发过程中,合理地处理错误非常重要,应该尽量捕获和处理所有可能出现的错误,避免在用户面前显示敏感信息,同时也要确保在开发阶段能够获得足够的错误信息以便调试。

    为了确保代码的健壮性和可维护性,推荐的做法是在生产环境中只报告E_ERROR、E_WARNING和E_PARSE级别的错误,并确保所有的E_NOTICE和E_STRICT级别的错误在部署到生产环境之前得到解决,这样,不仅可以提高用户体验,还能确保代码的稳定性和安全性。

    请登录之后再进行评论

    登录
  • 快速发布
  • 任务
  • 实时动态
  • 偏好设置
  • 帖子间隔 侧栏位置: