0

Я использую простой настраиваемый плагин, который анализирует и сохраняет внешние XML-данные в виде сериализованного массива в настраиваемом поле. Это прекрасно работает, однако, когда я обновляю сообщение, вместо массива я вижу только сообщение: «bool (false)». Я предполагаю, что это связано с сериализацией/unserialize, но не нашел никаких подсказок.get_post_meta unserialize issue - retuns boolean (false)

Мне нужно было сериализовать, когда я обновляю сообщение meta с помощью update_post_meta($post_id, 'tb_data', serialize($new_value_array)); Опуская сериализацию, как update_post_meta($post_id, 'tb_data', $new_value_array); не сохраняет данные в настраиваемом поле. Кроме того, для печати результатов я должен использовать maybe_unserialize(get_post_meta($post->ID, 'tb_data', true));.

Существует 2 пользовательских поля, (1) tb_item_group_id и (2) tb_data. Значение tb_data будет добавлено с использованием функции ниже:

Функция, которую я использую для обновления сообщения meta, приведена ниже.

function parse_file_func($title) { 
    // get_tickets_array();exit; 
    $language = explode('-', get_bloginfo('language')); 
    $language = $language[0]; 
    $file = file_get_contents('https://dl.dropboxusercontent.com/u/12344450/feed.xml'); 
    if (!$file) { 
     exit; 
    } 
    $domObj = new xmlToArrayParser($file); 
    $domArr = $domObj->array; 
    if (($domObj->parse_error)) { 
     echo $domObj->get_xml_error(); 
    } else { 
     $first = $domArr['rss']['channel']['item']; 
     foreach ($first as $item) { 
      if ($item['languageCode'] == $language) { 
       $args = array(
        'meta_key' => 'tb_item_group_id', 
        'meta_value' => $item['g:item_group_id'], 
        'post_type' => 'tickets', 
       ); 
       $post = get_posts($args); 
       if (empty($post)) { 
        continue; 
       } else { 
        $args = array(
         'meta_key' => 'tb_item_group_id', 
         'meta_value' => $item['g:item_group_id'], 
         'post_type' => 'tickets', 
        ); 
        $post = get_posts($args); 
        $post_id = $post[0]->ID; 
        $meta_values = get_post_meta($post_id, 'tb_data'); 
        if (empty($meta_values)) { 
         $new_value_array = array(); 
         unset($item['cdata']); 
         $new_value_array['tb_' . $item['g:item_group_id'] . '_' . $item['ticketID']] = $item; 
        } 
        else { 
         $meta_arrays = unserialize($meta_values[0]); 
         $new_value_array = $meta_arrays; 
         foreach ($meta_arrays as $meta_ticketbar => $tb_content) { 
          if ($meta_ticketbar == 'tb_' . $item['g:item_group_id'] . '_' . $item['ticketID']) { 
           unset($item['cdata']); 
           $new_value_array[$meta_ticketbar] = $item; 
          } else { 
           $new_value_array = $meta_arrays; 
           unset($item['cdata']); 
           $new_value_array['tb_' . $item['g:item_group_id'] . '_' . $item['ticketID']] = $item; 
          } 
         } 
        } 
        update_post_meta($post_id, 'tb_data', serialize($new_value_array)); 
        // update_post_meta($post_id, 'tb_data', base64_encode($new_value_array)); 
       } 
      } else { 
       continue; 
      } 
     } 
    } 
} 

и отображение на переднем конце, используя get_post_meta

<?php 
    // $tb_meta = get_post_meta($post->ID, 'tb_data', true); 
    $tb_meta = get_post_meta($post->ID, 'tb_data', true); 
    $tb_meta_unserialized = maybe_unserialize($tb_meta); 
?> 
<pre><?php 
    // print_r ($tb_meta_unserialized); 
    var_dump($tb_meta_unserialized); 
?></pre> 

ответ

0

мне удалось зафиксировать его на мою собственную.

Я использовал следующий код для обновления после мета

update_post_meta($post_id, 'tb_data', base64_encode(serialize($new_value_array))); 

... и следующий код, чтобы получить пост мета

$tb_meta = get_post_meta($post->ID, 'tb_data', true); 
$tb_meta_unserialized = unserialize(base64_decode($tb_meta)); 

Я надеюсь, что это поможет кому-то.