php一些常见的错误以及处理方式
来源:互联网 发布:外卖小票打印软件 编辑:程序博客网 时间:2024/05/16 16:01
错误处理:
1.1 错误报告级别
PHP程序的错误发生一般归属于下列三个领域:
语法错误:
语法错误最常见,并且也容易修复。如:代码中遗漏一个分号。这类错误会阻止脚本的执行。
运行时错误:
这种错误一般不会阻止PHP脚本的执行,但会阻止当前要做的事情。输出一条错误,但php脚本继续执行
逻辑错误:
这种错误最麻烦,既不阻止脚本执行,也不输出错误消息。
1.2 调整错误报告级别
一个异常(后面面向对象时会讲)则是在一个程序执行过程中出现的一个例外,或是一个事件,它中断了正常指令的运行,跳转到其他程序模块继续执行。
1.3 错误处理的一些常用函数
确定PHP错误报告行为的配置指令:
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);
实例
<html>
<head><title>测试错误报告</title></head>
<body>
<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();//调用一个没有被定义的函数
?>
</body>
</html>
set_error_handler():注意:E_ERROR、E_PARSE、E_CORE_ERROR、E_CORE_WARNING、E_COMPILE_ERROR、E_COMPILE_WARNING是不会被这个句柄处理的,也就是会用原始的方式显示,不过通常情况下不会发生。
使用set_error_handler()后,error_reporting()将会失效。也就是所有错误都是由自定义的函数处理。
1.4 使用trigger_error()函数来替代die( )
die():首先函数die()等同于exit(),两者如果执行都会终止PHP程序,而且可以在退出程序之前输出一些错误报告。trigger_error()则可以生成一个用户警告来代替,使程序更具有灵活性。
例如,trigger_error(“没有找到文件”,E_USER_ERROR)。使用trigger_error()函数来替代die(),你的代码在处理错误上会更具优势,对于客户程序员来说更容易处理错误。
1.5 自定义错误处理
自定义错误报告的处理方式,可以完全绕过标准的PHP错误处理函数,这样就可以按自己定义的格式打印错误报告,或改变错误报告打印的位置,以下几种情况可以考虑自定义错误处理。
可以记下错误的信息,及时发现一些生产环境出现的问题
可以屏蔽错误。
可以控制错误的输出。
可以作为调试工具。
使用set_error_handler()函数来设置用户自定义错误处理。
1.6 写错误日志
两种方式记录错误日志:
1>使用指定的文件记录错误报告日志
使用指定的文件记录错误报告日志:
1、先配置php.ini:
error_reporting = E_ALL//将向PHP发送每个错误
display_errors=Off//不显示错误报告
log_errors=On//决定日志语句记录的位置
log_errors_max_len=1024// 每个日志项的最大长度
error_log=“G:/myerror.log”//指定错误写进的文件
Error_log = syslog
2、使用函数:在php文件中使用error_log()来记录日志,就可以将信息写入到myerror.log文件中
如:error_log("登录失败了!");
实例:
<?php
if(!ora_logon($username, $password)){
//将错误消息写入到操作系统日志中
error_log("Oracle数据库不可用!", 0);
}
if(!($foo=allocate_new_foo()){
//发送到管理员邮箱中
error_log("出现大麻烦了!", 1, "webmaster@www.mydomain.com");
}
//发送到本机对应5000端口的服务器中
error_log("搞砸了!", 2, "localhost:5000");
//发送到指定的文件中
error_log("搞砸了!", 3, "/usr/local/errors.log");
?>
2>错误日志记录到操作系统的日志里
1、先配置PHP.ini文件中
error_reporting = E_ALL//将向PHP发送每个错误
display_errors=Off//不显示错误报告
log_errors=On//决定日志语句记录的位置。
log_errors_max_log=1024// 每个日志项的最大长度
error_log=syslog//指定到系统日志中。
2、使用四个函数来记录日志:
define_syslog_variables();//为系统日志初始化配置
openlog(); //打开一个日志链接
syslog(); //发送一条日志记录
closelog(); //关闭日志链接
查看操作系统日志:
如windows系统,通过右击“计算机管理”-> 系统工具->在系统工具菜单中选择事件查看器->widows日志->在应用程序选项中即可看到日志了。
阅读全文
0 0
- php一些常见的错误以及处理方式
- 新手学习C语言常见几个错误以及处理方式
- sharepoint 开发常见错误的处理方式
- 编程中常见的错误处理方式
- PHP开发中常见的一些错误
- JBOSS常见错误以及一些部署错误的收集
- PHP错误处理方式
- php常见错误以及解决方案
- Goldengate常见错误处理方式
- CocoaPods 的安装以及一些常见安装错误解决办法
- Ubuntu的apt-get命令以及一些常见错误
- 一些常见的问题错误及解决方式
- android webview 使用以及一些常见的异常处理
- android webview 使用以及一些常见的异常处理
- MySQL主从复制以及常见的一些问题处理
- 如何配置java环境以及常见的一些问题处理
- strut2 demo 示例 以及常见的错误处理
- 【转载】DirectShow 一些常见编译错误的处理
- caffe训练时loss=nan的原因
- C#使用Object类实现栈的方法详解
- Lines_gauss——检测图像中的线条及其宽度,在视觉表面检测方面应用广泛。
- java并发编程的一些总结
- Glide 4.0源码分析(3)
- php一些常见的错误以及处理方式
- 存储过程和函数具体的区别
- 2017.8.31开学第一周周中训练总结
- test
- 轮播图*3
- dns-prefetch性能优化
- 前端性能优化之图片优化方法
- DIV在100%下iframe宽度高度的自适应的问题
- 洛谷 P1074 靶形数独