プログラムで外部からカスタム投稿に注目画像を設定する方法


13

私は、ワードプレス環境外の画像を取得して、PHP経由でカスタム投稿に挿入しようとしています。

その画像をワードプレスに移動/アップロードする方法は、ワードプレスが行うように、ディレクトリの年の日付フォルダ形式をアップロードし、カスタムポストに対してその画像を注目の画像に設定しますか?

また、カスタムポストギャラリーに画像をアップロードするには?

以下は私のコードです

$filename = $image['name'];
$target_path = "../wp-content/uploads/";
$target_path = $target_path . $filename;
$wp_filetype = wp_check_filetype(basename($filename), null );
$wp_upload_dir = wp_upload_dir();
$attachment = array(
    'guid' => $wp_upload_dir['baseurl'] . '/' . basename( $filename ),
    'post_mime_type' => $wp_filetype['type'],
    'post_title' => preg_replace('/\.[^.]+$/', '', basename($filename)),
    'post_content' => '',
    'post_status' => 'inherit',
);
$attach_id = wp_insert_attachment( $attachment, $target_path, $post_id );
$attach_data = wp_generate_attachment_metadata( $attach_id, $filename );
wp_update_attachment_metadata( $attach_id, $attach_data );
set_post_thumbnail( $post_id, $attach_id );

アップロードディレクトリに画像をアップロードできましたが、年月日フォルダを作成できません。これはそれのためのwp関数ですか??

回答:


27

これをmedia_sideload_image()で単純に行うことはできませんか?

とても簡単そうです。唯一の問題は、管理領域にいない場合、WordPress内から次のライブラリを含める必要があることです。

// only need these if performing outside of admin environment
require_once(ABSPATH . 'wp-admin/includes/media.php');
require_once(ABSPATH . 'wp-admin/includes/file.php');
require_once(ABSPATH . 'wp-admin/includes/image.php');

// example image
$image = 'http://example.com/logo.png';

// magic sideload image returns an HTML image, not an ID
$media = media_sideload_image($image, $post_id);

// therefore we must find it so we can set it as featured ID
if(!empty($media) && !is_wp_error($media)){
    $args = array(
        'post_type' => 'attachment',
        'posts_per_page' => -1,
        'post_status' => 'any',
        'post_parent' => $post_id
    );

    // reference new image to set as featured
    $attachments = get_posts($args);

    if(isset($attachments) && is_array($attachments)){
        foreach($attachments as $attachment){
            // grab source of full size images (so no 300x150 nonsense in path)
            $image = wp_get_attachment_image_src($attachment->ID, 'full');
            // determine if in the $media image we created, the string of the URL exists
            if(strpos($media, $image[0]) !== false){
                // if so, we found our image. set it as thumbnail
                set_post_thumbnail($post_id, $attachment->ID);
                // only want one image
                break;
            }
        }
    }
}

1
このソリューションは、魅力(y)のように動作します
オマールタリク

このコードを追加できる場所
er.irfankhan11

1
ワードプレス4.8の時点で、あなたは第四パラメータを設定することができますmedia_sideload_image'id'、それが新しい添付ファイルIDを返します。例:$new_att_id = media_sideload_image($image, $post_id, "image description...", 'id'); if(!is_wp_error($new_att_id)) { set_post_thumbnail($post_id, $new_att_id); }
ドンウィルソン

1

パスと投稿IDを使用したアップロードの説明をお試しください。

コードは次のとおりです(レガシー用):

/* Import media from url
 *
 * @param string $file_url URL of the existing file from the original site
 * @param int $post_id The post ID of the post to which the imported media is to be     attached
 *
 * @return boolean True on success, false on failure
 */

function fetch_media($file_url, $post_id) {
require_once(ABSPATH . 'wp-load.php');
require_once(ABSPATH . 'wp-admin/includes/image.php');
global $wpdb;

if(!$post_id) {
    return false;
}

//directory to import to    
$artDir = 'wp-content/uploads/2013/06';

//if the directory doesn't exist, create it 
if(!file_exists(ABSPATH.$artDir)) {
    mkdir(ABSPATH.$artDir);
}

//rename the file
$ext = array_pop(explode("/", $file_url));
$new_filename = 'blogmedia-'.$ext;

if (@fclose(@fopen($file_url, "r"))) { //make sure the file actually exists
    copy($file_url, ABSPATH.$artDir.$new_filename);


    $siteurl = get_option('siteurl');
    $file_info = getimagesize(ABSPATH.$artDir.$new_filename);

    //create an array of attachment data to insert into wp_posts table
    $artdata = array();
    $artdata = array(
        'post_author' => 1, 
        'post_date' => current_time('mysql'),
        'post_date_gmt' => current_time('mysql'),
        'post_title' => $new_filename, 
        'post_status' => 'inherit',
        'comment_status' => 'closed',
        'ping_status' => 'closed',
        'post_name' => sanitize_title_with_dashes(str_replace("_", "-", $new_filename)),                                            'post_modified' => current_time('mysql'),
        'post_modified_gmt' => current_time('mysql'),
        'post_parent' => $post_id,
        'post_type' => 'attachment',
        'guid' => $siteurl.'/'.$artDir.$new_filename,
        'post_mime_type' => $file_info['mime'],
        'post_excerpt' => '',
        'post_content' => ''
    );

    $uploads = wp_upload_dir();
            $save_path = $uploads['basedir'].'/2013/06/'.$new_filename;

    //insert the database record
    $attach_id = wp_insert_attachment( $artdata, $save_path, $post_id );

    //generate metadata and thumbnails
    if ($attach_data = wp_generate_attachment_metadata( $attach_id, $save_path)) {
        wp_update_attachment_metadata($attach_id, $attach_data);
    }

    //optional make it the featured image of the post it's attached to
    $rows_affected = $wpdb->insert($wpdb->prefix.'postmeta', array('post_id' => $post_id, 'meta_key' => '_thumbnail_id', 'meta_value' => $attach_id));
}
else {
    return false;
}

return true;
}

