WordPress Beitragsbild von externer URL ohne Download

Lesezeit: 5 Minuten

Benutzeravatar von user3449429
Benutzer3449429

ich möchte externe bilder als beitragsbild auf wordpress verwenden.

Entweder ändern Sie den Worpdress-Code. (Hinzufügen einer gekennzeichneten Bild-Metabox, die URLs akzeptiert, und einige Änderungen vornehmen, um das gekennzeichnete Bild von der URL korrekt anzuzeigen)

oder Ändern des Plugin-WP-Remote-Thumbnails, das ein vorgestelltes Bild von einer Bild-URL aus festlegt. es lädt das Bild herunter und erstellt Thumbnails in WordPress und stellt das vorgestellte Bild ein.

Modifikationen: * kein Download von der URL, einfach die URL zur Anzeige direkt im Blog verwenden. * Wp-Content/Uploads aus der von WordPress generierten URL entfernen, um ausgewählte Bilder anzuzeigen (nur für externe URLs) * Keine Thumbnail-Erstellung.

Vielen Dank fürs Lesen. Ich weiß, dass es viele Fragen zu diesem Problem gibt, aber wenn wir diese Frage lösen, könnte es für viele Leute nützlich sein.

hier der code:

<?php
/*
Plugin Name: WP Remote Thumbnail
Plugin URI: http://magnigenie.com/wp-remote-thumbnail-set-external-images-featured-image/
Description: A small light weight plugin to set external/remote images as post thumbnail/featured image.
Version: 1.0
Author: Nirmal Kumar Ram
Author URI: http://magnigenie.com
License: GPLv2 or later
License URI: http://www.gnu.org/licenses/gpl-2.0.html
*/
?>
<?php

/**
 * Initialize wprthumb on the post edit screen.
 */
function init_wprthumb() {
    new wprthumb();
}

if ( is_admin() ) {
    add_action( 'load-post.php', 'init_wprthumb' );
    add_action( 'load-post-new.php', 'init_wprthumb' );
}


class wprthumb {

    /**
     * Hook into the appropriate actions when the wprthumb is constructed.
     */
    public function __construct() {
        add_action( 'add_meta_boxes', array( $this, 'add_meta_box' ) );
        add_action( 'save_post', array( $this, 'save' ) );
    }

    /**
     * Adds the meta box container.
     */
    public function add_meta_box( $post_type ) {
    if ( post_type_supports( $post_type, 'thumbnail' )) {
      add_meta_box(
        'some_meta_box_name'
        ,'Remote Post Thumbnail'
        ,array( $this, 'render_meta_box_content' )
        ,$post_type
        ,'side'
        ,'default'
      );
    }
    }

    /**
     * Save the meta when the post is saved.
     */
    public function save( $post_id ) {

        /*
         * We need to verify this came from the our screen and with proper authorization,
         * because save_post can be triggered at other times.
         */

        // Check if our nonce is set.
        if ( ! isset( $_POST['wprthumb_nonce'] ) )
            return $post_id;

        $nonce = $_POST['wprthumb_nonce'];

        // Verify that the nonce is valid.
        if ( ! wp_verify_nonce( $nonce, 'wprthumb' ) )
            return $post_id;

        // If this is an autosave, our form has not been submitted,
    // so we don't want to do anything.
        if ( defined( 'DOING_AUTOSAVE' ) && DOING_AUTOSAVE ) 
            return $post_id;

        // Check the user's permissions.
        if ( 'page' == $_POST['post_type'] ) {

            if ( ! current_user_can( 'edit_page', $post_id ) )
                return $post_id;

        } else {

            if ( ! current_user_can( 'edit_post', $post_id ) )
                return $post_id;
        }

    /* All good, its safe for us to save the data now. */

        // Sanitize the user input.
        $image = sanitize_text_field( $_POST['remote_thumb'] );
    $upload_dir = wp_upload_dir();
    //Get the remote image and save to uploads directory
    $img_name = time().'_'.basename( $image );
    $img = wp_remote_get( $image );
    $img = wp_remote_retrieve_body( $img );
    $fp = fopen( $upload_dir['path']."https://stackoverflow.com/".$img_name , 'w');
    fwrite($fp, $img);
    fclose($fp);

    $wp_filetype = wp_check_filetype( $image , null );
    $attachment = array(
      'post_mime_type' => $wp_filetype['type'],
      'post_title' => preg_replace('/\.[^.]+$/', '', $image ),
      'post_content' => '',
      'post_status' => 'inherit'
    );

    //require for wp_generate_attachment_metadata which generates image related meta-data also creates thumbs
    require_once( ABSPATH . 'wp-admin/includes/image.php' );
    $attach_id = wp_insert_attachment( $attachment, $image, $post_id );
    //Generate post thumbnail of different sizes.
    $attach_data = wp_generate_attachment_metadata( $attach_id , $image );
    wp_update_attachment_metadata( $attach_id,  $attach_data );
    //Set as featured image.
    delete_post_meta( $post_id, '_thumbnail_id' );
    add_post_meta( $post_id , '_thumbnail_id' , $attach_id, true);
    }

