2

m 维护一个项目,该项目必须通过 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. 有没有更好的方法来处理重定向?
4

1 回答 1

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));
    }
}
?>
于 2012-07-01T21:18:22.707 回答