0

エラーをバックトレースする次のコードがあります....しかし、その

$traces = debug_backtrace();

foreach ($traces as $k => $v)
{
    if ($v['function'] == 'include' 
        || $v['function'] == 'include_once' 
        || $v['function'] == 'require_once' 
        || $v['function'] == 'require')
    {
        $args = ''; 
        if (isset($v['args']) && is_array($v['args']))
        {
            $size = count($v['args']);
            foreach ($v['args'] as $key => $arg)
            {
                $args .= $v['args'][$key];
                if($key < $size)
                {
                    $args .= ', ';
                }
            }
        }

        $traces .= '#' . $k . ' ' 
                 . $v['function']
                 . '('.$args.') called at ['
                 . $v['file'].':'.$v['line'].']';
    }
    else
    {
        $function = (array_key_exists('function',$v)) ? 
                        $v['function'].'() ' : 'function_name';
        $file     = (array_key_exists('file',$v)) ? 
                        $v['file'] : 'file_name';
        $line     = (array_key_exists('line',$v)) ? 
                        $v['line'] : 'line';
        $traces  .= "#{$k} $function called at {$file}:{$line}\n";//This line giving me notice...

    }


}

ここで配列から文字列への変換として通知を受けています:

$traces .= "#$k $function called at $file:$line\n";

私は実際にこの配列を文字列に変換したいと考えています。私に通知せずに変換を行うことができるメソッドまたは関数はありますか...

これを修正するにはどうすればよいですか?

4

3 に答える 3

1

あなたはから始めます:

foreach($traces as $k=>$v) <- $traces here is an array

それからあなたはやろうとします

$traces.= "xxx" <- $traces here is handled as a string

テキスト コンテンツを集約するために $tracestr 文字列を定義したいと思います。

于 2012-10-18T16:25:34.953 に答える
0

配列を正しく作成していません

 $args .= $v['args'][$key];

文字列を作成しています。

 $args = array(); 
                if(isset($v['args']) && is_array($v['args']))
                {
                    $size = count($v['args']);
                    foreach ($v['
                    args'] as $key => $arg)
                    {
                        array_push($args,$v['args'][$key]);
                       // some of your code
                }
于 2012-10-18T16:26:45.823 に答える
0
$trace = debug_backtrace();
foreach($traces as ...)

ここに何か問題があります。$traceはデバッグ バックトレース配列です。foreach($traces) ... これは未定義のようです。そして、それを foreach するために非スカラーであるはずの$tracesに追加します。

変数に適切な名前を付けて、名前を変えてください!

于 2012-10-18T16:27:33.900 に答える