维护一个项目,该项目必须通过 PHP 4.X 到 5.2 兼容。该项目作为几个错误没有得到很好的处理。
我想做的是将用户重定向到一个"不错"的错误页面,并将错误记录在数据库中。为了跟踪用户、文件和错误消息。这是我到目前为止尝试过的:
set_error_handler("myErrorHandler");
/**
*My function to handle errors
*/
function myErrorHandler( $errno , $errstr , $errfile="nofile" , $errline=0 , $errcontextArray=NULL ){
session_start();
if (!isset($errno)|!isset($errstr)) {
exit(0);
}
if (!mysql_ping()) {
require '../Connection/databaseinfo.php';
}
$id_user = $_SESSION['ident'];
$errstr = GetSQLValueString($errstr, "text");
$errfile = GetSQLValueString($errfile, "text");
$errline = GetSQLValueString($errline, "int");
$sql = "insert into error_history
(id_user, message, file, line)
values ($id_user, $errstr, $errfile, $errline)";
mysql_query($sql) or die (mysql_error());
// header("location:error.php"); ---> I can't (see comment below)
echo "<script type='text/javascript'> window.location.href='error.php';</script>";//Redirection dégueulasse //TODO: trouver mieux
return true;
}
为什么不header()
?因为错误可以在页面中的任何位置触发,因此标头已经发送。
为什么不和obstart(), ob_flush()
一起header()
呢?因为有很多页面已经在生产中,我无法全部修改它们。
我的问题是:
- 我做错了吗?
- 有没有更好的方法来处理重定向?
这是在 php 5.2 中处理致命错误的方法:
<?php
register_shutdown_function('shutdownFunction');
function shutDownFunction() {
$error = error_get_last();
if($error['type'] >= 1){
mail('cc@cc.de', 'Error: XY',"Error msg:"."Server Error:".implode("'n", $error));
}
}
?>