フロントエンドから投稿のサムネイルをアップロードする


9

ユーザーが投稿を編集するときに投稿のサムネイルをアップロードできるようにしてください。これはどのように行われますか?私はそれがwordpressのajax関数を利用することを想像します。

何か案は、

素晴らしい

回答:


25

ブラウザのXMLHttpRequestオブジェクトを使用してファイルをアップロードすることはできないため、Ajaxでのファイルのアップロードは少し難しいので、何らかのAjaxアップロードプラグインを使用する必要があり、最も簡単なのはJQueryフォームプラグインです。 WordPressに含まれています。したがって、それを使用するには、それをエンキューする必要があります。

add_action('wp_print_scripts','include_jquery_form_plugin');
function include_jquery_form_plugin(){
    if (is_page('12')){ // only add this on the page that allows the upload
        wp_enqueue_script( 'jquery' );
        wp_enqueue_script( 'jquery-form',array('jquery'),false,true ); 
    }
}

そのページに、アップロードフォームとJQueryを追加して、JQueryフォームプラグインを呼び出します。次に例を示します。

<form id="thumbnail_upload" method="post" action="#" enctype="multipart/form-data" >
  <input type="file" name="thumbnail" id="thumbnail">
  <input type='hidden' value='<?php wp_create_nonce( 'upload_thumb' ); ?>' name='_nonce' />
  <input type="hidden" name="post_id" id="post_id" value="POSTID">
  <input type="hidden" name="action" id="action" value="my_upload_action">
  <input id="submit-ajax" name="submit-ajax" type="submit" value="upload">
<form>
<div id="output1"></div>
<script>
$(document).ready(function() { 
    var options = { 
        target:        '#output1',      // target element(s) to be updated with server response 
        beforeSubmit:  showRequest,     // pre-submit callback 
        success:       showResponse,    // post-submit callback 
        url:    ajaxurl                 // since 2.8 ajaxurl is always defined in the admin header and points to admin-ajax.php     
    }; 

    // bind form using 'ajaxForm' 
    $('#thumbnail_upload').ajaxForm(options); 
});
function showRequest(formData, jqForm, options) {
//do extra stuff before submit like disable the submit button
$('#output1').html('Sending...');
$('#submit-ajax').attr("disabled", "disabled");
}
function showResponse(responseText, statusText, xhr, $form)  {
//do extra stuff after submit
}
</script>

POSTIDを実際の投稿IDで更新する必要があります。次に、Ajax関数を作成して、ファイルのアップロードを受け入れ、投稿のサムネイルを更新します

//hook the Ajax call
//for logged-in users
add_action('wp_ajax_my_upload_action', 'my_ajax_upload');
//for none logged-in users
add_action('wp_ajax_nopriv_my_upload_action', 'my_ajax_upload');

function my_ajax_upload(){
//simple Security check
    check_ajax_referer('upload_thumb');

//get POST data
    $post_id = $_POST['post_id'];

//require the needed files
    require_once(ABSPATH . "wp-admin" . '/includes/image.php');
    require_once(ABSPATH . "wp-admin" . '/includes/file.php');
    require_once(ABSPATH . "wp-admin" . '/includes/media.php');
//then loop over the files that were sent and store them using  media_handle_upload();
    if ($_FILES) {
        foreach ($_FILES as $file => $array) {
            if ($_FILES[$file]['error'] !== UPLOAD_ERR_OK) {
                echo "upload error : " . $_FILES[$file]['error'];
                die();
            }
            $attach_id = media_handle_upload( $file, $post_id );
        }   
    }
//and if you want to set that image as Post  then use:
  update_post_meta($post_id,'_thumbnail_id',$attach_id);
  echo "uploaded the new Thumbnail";
  die();
} 

お役に立てれば


これは素晴らしいです。いくつかのクエリ。つまり、すべてはどこに行く必要があるのでしょうか。明らかに、フォームは問題のページに表示され、それが使用する投稿IDになります。最初の追加アクションは、HEAD領域またはfunctions.phpのアクションです。そして// ajax呼び出しをフックすることで始まる最後のajaxブロック。そのビットはどこに行きますか。どうもありがとう。
ロビンIナイト

最初と最後のコードスニペットはfunctions.phpの任意の場所に配置でき、2番目のスニペットはアップロードフォームを表示するページに配置する必要があります。2番目のスニペットをショートコードに変更すると、物事が簡単になります。 。
Bainternet、2011年

私がこれについて得ていないことは、フォームがmy_ajax_upload()を使用することをどのように知るのですか?それはajax呼び出しに含めるべきではありませんか?私が編集を許可している投稿のループがあり、特定の投稿を処理するために異なる機能が必要なため、これを質問します。
Pollux Khafra

アクション値が機能add_action(...するmy_ajax_uploadようにフック()されているため、フォームはmy_ajax_uploadを使用することを認識しています。
Bainternet、2012年

この機能に影響を与えるWPの最近の変更はありますか?何らかの理由で、JSコールバックではparamに期待どおりのものがすべて含まれているにもかかわらず、$_POSTに到達するまでmy_ajax_uploadにデータがありません。showRequestformData
drzaus 2013年
弊社のサイトを使用することにより、あなたは弊社のクッキーポリシーおよびプライバシーポリシーを読み、理解したものとみなされます。
Licensed under cc by-sa 3.0 with attribution required.