我们有一个监控客户网站性能的网站,我们使用商业智能wordpress插件来显示客户的性能。当一个新客户第一次登录并选择他的仪表板时,我们会得到以下错误,当我们在数据库中更新时,错误消失,但仪表板第一次应该显示自定义消息。
我正在使用以下SQL查询

select lastsamplestatus,lasterrorat,avguptimeday,status from
selenium_script_data as ssd inner join selenium_scripts as ss
on ss.script_id=ssd.selenium_id inner join wp_users as wu on
wu.ID=ss.customer_id where wu.ID={{{user_ID}

注意:未定义的变量:label_x in/home/sgulechha/alert.com/wp-content/plugins/wp-business-intelligence-lite/functions/functions.php,位于405行
注意:未定义的变量:data in/home/sgulechha/alert.com/wp-content/plugins/wp-business-intelligence-lite/functions/functions.php on line 417
警告:第417行/home/sgulechha/alert.com/wp-content/plugins/wp-business-intelligence-lite/functions/functions.php中为foreach()提供的参数无效
注意:尝试在第60行的/home/sgulechha/alert.com/wp-content/plugins/wp-business-intelligence-lite/resources/nvd3/wrappers/nvd3_linechart.php中获取非对象的属性
注意:未定义的变量:ds in/home/sgulechha/alert.com/wp-content/plugins/wp-business-intelligence-lite/resources/nvd3/wrappers/nvd3_linechart.php第154行
注意:尝试在第154行的/home/sgulechha/alert.com/wp-content/plugins/wp-business-intelligence-lite/resources/nvd3/wrappers/nvd3_linechart.php中获取非对象的属性
注意:未定义的变量:table in/home/sgulechha/alert.com/wp-content/plugins/wp-business-intelligence-lite/functions/functions.php第158行
注意:在第158行/home/sgulechha/alert.com/wp-content/plugins/wp-business-intelligence-lite/functions/functions.php中尝试获取非对象的属性
我们希望在管理员更新数据库之前为用户显示一条普通的自定义消息,我不知道在哪里可以自定义functions.php,我是从WordPress的商业智能插件中获得这个文件的。
我已经粘贴了下面的一部分代码,任何帮助将不胜感激。
//Assign values and labels
    switch($wpbi_chart->type){
        case chart::DONUT:
        case chart::PIE:                if(sizeof($label_x) > 0){
                                                    $wpbi_chart -> set_x_axis_labels($label_x,
                                                    $vo_chart->chart_x_labels_size,
                                                    $vo_chart->chart_x_labels_color);
                                                }
                                                foreach($data as $key => $value){
                                                //Overwrite data value for pie chart in order to show labels (via pie_value object)
                                                if(sizeof($label_x)>0){
                                                    for($idx = 0; $idx < sizeof($value); $idx++){
                                                        $value[$idx] = new pie_value($value[$idx], $label_x[$idx]);
                                                    }
                                                }
                                                $wpbi_chart -> set_tooltip($wpbi_dialog['charts']['pie']['tooltip']);
                                                $wpbi_chart -> create_element($key, $value);
                                                $wpbi_chart -> elements[$key] -> set_colours($wpbi_settings['pie-chart']['color-set']);
                                                }
                                                break;
        case chart::BAR_STACKED:        if(sizeof($label_x) > 0){
                                                $wpbi_chart -> set_x_axis_labels($label_x,
                                                    $_POST[$wpbi_settings['parameter']['ch-x-label-size']],
                                                    $_POST[$wpbi_settings['parameter']['ch-x-label-color']]);
                                                    $wpbi_chart->x_axis_istime = (sizeof($istime_cols) > 0);
                                                    if($wpbi_chart->x_axis_istime){
                                                        $wpbi_chart->x_axis_labels->labels = $wpbi_chart->convert_to_time($wpbi_chart->x_axis_labels->labels);
                                                    }
                                                }
                                                    $wpbi_chart-> set_y_axis_labels_color($_POST[$wpbi_settings['parameter']['ch-y-label-color']]);
                                                    $wpbi_chart-> set_y_axis_labels_size($_POST[$wpbi_settings['parameter']['ch-y-label-size']]);
                                                    foreach($data_stacked as $key => $value){
                                                        $wpbi_chart -> create_element('BAR_STACKED', $value);
                                                        $wpbi_chart -> elements['BAR_STACKED'] -> set_colours($stacked_label_color);
                                                    }
                                                    break;
        case chart::STACKED_AREA:
        case chart::LINE_AREA:      if(sizeof($label_x) > 0){
                                                    $wpbi_chart -> set_x_axis_labels($label_x,
                                                    $vo_chart->chart_x_labels_size,
                                                    $vo_chart->chart_x_labels_color);
                                                }
                                                $wpbi_chart-> set_y_axis_labels_color($vo_chart->chart_y_labels_color);
                                                $wpbi_chart-> set_y_axis_labels_size($vo_chart->chart_y_labels_size);
                                                foreach($data as $key => $value){
                                                    $wpbi_chart -> create_element($key, $value);
                                                    $wpbi_chart -> elements[$key] -> set_colour($label_color[$key]);
                                                    $wpbi_chart -> elements[$key] -> set_fill_colour($label_color[$key]);
                                                    $wpbi_chart -> elements[$key] -> set_fill_alpha( 0.5 );
                                                }
                                                break;
        case chart::RADAR:          if(sizeof($label_x) > 0){
                                                    $wpbi_chart -> set_y_axis_labels($label_x,
                                                    $vo_chart->chart_y_labels_size,
                                                    $vo_chart->chart_y_labels_color);
                                                }
                                                foreach($data as $key => $value){
                                                    $wpbi_chart -> create_element($key, $value);
                                                    $wpbi_chart -> elements[$key] -> set_colour($label_color[$key]);
                                                }
                                                break;
        case chart::BAR_HORIZONTAL: if(sizeof($label_x) > 0){
                                                    $wpbi_chart -> set_y_axis_labels($label_x,
                                                    $vo_chart->chart_y_labels_size,
                                                    $vo_chart->chart_y_labels_color);
                                                }
                                                $wpbi_chart-> set_x_axis_labels_color($vo_chart->chart_x_labels_color);
                                                $wpbi_chart-> set_x_axis_labels_size($vo_chart->chart_x_labels_size);
                                                foreach($data as $key => $value){
                                                    $wpbi_chart -> create_element($key, $value);
                                                    $wpbi_chart -> elements[$key] -> set_colour($label_color[$key]);
                                                }
                                                break;
        default:                                if(sizeof($label_x) > 0){
                                                    $wpbi_chart -> set_x_axis_labels($label_x,
                                                    $vo_chart->chart_x_labels_size,
                                                    $vo_chart->chart_x_labels_color, sizeof($istime_cols) > 0);
                                                    $wpbi_chart->x_axis_istime = (sizeof($istime_cols) > 0);
                                                    echo "welcome";
                                                } else {
                                                $wpbi_chart->set_x_axis_labels_color($vo_chart->chart_x_labels_color);
                                                $wpbi_chart->set_x_axis_labels_size($vo_chart->chart_x_labels_size);
                                                }
                                                $wpbi_chart-> set_y_axis_labels_color($vo_chart->chart_y_labels_color);
                                                $wpbi_chart-> set_y_axis_labels_size($vo_chart->chart_y_labels_size);
                                                foreach($data as $key => $value){
                                                    $wpbi_chart -> create_element($key, $value);
                                                    $wpbi_chart -> elements[$key] -> set_colour($label_color[$key]);
                                                }
                                                break;
    }

最佳答案

好的,朋友。别紧张。
你必须注意以下几点:
1-显示错误是因为您的错误报告设置为全部错误。如果按如下方式设置,则不会显示错误。

error_reporting(E_ALL ^ E_NOTICE ^ E_WARNING);

但是,它不能解决代码上的错误。只会把它藏起来。
2-当您看到“invalid argument supplied for foreach()”时,您的代码正试图遍历一个空变量。你需要去那个文件和行,做点什么,莉莉:
if ($yourVariable && count($yourVariable)>0)
   foreache($yourVariable as $yourValue){
   }

它将防止使用无效变量调用foreach。
3-当它在那行写着“试图获取非对象的属性”时,你就有了一个不是对象的变量。它可以是字符串,也可以是整数。或者别的…它只是不是一个物体。
查看所有错误,您可以看到数据变量是空的,然后所有错误都在之后发生,因为该代码总是与$data一起运行。尝试检查您的代码,以确保$data在开机前具有该值。

关于php - Wordpress - Business Intelligence Lite插件,我们在Stack Overflow上找到一个类似的问题:https://stackoverflow.com/questions/31739812/

10-15 12:20