在我的应用程序日志文件中编写PHP日志

时间:2012-10-04 21:18:46

标签: php logging error-handling

我正在开发一个php应用程序,我已经为它创建了日志记录功能。我的意思是每次出现问题我都会在日志文件中写入错误,因此如果用户报告错误,我可以使用我的日志文件来追踪该错误。

问题是如果我在生产服务器上传我的项目,我必须禁用PHP的默认错误显示;我只想在我自己的日志文件中记录php错误以及webserver的'error.log'。有什么办法让我能做到吗?

3 个答案:

答案 0 :(得分:3)

您可以使用自定义错误处理程序在php中进行自己的日志记录。这也允许您登录数据库(假设错误与数据库无关,并且您具有有效连接)或基于错误的平面文件以及设置自定义错误页面。见:

http://www.php.net/manual/en/function.set-error-handler.php

答案 1 :(得分:2)

对于特色的可用异常(我称之为全功能可用异常,(没有堆栈跟踪)):

如果您是开发人员,请设置:

   define('EXCEPTION_HANDLER_ACTIVE', true);

在生产中,这也应该是真的,但修改了代码以不向最终用户显示错误。 (使用:error_reporting(0); ini_set('display_errors', false)在页面顶部));

首先设置处理异常的主要功能:

set_error_handler("_handler_exception");

调用异常处理程序的函数:

function _handler_exception($err_severity, $err_msg, $err_filepath, $err_line)
    {
        if (EXCEPTION_HANDLER_ACTIVE == 1)
        {
            $eh = new exceptionhandler;

            $eh->exception_active = true;
            $eh->set_exception_handler_log($err_severity, $err_msg, $err_filepath, $err_line);
        }
        else
        {
            $eh = new exceptionhandler;

            $eh->exception_active = false;
            $eh->set_exception_handler_log($err_severity, $err_msg, $err_filepath, $err_line);
        }
    }

类异常处理程序:

class exceptionhandler
{
    public $exception_active = true;

