PHP错误和异常处理功能模块示例
本文实例讲述了PHP错误和异常处理功能模块。分享给大家供大家参考,具体如下
一、错误类型和基本的调试方法
PHP程序的错误发生一般归属于下列三个领域
语法错误
语法错误最常见,并且也容易修复。如代码中遗漏一个分号。这类错误会阻止脚本的执行。
运行时错误
这种错误一般不会阻止PHP脚本的执行,但会阻止当前要做的事情。输出一条错误,但php脚本继续执行
逻辑错误
这种错误最麻烦,既不阻止脚本执行,也不输出错误消息。
一个异常则是在一个程序执行过程中出现的一个例外,或是一个事件,它中断了正常指令的运行,跳转到其他程序模块继续执行。
PHP的错误报告级别
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
php.ini配置文件
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(E_ALL);]
设置错误级别实例error.php
<h2>测试错误报告</h2> <?php /开启php.ini中的display_errors指令,只有该指令开启如有错误报告才能输出/ ini_set('display_errors',1); /通过error_reporting()函数设置在本脚本中,输出所有级别的错误报告/ error_reporting(E_ALL); /“注意(notice)”的报告,不会阻止脚本的执行,并且不一定是一个问题/ getType($var);//调用函数时提供的参数变量没有在之前声明 /“警告(warning)”的报告,指示一个问题,不会阻止脚本的执行/ getType();//调用函数时没有提供必要的参数 /“错误(error)”的报告,它会终止程序,脚本不会再向下执行/ get_Type();//调用一个没有被定义的函数 ?>
PHP错误报告行为的配置指令
display_startup_errors= Off
是否显示PHP引擎在初始化时遇到的错误。
log_errors= On
决定日志语句记录的位置。
error_log(默认null)
指定错误写进的文件或记录错误日志于系统日志syslog。
Log_errors_max_len=1024
每个日志项的最大长度,单位是字节。0表示最大。
二、错误日志
两种方式记录错误日志
使用指定的文件记录错误报告日志
错误日志记录到操作系统的日志里
使用指定的文件记录错误报告日志
1、先配置php.ini:
error_reporting= E_ALL//将向PHP发送每个错误
display_errors=Off//不显示错误报告
log_errors=On//决定日志语句记录的位置。
log_errors_max_log=1024// 每个日志项的最大长度
error_log=G:/myerror.log//指定错误写进的文件
2、使用函数在php文件中使用error_log()来记录日志,就可以将信息写入到myerror.log文件中
如
error_log("登录失败了!");
3、使用四个函数来记录日志
define_syslog_variables();//为系统日志初始化配置 openlog();//打开一个日志链接 syslog();//发送一条日志
例子
<?php if(!Ora_Logon($username, $password)){ error_log("Oracle数据库不可用!", 0); //将错误消息写入到操作系统日志中 } if(!($foo=allocate_new_foo()){ error_log("出现大麻烦了!", 1, "webmaster@.mydomain."); //发送到管理员邮箱中 } error_log("搞砸了!",2, "localhost:5000"); //发送到本机对应5000端口的服务器中 error_log("搞砸了!", 3, "/usr/local/errors.log"); //发送到指定的文件中 ?>
<?php define_syslog_variables(); openlog("PHP5", LOG_PID , LOG_USER); syslog(LOG_WARNING, "警告报告向syslog中发送的演示,警告时间".date("Y/m/dH:i:s")); closelog(); ?>
查看日志如windows系统,通过右击“我的电脑”-> 选择管理选项->在系统工具菜单中选择事件查看器->在应用程序选项中即可看到日志了
三、异常处理
异常(Exception)处理用于在指定的错误发生时改变脚本的正常流程。是PHP5中的一个新的重要特性。异常处理是一种可扩展、易维护的错误处理统一机制,并提供了一种新的面向对象的错误处理方式。
异常处理格式
try{ //使用try去包含可能会发生异常的代码. //一旦出现异常try进行捕获异常,交给catch处理。 //抛出异常语句throw 异常对象。 }catch(异常对象参数){ //在这里做异常处理。 }[catch(。,,){ .. .. .. }]
更多关于PHP相关内容感兴趣的读者可查看本站专题《》、《》、《》、《》、《》、《》、《》、《》及《》
希望本文所述对大家PHP程序设计有所帮助。
编程语言
- 如何快速学会编程 如何快速学会ug编程
- 免费学编程的app 推荐12个免费学编程的好网站
- 电脑怎么编程:电脑怎么编程网咯游戏菜单图标
- 如何写代码新手教学 如何写代码新手教学手机
- 基础编程入门教程视频 基础编程入门教程视频华
- 编程演示:编程演示浦丰投针过程
- 乐高编程加盟 乐高积木编程加盟
- 跟我学plc编程 plc编程自学入门视频教程
- ug编程成航林总 ug编程实战视频
- 孩子学编程的好处和坏处
- 初学者学编程该从哪里开始 新手学编程从哪里入
- 慢走丝编程 慢走丝编程难学吗
- 国内十强少儿编程机构 中国少儿编程机构十强有
- 成人计算机速成培训班 成人计算机速成培训班办
- 孩子学编程网上课程哪家好 儿童学编程比较好的
- 代码编程教学入门软件 代码编程教程