php 错误和异常处理
一、错误和异常处理 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 <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.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();//发送一条日志 例子 <?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系统,通过右击“我的电脑”-> 选择管理选项->在系统工具菜单中选择事件查看器->在应用程序选项中即可看到日志了 1.3 异常处理 异常(Exception)处理用于在指定的错误发生时改变脚本的正常流程。是PHP5中的一个新的重要特性。异常处理是一种可扩展、易维护的错误处理统一机制,
并提供了一种新的面向对象的错误处理方式。
异常处理格式:
try{
使用try去包含可能会发生异常的代码.
一旦出现异常try进行捕获异常,交给catch处理。
抛出异常语句:throw 异常对象。
}catch(异常对象参数){
在这里做异常处理。
}[catch(。,,){
.. .. ..
}]
php 错误和异常处理的更多相关文章
- PHP错误以及异常处理
以前一直觉得php的异常处理没有什么,现在才发现这个还真是门学问,于是狠下心来好好研究了一下,写一篇文章,也作备忘吧. 1. php错误 无论是什么语言编程,都会有如下三种错误,当然php也不例外. ...
- Yii中的错误及异常处理
Yii中的错误及异常处理 Yii已经默认已经在CApplication上实现了异常和错误的接管,这是通过php的set_exception_handler, set_error_handler实现的. ...
- 再谈PHP错误与异常处理
博客好久没有更新了,实在惭愧,最近在忙人生大事,哈哈!这段时间没有看什么新的东西,结合项目中遇到的PHP异常处理问题,我又重新梳理了之前模糊的概念,希望对大家理解PHP异常处理有所帮助. 请一定要注意 ...
- Golang错误和异常处理的正确姿势
Golang错误和异常处理的正确姿势 错误和异常是两个不同的概念,非常容易混淆.很多程序员习惯将一切非正常情况都看做错误,而不区分错误和异常,即使程序中可能有异常抛出,也将异常及时捕获并转换成错误.从 ...
- 【PHP】解析PHP中的错误和异常处理
目录结构: contents structure [-] 错误级别 自定义处理器 设置异常日志 自定义异常类 在这篇文章中,笔者将会阐述PHP中的异常处理,希望能够对你有所帮助. 1.错误级别 PHP ...
- ThinkPHP5.0源码学习之注册错误和异常处理机制
在base.php文件中,用一句代码\think\Error::register();实现错误和异常处理机制的注册. // 注册错误和异常处理机制 \think\Error::register(); ...
- 2018/05/02 PHP 之错误与异常处理
在学习中,越学习越觉得自己基础薄弱. 在平常工作中,对于某些错误处理感觉不知道怎么下手,于是决定重新再整理一下. 强烈推荐这篇文章,真的感觉学习到了很多. 部分引用::再谈PHP错误与异常处理 -- ...
- PHP 注册错误和异常处理机制
注册错误和异常处理机制有三个PHP函数需要学习 1. register_shutdown_function('Bootstrap\Library\Frame::fatalError'); 2. set ...
- PHP常用功能块_错误和异常处理 — php(32)
一.错误和异常处理 1.1 错误类型和基本的调试方法PHP程序的错误发生一般归属于下列三个领域: 语法错误:语法错误最常见,并且也容易修复.如:代码中遗漏一个分号.这类错误会阻止脚本的执行. 运行时错 ...
随机推荐
- C#的MD5哈希值计算
MD5哈希值计算:(仅仅是记录一下) /// <summary> /// 获取字符串的MD5值 /// </summary> /// <param name=" ...
- [Jobdu] 题目1499:项目安排
题目描述: 小明每天都在开源社区上做项目,假设每天他都有很多项目可以选,其中每个项目都有一个开始时间和截止时间,假设做完每个项目后,拿到报酬都是不同的.由于小明马上就要硕士毕业了,面临着买房.买车.给 ...
- Oracle某些功能实现语句处理方法
触发器以及序列CREATE OR REPLACE TRIGGER t_MSTB_BDS_DATA BEFORE INSERT ON MSTB_BDS_DATA FOR EACH ROW DECLARE ...
- UBoot启动代码第一阶段流程
http://blog.csdn.net/xautfengzi/article/details/7470134 前段时间了看了UBoot的源码,放了一段时间之后忘得差不多了.现做一些注释,方便以后温习 ...
- tomcat 启动自动加载外部项目
conf/server.xml 配置 <!--<Context path="/upload" docBase="E://upload" />- ...
- Frosh Week
Problem Description During Frosh Week, students play various fun games to get to know each other and ...
- vcpkg —— VC++ 打包工具
引用: http://www.tuicool.com/articles/aeiYz2v vcpkg 是微软 C++ 团队开发的在 Windows 上运行的 C/C++ 项目包管理工具,可以帮助您在 W ...
- 一款基于jquery实现的鼠标单击出现水波特效
今天要为大家绍一款由jquery实现的鼠标单击出现水波特效.用鼠标猛点击页面,你可以看到页面不断出面水波纹效果.然后水波纹渐渐消失.效果非常不错.我们一起看下效果图: 在线预览 源码下载 实现的代 ...
- list集合绑定在datagridview上时如何实现排序
List<Person> lst = new List<Person>(); lst.Add(new Person("A", "1")) ...
- 简易web项目jdbcUtil
jdbc.username=root jdbc.password=root jdbc.driver=com.mysql.jdbc.Driver jdbc.url=jdbc:mysql://mini1: ...