web-dev-qa-db-ja.com

PHP キャッチ可能な致命的エラー:クラスWP_Errorのオブジェクトは文字列に変換できませんでした

私はこれで助けが必要です:

PHP Catchable fatal error:58行目の/hosting/www/ortopediairati.es/public/wp-content/themes/irati/rt-framework/functions/rt_breadcrumb.phpでクラスWP_Errorのオブジェクトを文字列に変換できませんでした

Wordpress 4.8にアップデートしましたが、ウェブがうまく機能していません。

完全なファイルはこちらです。

<?php

/* RT-Breadcrumb Function */
function rt_breadcrumb(){
global $taxonomy,$term_slug,$post,$delimiter;

if(!get_option('rttheme_breadcrumb_menus')){
    return false;
}

//Markup 
$before='<div class="breadcrumb">'.wpml_t(THEMESLUG, 'Breadcrumb Menu Text', get_option(THEMESLUG.'_breadcrumb_text')).' ';
$after='</div>';
$delimiter=' | ';

/*  WooCommerce Breadcrumb */ 
if ( function_exists( 'woocommerce_breadcrumb' ) ) {
    if( is_woocommerce() ){
        $defaults = array(
            'delimiter'  => $delimiter,
            'wrap_before'  => $before,
            'wrap_after' => $after,
            'before'   => '',
            'after'   => '',
            'home'    => null
        );

        woocommerce_breadcrumb($defaults); 
        return false;
    }
} 


echo $before;

//Home Page
echo "<a href=\"". BLOGURL ."\" title=\"". get_bloginfo('name')."\">".__( 'Home', 'rt_theme' )."</a>";

// page parents function
function page_parents($parent_page_id,$child_pages){
    global $delimiter;

    $parent_page = get_page($parent_page_id);
    $page_parents = $delimiter."<a href=\"".get_permalink($parent_page->ID)."\" title=\"". get_the_title($parent_page->ID) ."\" >". get_the_title($parent_page->ID) ."</a>" .$child_pages;

    if ($parent_page->post_parent) page_parents($parent_page->post_parent,$page_parents);

    else echo $page_parents;

}


// term parents function
function term_parents($term_id,$child_terms){
    global $taxonomy,$delimiter;

    $parent_term = get_term_by('ID',$term_id, $taxonomy);
    $term_parents = $delimiter."<a href=\"".get_term_link($parent_term->slug,$taxonomy)."\" title=\"". $parent_term->name ."\" >". $parent_term->name ."</a>" .$child_terms;

    if ($parent_term->parent) term_parents($parent_term -> parent,$term_parents);

    else echo $term_parents;

}

//get start page
function get_start_page($start_page){
    global $delimiter;

    //start page parents
    $get_start_page=get_page($start_page);
    if ($get_start_page -> post_parent){
        page_parents( $get_start_page -> post_parent,''); 
    }

    //start page
    if ($start_page && !get_query_var('lang')) {
        echo  $delimiter."<a href=\"".get_permalink($start_page)."\" title=\"". get_the_title($start_page) ."\" >". get_the_title($start_page) ."</a>";
    }
}

//terms
function term_links(){
    global $taxonomy,$post_type,$term_slug,$delimiter;

    //Find start page and define taxonomy names
    if($taxonomy=="product_categories"){
        $start_page=get_option('rttheme_product_list');
    }elseif($taxonomy=="portfolio_categories"){
        $start_page=get_option('rttheme_portf_page');
    }   

    //get start page
    if ($start_page) get_start_page($start_page);


    $term=get_term_by('slug',$term_slug, $taxonomy);

    //parent terms
    if (is_object($term) && $term -> parent){
        echo term_parents($term -> parent,'');   
    } 

    //current term
    if(is_object($term) && $term->slug) echo  $delimiter."<a href=\"".get_term_link($term->slug,$taxonomy)."\" title=\"". $term->name ."\" >". $term->name ."</a>";
}



//Pages
if ( is_page() ){
    //parent pages
    if ($post -> post_parent){
        page_parents( $post -> post_parent,''); 
    } 

    //current page
    echo  $delimiter ."". $post->post_title;
}

//Single
elseif (is_single() && !is_attachment()){ 
    // Get post type
    $post_type = get_post_type();

    //Taxonomies
    if($post_type == 'products' || $post_type == 'portfolio'){

        term_links();
        //current page
        echo  $delimiter."<a href=\"".get_permalink()."\" title=\"". get_the_title() ."\" >". get_the_title() ."</a>";

    }else{
    //Categories

    //start page
    $start_page=get_option('rttheme_blog_page');

    //get start page
    if ($start_page) get_start_page($start_page);

        $category_id = get_the_category();
        $category_id = $category_id[0]->cat_ID;//only one category can be show in the list  - the first one
        echo $delimiter;
        if($category_id){
            echo get_category_parents($category_id, TRUE, $delimiter, FALSE );
        }
        echo $post->post_title;
    }

//Category
}elseif (is_category()){
    //start page
    $start_page=get_option('rttheme_blog_page');

    //get start page
    if ($start_page) get_start_page($start_page);

        echo $delimiter."".get_category_parents(get_query_var('cat'), TRUE, $delimiter, FALSE);

//Taxonomy
}elseif (is_tax()){
    term_links();
} else {
    echo  $delimiter."";
    wp_title('');
}

echo $after;

wp_reset_query(); 
}
?>

