维护项目,必须通过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()
?因为错误可以在页面的任何地方触发,因此已经发送了标题。
为什么不header()
和obstart(), ob_flush()
?因为有很多页面已经在制作中,我无法全部修改。
我的问题是:
答案 0 :(得分:0)
这是如何处理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));
}
}
?>