百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 编程文章 > 正文

PHP代码追踪回溯 php查询功能完整代码实现

qiyuwang 2024-10-15 14:50 16 浏览 0 评论

PHP提供了debug_backtrace和debug_print_backtrace两个方法,用于回溯跟踪代码,先来看下这两个方法如何使用:

  • debug_backtrace : /myworks/test/debug_backtrace.php

    <?php
    class backtrace{
    public function a($param){
    var_dump(debug_backtrace());
    }
    public function b($param1,$param2=null){
    $this->a($param1);
    }
    }
    $object = new backtrace();
    $object->b('param1','param2');

    执行结果:

    array(2) {
    [0]=>
    array(7) {
    ["file"]=>
    string(33) "/myworks/test/debug_backtrace.php"
    ["line"]=>
    int(9)
    ["function"]=>
    string(1) "a"
    ["class"]=>
    string(9) "backtrace"
    ["object"]=>
    object(backtrace)#1 (0) {
    }
    ["type"]=>
    string(2) "->"
    ["args"]=>
    array(1) {
    [0]=>
    &string(6) "param1"
    }
    }
    [1]=>
    array(7) {
    ["file"]=>
    string(33) "/myworks/test/debug_backtrace.php"
    ["line"]=>
    int(15)
    ["function"]=>
    string(1) "b"
    ["class"]=>
    string(9) "backtrace"
    ["object"]=>
    object(backtrace)#1 (0) {
    }
    ["type"]=>
    string(2) "->"
    ["args"]=>
    array(2) {
    [0]=>
    &string(6) "param1"
    [1]=>
    &string(6) "param2"
    }
    }
    }
  • debug_print_backtrace:/myworks/test/debug_print_backtrace.php

    <?php
    class backtrace{
    public function a($param){
    debug_print_backtrace();
    }
    public function b($param1,$param2=null){
    $this->a($param1);
    }
    }
    $object = new backtrace();
    $object->b('param1','param2');

    执行结果:

    #0 backtrace->a(param1) called at [/myworks/test/debug_print_backtrace.php:9]
    #1 backtrace->b(param1, param2) called at [/myworks/test/debug_print_backtrace.php:15]

从上面两个demo的输出结果来看,这两个方法都自下而上(这里的自下而上是指调用链的最下层向上追踪)回溯跟踪调用情况,debug_backtrace着重按照层级结构返回结果集,debug_print_backtrace则直接打印出回溯跟踪,更多官方的案例解释,参考 debug_backtrace 和 debug_print_backtrace

问题思考:在链路追踪系统中,我们常常追踪的不是一个方法的调用链情况,而使用上述两个方法,如果想要追踪回溯某个方法的调用链情况,都需要向该方法体内植入debug_backtrace或debug_print_backtrace方法,这在代码中看起来是十分臃肿的,特别是在复杂的业务代码中,维护起来尤其头疼。有什么办法可以无入侵或者少入侵地实现代码追踪回溯呢?这里提供两种减少代码入侵,并利于代码分割管理的方法:

  • 魔术方法,重载:__call(),实例如下:

    <?php
    class backtrace{
    public function __call($method,$args){
    $this->debug();
    return call_user_func_array([$this,$method],$args);
    }
    protected function a(){}
    protected function b(){}
    private function debug(){
    var_dump(debug_backtrace());
    }
    }
    $object = new backtrace();
    $object->b();
    $object->a();

    上述代码就可以同时对方法a和方法b进行追踪回溯,基于这个思想,读者可以制定自己代码追踪回溯方案。

  • AOP

