php错误处理以及php的异常处理机制2014-10-18php错误处理当我们开发程序时,有时候程序出现了问题,我们就可以用以下几种办法找出错误。开发阶段:开发时输出所有的错误报告,有利于我们进行程序调试运行阶段:我们不要让程序输出任何一种错误报告(不能让用户看到(包括懂技术, 不懂技术的人))将错误报告写入日志中一、指定错误报告 error_reporting = E_LL二、关闭错误输出 display_errors = Off三、开启错误日志功能 log_errors = On1. 默认如果不指定错误日志位置,则默认写WEB服务器的日志中2. 为error_log选项指定 一个文件名(可写)3. 写入到操作系统日志中error_log=syslog以下代码示例
<span style="font-family:SimSun;font-size:14px;"><?php//error_reporting(E_ALL);/// ini_set("display_errors", "off");//ini_set("error_log", "syslog");//ini_set("MAX_FILEUPLOAD", 200000000);//echo ini_get("upload_max_filesize");//error_log("this is a error message!!!!");getType($var); //注意getType();//警告getTye();//错误会终止程序运行echo "###########################<br>"; ?></span>
当然php还提供了函数error_get_last()来获得错误信息函数定义和用法error_get_last()函数获取最后发生的错误。该函数以数组的形式返回最后发生的错误。返回的数组包含 4 个键和值:[type] - 错误类型[message] - 错误消息[file] - 发生错误所在的文件[line] - 发生错误所在的小例子:
<span style="font-family:SimSun;font-size:14px;"><?php echo $test; print_r(error_get_last()); ?>输出:Array ( [type] => 8 [message] => Undefined variable: test [file] => D:www est.php [line] => 2 )</span>
php5.4以后也提供了PHP预定义变量$php_errormsg$php_errormsg — 前一个错误信息$php_errormsg 变量包含由 PHP 生成的最新错误信息。这个变量只在错误发生的作用域内可用,并且要求track_errors 配置项是开启的(默认是关闭的)。例子:
<?php@strpos();echo $php_errormsg;?>
会输出:Wrong parameter count for strpos()所以这样我们也很方便了。。。这样是不是对调试程序和排查错误的时候很有帮助呢?URL:http://www.bianceng.cn/webkf/PHP/201410/45958.htm这些错误报告级别是错误处理程序旨在处理的错误的不同的类型: