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

      让PHP可以像js一样利用浏览器的控制台调试代码  ------- FirePHP(http://www.firephp.org/)

    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或者日志的形式输出了

  • 相关阅读:
    sklearn中禁止输出ConvergenceWarning:
    sklearn里训练集和测试集的分割
    sklearn模型的保存与加载使用
    django项目成功启动,但views里代码未执行
    使用sklearn对iris数据集做基本的训练和预测
    unrecognized option '--high-entropy-va'
    快速下载Mingw(不使用sourceforge.net)
    cc1.exe: sorry, unimplemented: 64-bit mode not compiled in
    GoLand里Go Module模式下import自定义包
    GoLand生成可执行文件(Windows、Linux)
  • 原文地址:https://www.cnblogs.com/xingxia/p/phptool_firephp.html
Copyright © 2011-2022 走看看