誰かが私を手伝ってくれる?

3
Sergi

エラーが示す58行目は、この行です。

$parent_term = get_term_by('ID',$term_id, $taxonomy);
$term_parents = $delimiter."<a href=\"".get_term_link($parent_term->slug,$taxonomy)."\" title=\"". $parent_term->name ."\" >". $parent_term->name ."</a>" .$child_terms;

そして私達のエラーは:

クラスWP_Errorのオブジェクトを文字列に変換できませんでした

つまり、追加されているものの1つは"string"ではなく、実際にはWP_Errorオブジェクトです。

私はget_term_linkに疑念を投げかけるでしょう。それはおそらくエラーオブジェクトを返しているものです。

  • 用語が存在しません
  • 分類法が登録されていないか有効ではありません
  • 渡される値は予期せず空白です
  • $parent_termは用語ではなく、エラーオブジェクトです

それがここでの教訓につながります。

関数がエラーオブジェクトを返すことがあるので、それをチェックする必要があります。単に成功したと仮定しないでください

エラーをチェックする方法

いつも失敗する例を見てみましょう。

$value = get_term_link( "not a real term","fake taxonomy" );
if ( is_wp_error( $value ) ) {
    // something went wrong
}

is_wp_errorがエラーオブジェクトの場合、$valueはtrueになります。一部の関数はfalseまたはnullを返すことがあるので、!empty( $value )も便利なチェックです。

エラーオブジェクトにはエラーコードとメッセージを含めることができ、get_error_message()メソッドを使用してそれらを表示できます。

$value = get_term_link( "not a real term","fake taxonomy" );
if ( is_wp_error( $value ) ) {
    // something went wrong
    echo $value->get_error_message();
}

$valueを手動でデフォルト値に設定することもできます

グローバルに関する最後の注意

コードはグローバル変数を利用しますが、これらの変数は$taxonomyのようなスーパージェネリックな名前を持ちます。他のプラグインもこれらを使用するかもしれず、それらは衝突する可能性があります。関数名についても同じことが言えます。

良い

それらに接頭辞を付けます。

// term parents function
function sergi_term_parents( $term_id, $child_terms ) {
    global $sergi_taxonomy, $sergi_delimiter;

ベスト

依存性注入を使用し、グローバルを完全に排除します。

// term parents function
function sergi_term_parents( $term_id, $child_terms, $taxonomy, $delimeter ){

今すぐあなたのterm_parents関数は決して衝突しないでしょう、そしてどんな分類学または区切り文字のためにも働きます

6
Tom J Nowell