1

注目画像をプログラムで設定する次のコードを参照してください。 http://www.pearlbells.co.uk/code-snippets/set-featured-image-wordpress-programmatically/

function setFeaturedImages() {

$base = dirname(__FILE__);
$imgfile= $base.DS.'images'.DS.'14'.DS.'Ascot_Anthracite-Grey-1.jpg';
$filename = basename($imgfile);
$upload_file = wp_upload_bits($filename, null, file_get_contents($imgfile));
if (!$upload_file['error']) {
    $wp_filetype = wp_check_filetype($filename, null );
    $attachment = array(
        'post_mime_type' => $wp_filetype['type'],
        'post_parent' => 0,
        'post_title' => preg_replace('/\.[^.]+$/', '', $filename),
        'post_content' => '',
        'post_status' => 'inherit'
    );
$attachment_id = wp_insert_attachment( $attachment, $upload_file['file'], 209 );

if (!is_wp_error($attachment_id)) {
    require_once(ABSPATH . "wp-admin" . '/includes/image.php');
    $attachment_data = wp_generate_attachment_metadata( $attachment_id, $upload_file['file'] );
    wp_update_attachment_metadata( $attachment_id,  $attachment_data );
}

set_post_thumbnail( 209, $attachment_id );

}
}

0

おそらく私は誤解していますが、なぜあなたはWordPress環境の外でそれをしたいのですか?この機能を複製するのは大変な作業です!WordPressは、単にファイルをアップロードして特定のディレクトリに配置するだけでなく、たとえば、どのユーザーにファイルのアップロードを許可するか、アップロード用のデータベースレコードを追加し、特徴的な画像関係を設定し、ファイルのアップロード-サイトの設定(命名規則、メディアのアップロード場所など)を順守している間。

外部サイトからファイルをアップロードする場合など、WordPress管理セクションにログインせずにファイルをアップロードするだけの場合は、XML-RPC API、具体的にはuploadFileメソッドをご覧ください。

別のオプションは、自分でミニAPIを作成することです。基本的にあなたがしたいことはこれです:

  1. アップロードを介してサーバー上のファイルを取得します(またはサーバーに指定されたURLからファイルをダウンロードさせます)。
  2. 使用wp_upload_dir()アップロードディレクトリのパスを取得するとsanitize_file_name()、パスを構築し、そして得られた場所にファイルを書き込むこと。
  3. wp_insert_attachment()データベースに添付ファイルを保存するために使用します(wp_check_filetype()設定に役立ちますpost_mime_type)。必要に応じてpost_parent_thumbnail_idメタキーも設定します。
  4. 必要に応じて、APIを外部ユーザーに公開するか、ログインを要求します。少なくともパブリックフォームを使用wp_create_nonce()wp_verify_nonce()、フォームのセキュリティを少し高める場合。

アプリケーション用のWebサービスを作成しています。アプリケーションは、投稿データと画像を挿入するFILE配列を私に送信します。データベースに投稿の詳細を挿入しましたが、画像部分にはまりました。
ファイサルシェザード

のドキュメントを確認してくださいwp_insert_attachment()、それはあなたが必要とする多くのことをするはずです。WordPress以外でデータベースを手動で変更することをお勧めします。代わりに、WordPressのソースを見て、投稿データの追加、ファイルのアップロードの処理、添付ファイルの挿入を担当する部分を特定してください。言い換えれば、上記の回答で説明したこととほぼ同じです。
サイモン

@サイモン私は同じ問題を抱えています。アップロードしたいもう1つの理由は、別の投稿に添付したい画像のバッチジョブがある場合で、手動では行いません。
hitautodestruct

1
@hitautodestruct:絶対に、既存のサイト、レガシーシステム、データベースエクスポートなどからデータを移行するとき、私はしばしばそれを行います。画像を正しい場所に配置する独自のもの(これは、私が問題について認識したものをある程度拡張したものです)。
サイモン
弊社のサイトを使用することにより、あなたは弊社のクッキーポリシーおよびプライバシーポリシーを読み、理解したものとみなされます。
Licensed under cc by-sa 3.0 with attribution required.