PHP错误和异常处理功能模块示例

前端之家收集整理的这篇文章主要介绍了PHP错误和异常处理功能模块示例前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。

@H_403_0@本文实例讲述了PHP错误和异常处理功能模块。分享给大家供大家参考,具体如下:


@H_403_0@

一、错误类型和基本的调试方法


@H_403_0@PHP程序的错误发生一般归属于下列三个领域:


@H_403_0@<span style="color: #ff6600">

语法错误


@H_403_0@语法错误最常见,并且也容易修复。如:代码中遗漏一个分号。这类错误会阻止脚本的执行。


@H_403_0@<span style="color: #ff6600">

运行时错误


@H_403_0@这种错误一般不会阻止PHP脚本的执行,但会阻止当前要做的事情。输出一条错误,但PHP脚本继续执行


@H_403_0@<span style="color: #ff6600">

逻辑错误


@H_403_0@这种错误最麻烦,既不阻止脚本执行,也不输出错误消息。
一个异常则是在一个程序执行过程中出现的一个例外,或是一个事件,它中断了正常指令的运行,跳转到其他程序模块继续执行。


@H_403_0@<span style="color: #0000ff">

PHP错误报告级别


@H_403_0@E_ALL //所有信息值:6143
E_ERROR//致命的运行时错误值:1
E_RECOVERABLE_ERROR //接近致命的运行时错误,若未被捕获则视同E_ERROR 值:4096
E_WARNING //运行时警告(非致命性错误) 值:2
E_PARSE//编译时解析错误值:4
E_NOTICE //运行时提醒(经常是bug,也可能是有意的) 值:8
E_STRICT//编码标准化警告(建议如何修改以向前兼容) 值:2048
E_CORE_ERROR //PHP启动时初始化过程中的致命错误值:16
E_CORE_WARNING //PHP启动时初始化过程中的警告(非致命性错)值:32
E_COMPILE_ERROR //编译时致命性错值:64
E_COMPILE_WARNING //编译时警告(非致命性错) 值:128
E_USER_ERROR //用户自定义的致命错误值:256
E_USER_WARNING //用户自定义的警告(非致命性错误) 值:512
E_USER_NOTICE //用户自定义的提醒(经常是bug) 值:1024


@H_403_0@<span style="color: #0000ff">

PHP.ini配置文件


@H_403_0@display_errors: 是否开启PHP输出错误报告的功能
值为:On(默认输出错误报告)、Off(屏蔽所有错误信息)
PHP脚本中可调用ini_set( )函数,动态设置PHP.ini配置文件.
如:ini_set("display_errors","On"); //显示所有错误信息
error_reporting: 设置不同的错误报告级别。
error_reporting= E_ALL & ~E_NOTICE
--可以抛出任何非注意的错误,默认值
error_reporting= E_ERROR | E_PARSE | E_CORE_ERROR
--只考虑致命的运行时错误、新解析错误和核心错误
error_reporting= E_ALL & ~(E_USER_ERROR | E_USER_WARNING | E_USER_NOTICE)
--报告除用户导致的错误之外的所有错误
PHP脚本可以通过error_reporting( )函数动态设置错误报告级别。如:error_reporting(EALL);]


@H
403_0@设置错误级别实例:error.PHP


<div class="jb51code">
<pre class="brush:PHP;">

测试错误报告

@H_403_0@PHP错误报告行为的配置指令

@H_403_0@显示PHP引擎在初始化时遇到的错误。 log_errors= On 决定日志语句记录的位置。 error_log(默认null) 指定错误写进的文件或记录错误日志于系统日志syslog。 Log_errors_max_len=1024 每个日志项的最大长度,单位是字节。0表示最大。

@H_403_0@

二、错误日志

@H_403_0@两种方式记录错误日志:

@H_403_0@使用指定的文件记录错误报告日志 错误日志记录到操作系统的日志里

@H_403_0@使用指定的文件记录错误报告日志

@H_403_0@1、先配置PHP.ini:

@H_403_0@PHP发送每个错误 display_errors=Off//不显示错误报告 log_errors=On//决定日志语句记录的位置。 log_errors_max_log=1024// 每个日志项的最大长度 error_log=G:/myerror.log//指定错误写进的文件

@H_403_0@2、使用函数:在PHP文件中使用error_log()来记录日志,就可以将信息写入到myerror.log文件

@H_403_0@如:

PHP;"> error_log("登录失败了!");
@H_403_0@3、使用四个函数来记录日志:

PHP;"> define_syslog_variables();//为系统日志初始化配置 openlog();//打开一个日志链接 syslog();//发送一条日志
@H_403_0@例子

PHP;">
PHP;">
@H_403_0@查看日志:如windows系统,通过右击“我的电脑”-> 选择管理选项->在系统工具菜单中选择事件查看器->在应用程序选项中即可看到日志了

@H_403_0@

三、异常处理

@H_403_0@异常(Exception)处理用于在指定的错误发生时改变脚本的正常流程。是PHP5中的一个新的重要特性。异常处理是一种可扩展、易维护的错误处理统一机制,并提供了一种新的面向对象的错误处理方式。

@H_403_0@异常处理格式:

PHP;"> try{ //使用try去包含可能会发生异常的代码. //一旦出现异常try进行捕获异常,交给catch处理。 //抛出异常语句:throw 异常对象。 }catch(异常对象参数){ //在这里做异常处理。 }[catch(。,,){ .. .. .. }]
@H_403_0@更多关于PHP相关内容感兴趣的读者可查看本站专题:《》、《》、《》、《》、《》、《》、《》、《》及《PHP常见数据库操作技巧汇总》

@H_403_0@希望本文所述对大家PHP程序设计有所帮助。

猜你在找的PHP相关文章