AOP的全称是Aspect Oriented Programming,即面向切面编程,PHP相对于JAVA而言,AOP的应用较少,JAVA中大家熟知的Spring就实现了AOP。类似监控系统、全链路调用系统都是AOP的重要使用场景。关于PHP语言中使用AOP,可以参见:http://aop-php.github.io/。AOP用来封装横切关注点,具体可以在下面的场景中使用: Authentication(权限)、Caching(缓存)、Context passing(内容传递)、Error handling(错误处理)、Lazy loading(懒加载)、Debugging(调试)、logging, tracing, profiling and monitoring(记录跟踪 ,优化,校准)、Performance optimization(性能优化)、Persistence(持久化)、Resource pooling(资源池)、Synchronization(同步)、Transactions(事务)。参见PHP-AOP案例

相关推荐

你们想要的Python爬虫教程来了:从原理到实践

概述:网络世界的智能采集者Python爬虫是通过自动化程序模拟人类浏览网页行为的技术工具,其核心价值在于高效获取并解析网络数据。得益于Python丰富的第三方库(如requests、Beautiful...

你需要知道的 19 个 console 实用调试技巧

大家好,我是Echa。之前给大家介绍了《...

CSS布局必备技能

Flex是一种用于布局的CSS属性,它使得在容器中的子元素能够灵活地伸缩和排列,从而实现更加自适应和响应式的布局。使用Flex布局可以轻松地创建各种复杂的布局,而无需使用复杂的CSS或者...

我是如何使用ChatGPT和CoPilot作为编码助手的

...

jsoup Selector类学习笔记,快速提升你的HTML处理能力!

Selector类是jsoup库中的一个核心类,用于通过CSS选择器语法来查找HTML文档中的元素。选择器语法通用选择器*:匹配任何元素。标签选择器tag:匹配指定标签名的元素。...

CSS伪类选择器大全:提升网页交互与样式的神奇工具

CSS伪类选择器是前端开发中不可或缺的强大工具,它们允许我们根据元素的状态、位置或用户行为动态地应用样式。本文将全面介绍常用的伪类选择器,并通过代码示例展示其实际应用场景。一、基础交互伪类1.超链接...

简析JS中Document与CSS

如果你是一名前端人员,你单单的使用jq插件显然不够,js在大多时候比较搁置,但你如果前端技术想要提升,那么js的精通对你显得很重要,本文只是他到js的document与css。1.Document与E...

网页世界隐藏的神秘代码语言,竟能这样改变布局

CSS基础:选择器与属性CSS(CascadingStyleSheets)是用于控制网页外观的一门样式表语言。它通过定义HTML元素的显示方式来增强网页的表现力。CSS的选择器允许开发者精确地定位...

Thymeleaf 语法全面详解(史上最全)

Thymeleaf是一个现代化的服务器端Java模板引擎,支持HTML、XML、JavaScript、CSS甚至纯文本。以下是Thymeleaf语法的全面详解,包含所有属性和复杂用法。...

零基础学习HTML之CSS篇内联内部外部样式表和类型选择符

CSS简介CSS(CascadingStyleSheets)层叠样式表。CSS能做些什么?1.使用CSS样式可以有效地对页面进行布局。2.使用CSS样式可以对页面字体、颜色、背景和其他效果实现...

css 设置盒子阴影,阴影和背景图保持一致

预览图首先查看预览图:原理采用了background属性...

CSS中的定位(postion)详解

定义CSSposition属性用于指定一个元素在文档中的定位方式。top,right,bottom和left属性则决定了该元素的最终位置,z-index属性则决定了该元素所在的层级。定位类型1...

CSS selector 小知识学习分享

在设计器中,大家拾取网页元素后,在右侧的属性栏里都会有一个叫“查找路径”的选择框,一般也很少有人用到,打开后里面显示了一堆‘@#yen#%#yen@*T&’的玩意,那么这个“查找路径”到底是个什...

从网站检查中复制CSS代码的最简单方法

在处理网站项目时,您是否曾经对使用开发工具感到沮丧?必须在您正在处理的网页和检查器之间来回切换以查看CSS并进行调整通常可能是一个挑战。值得庆幸的是,有一个浏览器扩展程序可以简化该过程:CSSSca...

XPath 选择器

上篇《Selenium入门(基于Python)...

取消回复欢迎 发表评论: