「_encloseme」メタキーの難問


8

メタボックス/カスタムフィールドを操作しているときに、これらの多くを間接的に作成_encloseme meta_keysしているようwp_postmetaです。

ここに見られる:

これまでのところこれで問題は発生しておらず、カスタムフィールドは正常に機能していますが、私はローカルテストサイトに2つほどの投稿しかしなかったので、後で問題が発生する場合はライブサイトに実装したくありません。道を行く。誰もがこれらについて何をすべきか知っています、彼らは正常ですか?

これが私のメタボックスのコードです。

<?php

    //Add meta boxes to post types
    function plib_add_box() {
        global $meta_box;

        foreach($meta_box as $post_type => $value) {
            add_meta_box($value['id'], $value['title'], 'plib_format_box', $post_type, $value['context'], $value['priority']);
        }
    }
    //Formatting
    function plib_format_box() {
      global $meta_box, $post;

      // verification
      echo '<input type="hidden" name="plib_meta_box_nonce" value="', wp_create_nonce(basename(__FILE__)), '" />';

      echo '<table class="form-table">';

      foreach ($meta_box[$post->post_type]['fields'] as $field) {
          // get current post meta data
          $meta = get_post_meta($post->ID, $field['id'], true);

          echo '<tr>'.
                  '<th style="width:20%"><label for="'. $field['id'] .'">'. $field['name']. '</label></th>'.
                  '<td>';
          switch ($field['type']) {
              case 'text':
                  echo '<input type="text" name="'. $field['id']. '" id="'. $field['id'] .'" value="'. ($meta ? $meta : $field['default']) . '" size="30" style="width:97%" />'. '<br />'. $field['desc'];
                  break;
              case 'textarea':
                  echo '<textarea name="'. $field['id']. '" id="'. $field['id']. '" cols="60" rows="4" style="width:97%">'. ($meta ? $meta : $field['default']) . '</textarea>'. '<br />'. $field['desc'];
                  break;
              case 'select':
                  echo '<select name="'. $field['id'] . '" id="'. $field['id'] . '">';
                  foreach ($field['options'] as $option) {
                      echo '<option '. ( $meta == $option ? ' selected="selected"' : '' ) . '>'. $option . '</option>';
                  }
                  echo '</select>';
                  break;
              case 'radio':
                  foreach ($field['options'] as $option) {
                      echo '<input type="radio" name="' . $field['id'] . '" value="' . $option['value'] . '"' . ( $meta == $option['value'] ? ' checked="checked"' : '' ) . ' />' . $option['name'];
                  }
                  break;
              case 'checkbox':
                  echo '<input type="checkbox" name="' . $field['id'] . '" id="' . $field['id'] . '"' . ( $meta ? ' checked="checked"' : '' ) . ' />';
                  break;
          }
          echo     '<td>'.'</tr>';
      }

      echo '</table>';

    }
    // Save data from meta box
    function plib_save_data($post_id) {
        global $meta_box,  $post;

        //Verify
        if (!wp_verify_nonce($_POST['plib_meta_box_nonce'], basename(__FILE__))) {
            return $post_id;
        }

        //Check > autosave
        if (defined('DOING_AUTOSAVE') && DOING_AUTOSAVE) {
            return $post_id;
        }

        //Check > permissions
        if ('page' == $_POST['post_type']) {
            if (!current_user_can('edit_page', $post_id)) {
                return $post_id;
            }
        } elseif (!current_user_can('edit_post', $post_id)) {
            return $post_id;
        }

        foreach ($meta_box[$post->post_type]['fields'] as $field) {
            $old = get_post_meta($post_id, $field['id'], true);
            $new = $_POST[$field['id']];

            if ($new && $new != $old) {
                update_post_meta($post_id, $field['id'], $new);
            } elseif ('' == $new && $old) {
                delete_post_meta($post_id, $field['id'], $old);
            }
        }
    }

    add_action('save_post', 'plib_save_data');

    //We create an array called $meta_box and set the array key to the relevant post type
// If custom post type, change the 'post' variable
    $meta_box['post'] = array(

        //This is the id applied to the meta box
        'id' => 'venue_location',  

        //This is the title that appears on the meta box container
        'title' => 'Venue/Location',    

        //This defines the part of the page where the edit screen section should be shown
        'context' => 'normal',    

        //This sets the priority within the context where the boxes should show
        'priority' => 'high',

        //Here we define all the fields we want in the meta box
        'fields' => array(
            array(
                'name' => 'Venue',
                'desc' => 'Venue Name',
                'id' => 'venue_info',
                'type' => 'text',
                'default' => ''
            ),
            array(
                'name' => 'Location',
                'desc' => 'Location of the Venue',
                'id' => 'location_info',
                'type' => 'text',
                'default' => ''
            )
        )
    );
    add_action('admin_menu', 'plib_add_box');
?>

(念のため、上記のコードへのパストビンリンクは次のとおりです:http ://pastebin.com/0QsqxtZW )


どのバージョンのワードプレスを使用していますか?検索は_encloseme非常に古いですワードプレス2.0の情報を考え出す続けます。
スコット

また、メタボックスを追加するために使用している質問にコードを追加できますか?
スコット

うん。私もそれに遭遇しました-私は3.1.3を使用しています。ここにコード長の制限が何であるか分からない。だからここに私のメタボックスのコードへのペーストビンリンクがあります。pastebin.com/0QsqxtZW
mmaximalist

回答:


13

短縮版:

_enclosemeは、公開時に投稿に追加されます。wp-cronプロセスは、エンクロージャーを探すためにポストを処理するために、すぐにスケジュールされる必要があります。

つまり、後で通常どおりにクリーンアップされます。心配することは何もありません。

完全な説明:

「エンクロージャー」は、オーディオファイルやビデオファイルなどへの投稿内のリンクです。WordPressは、リンクされているファイルのMIMEタイプに基づいてこれらを検出し、それらに関する追加のメタデータを保存します。このメタデータはRSSフィードで使用され、これらのファイルを投稿に接続するための特別なタグを作成します。

たとえば、これがポッドキャストの仕組みです。投稿にMP3へのリンクを配置すると、そのリンクのエンクロージャが作成され、フィードにはエンクロージャが含まれます。iTunesなどのポッドキャストリーダーは、それを使用してRSSからMP3を直接ダウンロードできます。フィード。

_enclosemeは、投稿がまだエンクロージャプロセスで処理されていないことを示す、特別なメタデータです。公開された投稿を作成または更新すると、投稿がエンクロージャーの作成者によって処理されるように自動的に追加されます。


オットーさん、きちんと対応してくれてありがとうございます。できれば+1します。
mmaximalist '06 / 06/19

私の投稿が各save_pst / update_postの1投稿メタ_encloseme配列に1つ追加することを確認しました。これは、それがすでに設定されているかどうかをチェックしないので、更新/保存ごとに同じものが追加されますか?ありがとう!
カイザー2011

1
いいえ、チェックしません。追加するだけです。これは通常問題ではありません。後でエンクロージャーを実行するプロセスで削除されます。
オットー
弊社のサイトを使用することにより、あなたは弊社のクッキーポリシーおよびプライバシーポリシーを読み、理解したものとみなされます。
Licensed under cc by-sa 3.0 with attribution required.