这里有新鲜出炉的 PHP 教程,程序狗速度看过来!
PHP(外文名: Hypertext Preprocessor,中文名:"超文本预处理器")是一种通用开源脚本语言。语法吸收了 C 语言、Java 和 Perl 的特点,入门门槛较低,易于学习,使用广泛,主要适用于 web 开发领域。PHP 的文件后缀名为 php。
这篇文章主要介绍了 PHP 错误和异常处理功能模块, 较为详细的分析了 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@www.mydomain.com"); //发送到管理员邮箱中
- }
- 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 程序设计有所帮助。
来源: http://www.phperz.com/article/17/0802/341268.html