Maison > développement back-end > tutoriel php > PHP常用功能块_错误和异常处理 — php(32)

PHP常用功能块_错误和异常处理 — php(32)

WBOY
Libérer: 2016-08-08 09:23:41
original
1095 Les gens l'ont consulté

一、错误和异常处理

1.1 错误类型和基本的调试方法
??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

<span><h2>测试错误报告</h2>
<span>php
</span><span>/*</span><span>开启php.ini中的display_errors指令,只有该指令开启如有错误报告才能输出</span><span>*/</span><span>ini_set(</span><span>'</span><span>display_errors</span><span>'</span>,<span>1</span><span>);
</span><span>/*</span><span>通过error_reporting()函数设置在本脚本中,输出所有级别的错误报告</span><span>*/</span><span>error_reporting(E_ALL);
</span><span>/*</span><span>“注意(notice)”的报告,不会阻止脚本的执行,并且不一定是一个问题</span><span>*/</span><span>getType($</span><span>var</span>);<span>//</span><span>调用函数时提供的参数变量没有在之前声明</span><span>/*</span><span>“警告(warning)”的报告,指示一个问题,但是不会阻止脚本的执行</span><span>*/</span><span>getType();</span><span>//</span><span>调用函数时没有提供必要的参数</span><span>/*</span><span>“错误(error)”的报告,它会终止程序,脚本不会再向下执行</span><span>*/</span><span>get_Type();</span><span>//</span><span>调用一个没有被定义的函数</span>?></span>
Copier après la connexion

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

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

1.2 错误日志

两种方式记录错误日志:
??使用指定的文件记录错误报告日志
??错误日志记录到操作系统的日志里

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

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("登录失败了!");

2、使用四个函数来记录日志:
??define_syslog_variables();//为系统日志初始化配置
??openlog();//打开一个日志链接
??syslog();//发送一条日志

例子

<span><span>php
</span><span>if</span>(!<span>Ora_Logon($username, $password)){
error_log(</span><span>"</span><span>Oracle数据库不可用!</span><span>"</span>, <span>0</span><span>);
</span><span>//</span><span>将错误消息写入到操作系统日志中</span><span>}
</span><span>if</span>(!($foo=<span>allocate_new_foo()){
error_log(</span><span>"</span><span>出现大麻烦了!</span><span>"</span>, <span>1</span>, <span>"</span><span>webmaster@www.mydomain.com</span><span>"</span>); <span>//</span><span>发送到管理员邮箱中</span><span>}
error_log(</span><span>"</span><span>搞砸了!</span><span>"</span>,<span>2</span>, <span>"</span><span>localhost:5000</span><span>"</span><span>);
</span><span>//</span><span>发送到本机对应5000端口的服务器中</span>error_log(<span>"</span><span>搞砸了!</span><span>"</span>, <span>3</span>, <span>"</span><span>/usr/local/errors.log</span><span>"</span><span>);
</span><span>//</span><span>发送到指定的文件中</span>?></span>
Copier après la connexion

<span><span>php
define_syslog_variables();
openlog(</span><span>"</span><span>PHP5</span><span>"</span><span>, LOG_PID , LOG_USER);
syslog(LOG_WARNING, </span><span>"</span><span>警告报告向syslog中发送的演示,警告时间:</span><span>"</span>.date(<span>"</span><span>Y/m/dH:i:s</span><span>"</span><span>));
closelog();
</span>?></span>
Copier après la connexion

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

1.3 异常处理

异常(Exception)处理用于在指定的错误发生时改变脚本的正常流程。是PHP5中的一个新的重要特性。异常处理是一种可扩展、易维护的错误处理统一机制,并提供了一种新的面向对象的错误处理方式。
??异常处理格式:
try{
使用try去包含可能会发生异常的代码.
一旦出现异常try进行捕获异常,交给catch处理。
抛出异常语句:throw 异常对象。
}catch(异常对象参数){
在这里做异常处理。
}[catch(。,,){
.. .. ..
}]

以上就介绍了PHP常用功能块_错误和异常处理 — php(32),包括了方面的内容,希望对PHP教程有兴趣的朋友有所帮助。

Étiquettes associées:
source:php.cn
Déclaration de ce site Web
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn
Tutoriels populaires
Plus>
Derniers téléchargements
Plus>
effets Web
Code source du site Web
Matériel du site Web
Modèle frontal