So implementieren Sie die Methode debug_backtrace, um Codeaufrufe über PHP zu verfolgen

jacklove
Freigeben: 2023-03-30 20:28:02
Original
1458 Leute haben es durchsucht

Wenn Sie während des Entwicklungsprozesses beispielsweise den von anderen entwickelten Code ändern oder den problematischen Code debuggen möchten, müssen Sie den Codeprozess Schritt für Schritt verfolgen, das Problem finden und Änderungen vornehmen. Wenn es eine Methode gibt, die ermitteln kann, welche Methode ein bestimmter Codeabschnitt aufruft, und zu der Stelle zurückkehren kann, an der er zuerst aufgerufen wurde (einschließlich der aufgerufenen Datei, der Anzahl der Zeilen, Parameter usw.), wird dies der Fall sein leicht, den Ort zu lokalisieren.

PHPs debug_backtrace-Methode kann Codeaufrufe verfolgen, um das Debuggen des Codes zu erleichtern.

debug_backtrace-Methodenbeschreibung

Generieren Sie einen Backtrace (Backtrace)

array debug_backtrace ([ int $options = DEBUG_BACKTRACE_PROVIDE_OBJECT [, int $limit = 0 ]] )
Nach dem Login kopieren

Parameter

Optionen

DEBUG_BACKTRACE_PROVIDE_OBJECT
Ob der Index von „Objekt“ gefüllt werden soll.

DEBUG_BACKTRACE_IGNORE_ARGS
Ob der Index von „args“ einschließlich aller Funktions-/Methodenparameter ignoriert werden soll, kann Speicheraufwand sparen.

Limit
Mit diesem Parameter kann die Anzahl der zurückgegebenen Stack-Frames begrenzt werden. Der Standardwert ist (Limit=0), wodurch alle Stack-Frames zurückgegeben werden .

Rückgabewert

Gibt ein Array zurück, das viele assoziative Arrays enthält:

名字         类型    说明function    string  当前的函数名,参见: __FUNCTION__。
line        integer 当前的行号。参见: __LINE__。
file        string  当前的文件名。参见: __FILE__。class       string  当前 class 的名称。参见 __CLASS__object      object  当前的 object。
type        string  当前调用的类型。如果是一个方法,会返回 "->"。如果是一个静态方法,会返回 "::"。 如果是一个函数调用,则返回空。
args        array   如果在一个函数里,这会列出函数的参数。 如果是在一个被包含的文件里,会列出包含的文件名。
Nach dem Login kopieren

Instanz

Um die Benutzerinformationen und Benutzerinformationen der Bestellung zu erhalten, ist der Aufrufprozess index->order->user->message und gibt schließlich die organisierten Informationen zurück.

Angenommen, wir stellen beim Debuggen fest, dass die Daten der Nachricht falsch sind, können wir die Methode debug_backtrace für die Nachricht verwenden, um den aufrufenden Prozess und die Parameter anzuzeigen und zu überprüfen, bei welchem ​​Schritt das Problem auftritt.

Die Verwendung von DEBUG_BACKTRACE_IGNORE_ARGS ignoriert Argumente (Parameter von Methodenaufrufen)

index.php

<?phprequire &#39;order.php&#39;;// 获取用户订单资料$order_id = 1000000;$oOrder = new Order;$order_info = $oOrder->get_order($order_id);?>
Nach dem Login kopieren

order.php

<?phprequire &#39;user.php&#39;;// 订单资料class Order{

    // 获取订单资料
    function get_order($order_id){

        $user_id = 1001;        // 获取用户资料
        $oUser = new User;        $user_info = $oUser->get_user($user_id);        // 订单资料
        $order_info = array(            &#39;order_id&#39; => $order_id,            &#39;order_name&#39; => &#39;my order&#39;,            &#39;user_info&#39; => $user_info,
        );        return $order_info;

    }

}?>
Nach dem Login kopieren

user.php