    /**
     * Render Meta Box content.
     */
    public function render_meta_box_content( $post ) {

        // Add an nonce field so we can check for it later.
        wp_nonce_field( 'wprthumb', 'wprthumb_nonce' );

        // Display the form, using the current value.
        echo '<label for="remote_thumb">';
        _e( 'Enter remote image url', 'wprthumb' );
        echo '</label> ';
        echo '<input type="text" id="remote_thumb" name="remote_thumb" size="25" />';
    }
}

  • Hast du einen Weg gefunden?

    – die Nüsse

    7. November 2014 um 9:30 Uhr

  • Ich verwende Nelio External Featured Image

    – Benutzer3449429

    7. November 2014 um 9:57 Uhr

Ich habe gerade herausgefunden, dass Sie Bilder von Remote-URLs einfügen können, ohne sie zuerst herunterladen und dann erneut hochladen zu müssen. Dies funktioniert standardmäßig in WordPress, ohne dass Plugins installiert werden müssen.

Hier ist wie:

Wo immer Sie DATEIEN HOCHLADEN sehen, klicken Sie darauf – Ihr Dateibrowser erscheint dort, wo Sie erwarten würden, dass Sie eine lokale Datei auswählen müssen, ABER wenn Sie einfach die BILD-URL in dieses Feld einfügen und auf ÖFFNEN oder klicken [ENTER] dann importiert WordPress das Bild von der Remote-URL.

Klicken Sie auf DATEIEN AUSWÄHLEN, um Bilder von einer Remote-URL hochzuladen
Klicken Sie auf DATEIEN AUSWÄHLEN, um Bilder von einer Remote-URL hochzuladen

Fügen Sie die Remote-Bild-URL an der Stelle ein, an der Sie normalerweise den Dateinamen haben würden
Fügen Sie die Remote-Bild-URL an der Stelle ein, an der Sie normalerweise den Dateinamen haben würden

  • Entschuldigung, aber ich möchte einfach keine Dateien auf meinem Server ablegen. Zeigen Sie einfach das entfernte Bild an. danke für den tipp, kannte ich noch nicht

    – Benutzer3449429

    14. Juni 2014 um 4:39 Uhr

  • Ja – es hat mir viel Zeit gespart, seit ich es entdeckt habe

    – David Hilditch

    23. Februar 2015 um 1:11 Uhr

Ich finde nur dieses Plugin, das zu tun scheint, was Sie brauchen:
https://wordpress.org/plugins/external-featured-image

Benutzeravatar von Marcel
Marcel

Sie können das Plugin verwenden Vorgestelltes Bild von URL (FIFU) dafür.

  • Ich habe Ihr Plug-in heute ausprobiert, aber es scheint nicht mit Bildern von Google-Fotos zu funktionieren.

    – Luuklag

    8. Januar 2021 um 21:39 Uhr


  • Könntest du den Support kontaktieren? Vielen Dank!

    – Marcel

    9. Januar 2021 um 15:27 Uhr

1389870cookie-checkWordPress Beitragsbild von externer URL ohne Download

This website is using cookies to improve the user-friendliness. You agree by using the website further.

Privacy policy