   public function set_exception_handler_log($err_severity, $err_msg, $err_filepath, $err_line)
    {        
    $ret_err_severity = NULL;
    $ret_err_no = NULL;
    $ret_info = NULL;
    $filenameerr = NULL;
    $dbout = NULL;

    switch ($err_severity)
    {
        case E_ERROR:
            $ret_err_severity = "E_ERROR"." [ ".$err_severity." ]";
            $ret_err_no = "1";
            $ret_info = "Fatal run-time errors. These indicate errors that can not be recovered from, such as a memory allocation problem. Execution of the script is halted.";
            $ret_err_msg = $err_msg;
            break;

        case E_STRICT:
            $ret_err_severity = "E_STRICT"." [ ".$err_severity." ]";
            $ret_err_no = "2048";
            $ret_info = "Enable to have PHP suggest changes to your code which will ensure the best interoperability and forward compatibility of your code. ";
            $ret_err_msg = $err_msg;
            break;
        default:
            $ret_err_severity = "CODE"." [ ".$err_severity." ]";
            $ret_err_no = $err_severity;
            $ret_info = "Other error";
            $ret_err_msg = $err_msg;
            break;
    }

    $ef = explode("/", $err_filepath);
    $ec = (count($ef) - 1);
    $filenameerr = $ef[$ec];

    $backtrace = debug_backtrace();

    if (!isset($doc_root)) {
        $doc_root = str_replace('\\', '/', $_SERVER['DOCUMENT_ROOT']);
    }

    $debug_backtrace_parse = print_r(debug_backtrace(), true);
    $debug_backtrace2 = str_replace($err_msg, '<b>'.$err_msg.'</b>', $debug_backtrace_parse);
    $debug_backtrace = str_replace($err_filepath, '<b>'.$err_filepath.'</b>', $debug_backtrace2);

    $line = (isset($backtrace[1]['line'])) ? htmlspecialchars($backtrace[1]['line']) : '';
    $file = (isset($backtrace[1]['file'])) ? htmlspecialchars(str_replace(array('\\', $doc_root), array('/', ''), $backtrace[1]['file'])) : '';
    $class = !empty($backtrace[2]['class']) ? htmlspecialchars($backtrace[2]['class']) . '::' : '';
    $function = !empty($backtrace[2]['function']) ? htmlspecialchars($backtrace[2]['function']) . '() ' : '';
    $dbout = "<pre>$class$function =&gt;$file #$line</b><pre>";

    $memory = memory_get_usage()/1024/1024;

    if ($this->exception_active == true)
    {
        $source_highlight = $this->source_highlight($file, $backtrace);

        ob_start();
        include_once(exception.tpl);
        $buffer = ob_get_contents();
        ob_end_clean();
        echo $buffer;
        exit(-1);
    }
    }

Exception.tpl

<html>
    <head>
    <title><?php echo $ret_err_severity; ?> | <?php echo $filenameerr; ?></title>
    <style type="text/css">
        div#errorhandlerexception
        {
            border: 1px solid #ff0000;
            background-color: #ff9999;
            width: 96%;
            padding: 10px;
            color: #000;
            font-family: sans-serif;
            font-size: 10px;
            margin: 0 auto;
        }
        div#errorhandlerexception h2
        {
            border-bottom: 1px solid #fff;
            color: #ffffff;
        }
        div#errorhandlerexception td
        {
            background-color: #ffcccc;
            width: 100%;
            padding: 3px;
        }
        div#errorhandlerexception .main
        {
            width: 100px;
            height: 30px;
        }
        div#errorhandlerexception
        {
            margin-bottom: 40px;
        }
        .linenum
        {
            text-align:right;
            background:#FDECE1;
            border:1px solid #cc6666;
            padding:0px 1px 0px 9px;
            float:left;
            width:25px;
            margin:3px 0px 30px 0px;
            font-family: Courier New, Courier;
            font-size: 11px;
        }
        .code
        {
            font-family:Courier New, Courier;
            font-size: 11px;
            float: left;
            width: 100%;
        }
        .linetext
        {
            width:95%;
            text-align:left;
            background: #fff;
            border: 1px solid #cc6666;
            border-left:0px;
            padding:0px 1px 0px 8px;
            font-family: Courier New, Courier;
            float:left;
            margin:3px 0px 30px 0px;
            font-size: 11px;
        }
        br.clear
        {
            font-family:Courier New, Courier;
            clear:both;
            font-size: 11px;
        }
        #exception_selected_block
        {
            background-color: #ffff00;
        }
        div.exception_filename
        {
            border-left: 19px solid #AA7777;
            border-top: 3px solid #AA7777;
            color: #000000;
            float: left;
            font-weight: bold;
            padding: 6px;
            width: 98%;
        }
    </style>
    </head>

<body>
<div id="errorhandlerexception"><?php #echo $msg; ?>
<h2>EXCEPTION ERROR HANDLER</h2>
<table>
    <tr><td class="main">Status:</td><td><?php echo $ret_err_severity; echo " #".$err_severity; ?></td></tr>
    <tr><td class="main">Debug stack:</td><td><?php echo $dbout; ?></td></tr>
    <tr><td class="main">Code:</td><td><?php echo $ret_err_no; ?></td></tr>
    <tr><td class="main">Message:</td><td><?php echo $ret_err_msg; ?></td></tr>
    <tr><td class="main">Info:</td><td><?php echo $ret_info; ?></td></tr>
    <tr><td class="main">File:</td><td><?php echo $filenameerr; ?><br><?php echo $err_filepath; ?></td></tr>
    <tr><td class="main">Line:</td><td><?php echo $err_line; ?></td></tr>
    <tr><td class="main" colspan="2"><?php echo $source_highlight; ?></td></tr>
    <tr><td class="main">Debug backtrace:</td><td><pre><?php echo $debug_backtrace; ?></pre></td></tr>
</table>
</div>
</body>
</html>

答案 2 :(得分:1)

你可以使用set_error_handler来定义你自己的函数,如果发生错误就会调用它。

<?php
//error handler function
function customError($errno, $errstr, $errfile, $errline)
  {
  echo "<b>Custom error:</b> [$errno] $errstr<br />";
  echo " Error on line $errline in $errfile<br />";
  echo "Ending Script";
  die();

//set error handler
set_error_handler("customError");

$test=2;

//trigger error
if ($test>1)
  {
  trigger_error("A custom error has been triggered");
  }
?> 

参考:http://www.w3schools.com/php/func_error_set_error_handler.asp