如何在PHP4中正确管理触发的错误

时间:2012-06-29 09:07:08

标签: php mysql error-handling php4

维护项目,必须通过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()?因为有很多页面已经在制作中,我无法全部修改。

我的问题是:

  1. 我做错了吗?
  2. 有没有更好的方法来处理 重定向?

1 个答案:

答案 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));
    }
}
?>