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

 更新时间:2016年11月12日 12:25:38   作者:郑宏鑫erke  
这篇文章主要介绍了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相关内容感兴趣的读者可查看本站专题:《PHP错误与异常处理方法总结》、《php字符串(string)用法总结》、《PHP数组(Array)操作技巧大全》、《PHP运算与运算符用法总结》、《PHP网络编程技巧总结》、《PHP基本语法入门教程》、《php面向对象程序设计入门教程》、《php+mysql数据库操作入门教程》及《php常见数据库操作技巧汇总

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

相关文章

  • php中的异常和错误浅析

    php中的异常和错误浅析

    PHP错误是属于php程序自身的问题,一般是由非法的语法,环境问题导致的,使得编译器无法通过检查甚至无法运行的情况。PHP异常一般是业务逻辑上出现的不合预期、与正常流程不同的状况,不是语法错误。本文介绍了php中异常和错误的相关资料,需要的朋友可以参考下。
    2017-05-05
  • PHP 99乘法表的几种实现代码

    PHP 99乘法表的几种实现代码

    对于刚学PHP的新手来讲,用php写九九乘法表无疑是非常经典的一道练习题,但不要小看这道练习题,它对于逻辑的考验还是相当到位的,这里脚本之家小编就为大家分享一下
    2020-10-10
  • PHP用反撇号执行外部命令

    PHP用反撇号执行外部命令

    shell_exec() 命令行实际上仅是反撇号 ` 操作符的变体,如果您编写过 shell 或 Perl 脚本,您就知道可以在反撇号操作符内部捕捉其他命令的输出。
    2015-04-04
  • php5中date()得出的时间为什么不是当前时间的解决方法

    php5中date()得出的时间为什么不是当前时间的解决方法

    从php5.10开始,php中加入了时区的设置,在php中显示的时间都是格林威治标准时间,这就造成了我们 中国的用户会差八个小时的问题!
    2008-06-06
  • 简述php环境搭建与配置

    简述php环境搭建与配置

    本文主要对php的环境搭建与配置进行步骤介绍。文章中标出了重点,方便大家阅读,需要的朋友可以参考下
    2016-12-12
  • php中cURL error 60:SSL certificate problem: unable to get local issuer certificate问题的解决方法

    php中cURL error 60:SSL certificate problem: unable to 

    PHP中cURL错误60通常表示SSL证书问题,即无法获取本地颁发机构证书,这通常是由于cURL无法验证远程服务器的SSL证书导致的,本给大家介绍了如何解决php中cURL error 60,需要的朋友可以参考下
    2023-12-12
  • php生成gif动画的方法

    php生成gif动画的方法

    这篇文章主要介绍了php合成或者创建gif动画,并提供了两个实例,感兴趣的小伙伴们可以参考一下
    2015-11-11
  • PHP实现支持SSL连接的SMTP邮件发送类

    PHP实现支持SSL连接的SMTP邮件发送类

    这篇文章主要介绍了PHP实现支持SSL连接的SMTP邮件发送类,实例分析了php实现smtp邮件发送类的原理与技巧,以及支持SSL连接的方法,需要的朋友可以参考下
    2015-03-03
  • php smtp实现发送邮件功能

    php smtp实现发送邮件功能

    这篇文章主要为大家详细介绍了php smtp实现发送邮件功能,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2017-06-06
  • 当前比较流行的两款PHP加密、解密工具Zend Guard和iconCube介绍

    当前比较流行的两款PHP加密、解密工具Zend Guard和iconCube介绍

    这篇文章主要介绍了当前比较流行的两款PHP加密、解密工具Zend Guard和iconCube介绍,本文还给出了iconCube的安装教程,需要的朋友可以参考下
    2014-09-09

最新评论