zoukankan      html  css  js  c++  java
  • php调试工具之firePHP

    让PHP可以像js一样利用浏览器的控制台调试代码  ------- FirePHP

    1. 安装FirePHP插件

      在Chrome浏览器的应用商店中,搜索firephp关键词,在出来的插件列表中,选择第一个,将它添加到Chrome即可

    2. 获取FirePHP类库

      仅仅安装好FirePHP浏览器端的插件是不够的,我们还需要安装它的服务端,FirePHP类库下载地址:http://www.firephp.org

     

      下载对应语言版本的类库文件, 下载完成后,将压缩包中的fb.php和FirePHP.class.php两个文件,拷贝到我们的项目中

       在项目中引入 即可使用

    3. 使用

      示例:

    复制代码
    <?php
    
    namespace CommonLibUtil;
    
    if (!class_exists('FB')) {
    
        vendor('FirePHP.fb');
    
    }
    
    
    
    class FireBug {
    
        /**
    
        * 将php调试信息打印到控制台
    
        * @param mixes $object : 待输出的数据,类型可以是字符串、数组或者对象
    
        * @param string $label : 标题
    
        * @param boolean $showTrace : 是否显示调用跟踪信息
    
        */
    
        public static function console($object, $label=null, $showTrace=false)
        {
            //开发与生产模式的开关标识,我们只在开发模式下调试脚本
            if (!DEBUG_PHP) {
                return;
            }
    
            try {
                $label = $label ? $label : time();
                FB::log($object,$label);
                if (is_array($object) || is_object($object)) {
                    $headers = array_keys(reset($object));
                    if (is_array($headers)) {
                        array_unshift($object,$headers);
                        FB::table($label,$object);
                    }else{
                        FB::table($label,array(array_keys($object),$object));
                    }
    
                }else if(is_object($object)){
                    FB::table($label,$object);
                }
    
                if ($showTrace) {
                    FB::trace($label);
                }
    
            } catch (Exception $e) {
                echo '请开启输出缓冲函数ob_start()';
            }
    
        }
    
    }
    复制代码

       

    复制代码
    fb('Hello World');
            fb('log message', FirePHP::LOG);
            fb('Info message' ,FirePHP::INFO);
            fb('Warn message' ,FirePHP::WARN);
            fb('Error message',FirePHP::ERROR);
    
    
            fb('Message with label','Label',FirePHP::LOG);
    
            fb(array('key1'=>'val1',
                'key2'=>array(array('v1','v2'),'v3')),
                'TestArray',FirePHP::LOG);
    
            fb('Backtrace to here',FirePHP::TRACE);
    
            fb(array('2 SQL queries took 0.06 seconds',array(
               array('SQL Statement','Time','Result'),
               array('SELECT * FROM Foo','0.02',array('row1','row2')),
               array('SELECT * FROM Bar','0.04',array('row1','row2'))
              )),FirePHP::TABLE);
    
            /* Will show only in "Server" tab for the request */
            fb(apache_request_headers(),'RequestHeaders',FirePHP::DUMP);
    复制代码

    效果展示:

      

    是不是非常方便,通过FirePHP,我们就不需要把调试信息用echo,print_r或者日志的形式输出了

  • 相关阅读:
    setlocale set the current locale
    测试一个目录下的文件共有多少行
    ping中用到的校验和算法
    atomic integer operations P176
    我要理解1为什么是0xffffffff,所以写了下面的程序理解。
    贝叶斯网络中一个节点的类
    bash 的浮点除法
    shell(1)
    AndroidBroadcast详解与汇总
    AndroidActivity详解与汇总
  • 原文地址:https://www.cnblogs.com/xiamibk/p/12931379.html
Copyright © 2011-2022 走看看