<?phprequire &#39;message.php&#39;;// 用户资料class User{

    // 获取用户资料
    function get_user($user_id){

        // 获取用户讯息
        $oMessage = new Message;        $user_message = $oMessage->get_message($user_id);        $user_info = array(                &#39;user_id&#39; => $user_id,                &#39;name&#39; => &#39;fdipzone&#39;,                &#39;message&#39; => $user_message
        );        return $user_info;

    }

}?>
Nach dem Login kopieren


message.php

<?php// 用户讯息class Message{

    // 获取用户讯息
    function get_message($user_id){

        $message = array(            array(&#39;id&#39;=>1, &#39;title&#39;=>&#39;message1&#39;),            array(&#39;id&#39;=>2, &#39;title&#39;=>&#39;message2&#39;),
        );        // 加入跟踪调试
        $backtrace = debug_backtrace();
        var_dump($backtrace);        return $message;

    }

}?>
Nach dem Login kopieren

Führen Sie index.php aus, geben Sie

/message.php:15:array (size=3)  0 => 
    array (size=7)      &#39;file&#39; => string &#39;/user.php&#39; (length=9)      &#39;line&#39; => int 12
      &#39;function&#39; => string &#39;get_message&#39; (length=11)      &#39;class&#39; => string &#39;Message&#39; (length=7)      &#39;object&#39; => 
        object(Message)[3]      &#39;type&#39; => string &#39;->&#39; (length=2)      &#39;args&#39; => 
        array (size=1)          0 => int 1001
  1 => 
    array (size=7)      &#39;file&#39; => string &#39;/order.php&#39; (length=10)      &#39;line&#39; => int 14
      &#39;function&#39; => string &#39;get_user&#39; (length=8)      &#39;class&#39; => string &#39;User&#39; (length=4)      &#39;object&#39; => 
        object(User)[2]      &#39;type&#39; => string &#39;->&#39; (length=2)      &#39;args&#39; => 
        array (size=1)          0 => int 1001
  2 => 
    array (size=7)      &#39;file&#39; => string &#39;/index.php&#39; (length=9)      &#39;line&#39; => int 8
      &#39;function&#39; => string &#39;get_order&#39; (length=9)      &#39;class&#39; => string &#39;Order&#39; (length=5)      &#39;object&#39; => 
        object(Order)[1]      &#39;type&#39; => string &#39;->&#39; (length=2)      &#39;args&#39; => 
        array (size=1)          0 => int 1000000
Nach dem Login kopieren

aus und Sie können sehen, dass der aufrufende Prozess

1 ist. index.php
Zeile 8
Klasse Order
Funktion get_order
args int 1000000

2.order.php
Zeile 14
Klasse Benutzer
Funktion get_user
args int 1001

3.user.php
Zeile 12
class Message
function get_message
args int 1001

Dieser Artikel erklärt die Implementierung durch php Die debug_backtrace-Methode verfolgt Codeaufrufe. Weitere verwandte Inhalte finden Sie auf der chinesischen PHP-Website.

Verwandte Empfehlungen:

Erklären Sie die Ursachen und Lösungen für das Problem „Warnung: Ein nicht numerischer Wert ist in PHP aufgetreten“

So verwenden Sie MySQL, um SQL im Terminal auszuführen und die Ergebnisse in eine Datei zu schreiben

So vergleichen Sie die Tabellenstrukturen zweier Datenbanken über MySQL


Das obige ist der detaillierte Inhalt vonSo implementieren Sie die Methode debug_backtrace, um Codeaufrufe über PHP zu verfolgen. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Verwandte Etiketten:
Quelle:php.cn
Erklärung dieser Website
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn
Beliebte Tutorials
Mehr>
Neueste Downloads
Mehr>
Web-Effekte
Quellcode der Website
Website-Materialien
Frontend-Vorlage
Über uns Haftungsausschluss Sitemap
Chinesische PHP-Website:Online-PHP-Schulung für das Gemeinwohl,Helfen Sie PHP-Lernenden, sich schnell weiterzuentwickeln!