Home  >  Article  >  Backend Development  >  How to implement debug_backtrace method tracking code calls through php

How to implement debug_backtrace method tracking code calls through php

jacklove
jackloveOriginal
2018-06-08 15:54:171475browse

During the development process, for example, if you want to modify the code developed by others or debug the problematic code, you need to track the code process step by step, find the problematic areas, and make modifications. If there is a method that can get which method a certain piece of code is called, and can go back to the place where it was first called (including the file called, the number of lines, parameters, etc.), it will be easy to locate the problem. place.

php's debug_backtrace method can trace code calls to facilitate debugging the code.

debug_backtrace method description

Generate a backtrace (backtrace)

array debug_backtrace ([ int $options = DEBUG_BACKTRACE_PROVIDE_OBJECT [, int $limit = 0 ]] )

Parameters

options

##DEBUG_BACKTRACE_PROVIDE_OBJECT

Whether to fill the index of "object".

DEBUG_BACKTRACE_IGNORE_ARGS

Whether to ignore the index of "args", including all function/method parameters, can save memory overhead.

limit This parameter can be used to limit the number of stack frames returned. The default is (limit=0), and all stack frames are returned.


Return value

Returns an array containing many associative arrays. Possible returned elements:

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

Instance

To obtain the user information and user information of the order, the calling process is index->order->user->message, and finally returns the sorted information.

Suppose we find that the data of the message is incorrect during debugging, we can use the debug_backtrace method on the message to view the calling process and the parameters of the call, and check which step has the problem.

Use

DEBUG_BACKTRACE_IGNORE_ARGS will ignore args (parameters of method call)

index.php

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

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;

    }

}?>

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;

    }

}?>


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;

    }

}?>

Run index.php, output

/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

, you can see that the calling process is

1.index. php

line 8
class Order
function get_order
args int 1000000

2.order.php

line 14
class User
function get_user
args int 1001

3.user.php

line 12
class Message
function get_message
args int 1001

This article explains the implementation through php The debug_backtrace method tracks code calls. For more related content, please pay attention to the PHP Chinese website.

Related recommendations:

Explain the causes and solutions to the Warning: A non-numeric value encountered problem in php

How to use mysql to execute sql on the terminal and write the results to a file

How to compare the table structures of two databases through mysql


The above is the detailed content of How to implement debug_backtrace method tracking code calls through php. For more information, please follow other related articles on the PHP Chinese website!

Statement:
The content of this article is voluntarily contributed by netizens, and the copyright belongs to the original author. This site does not assume corresponding legal responsibility. If you find any content suspected of plagiarism or infringement, please contact admin@php.cn