¿Cómo agrego una imagen URL enviada a WordPress?

A veces, necesita agregar una imagen presentada dinámicamente a una publicación o un tipo de publicación personalizada desde un servidor que no sea el que ejecuta su instalación de WordPress. Y te enfrentas a una pregunta común: ¿cómo hacerlo?
Por supuesto, en este caso, debe tomar la imagen presentada del segundo servidor, descargarla en su propio servidor, en la carpeta de carga y asignarla a la publicación correcta. En el primer paso, crearemos dinámicamente una nueva publicación y luego procesaremos la imagen presentada.
Paso 1: crea una publicación dinámica
Para crear publicaciones dinámicamente, debe usar la función wp_insert_post (). Puede pegar el código a continuación en la declaración "IF"; de lo contrario, se creará una nueva publicación cada vez que se cargue la página. No tan útil
// Register Post Data $post = array(); $post['post_status'] = 'publish'; $post['post_type'] = 'post'; // can be a CPT too $post['post_title'] = 'My New Post'; $post['post_content'] = 'My new post content'; $post['post_author'] = 1; // Create Post $post_id = wp_insert_post( $post );
Ejecutar este código simplemente crea una nueva publicación. Ahora es el momento de agregar una imagen destacada.
Paso 2: agregue una imagen presentada
Para agregar una imagen destacada desde una URL, necesitamos usar algunas funciones de WordPress:
Ahora aquí está el código. Comenté cada acción para que pueda ver exactamente lo que sucede cuando se ejecuta este script.
// Add Featured Image to Post
$image_url="http://s.wordpress.org/style/images/wp-header-logo.png"; // Define the image URL here
$image_name="wp-header-logo.png";
$upload_dir = wp_upload_dir(); // Set upload folder
$image_data = file_get_contents($image_url); // Get image data
$unique_file_name = wp_unique_filename( $upload_dir['path'], $image_name ); // Generate unique name
$filename = basename( $unique_file_name ); // Create image file name
// Check folder permission and define file location
if( wp_mkdir_p( $upload_dir['path'] ) ) {
$file = $upload_dir['path'] . "https://blogging-techies.com/" . $filename;
} else {
$file = $upload_dir['basedir'] . "https://blogging-techies.com/" . $filename;
}
// Create the image file on the server
file_put_contents( $file, $image_data );
// Check image file type
$wp_filetype = wp_check_filetype( $filename, null );
// Set attachment data
$attachment = array(
'post_mime_type' => $wp_filetype['type'],
'post_title' => sanitize_file_name( $filename ),
'post_content' => '',
'post_status' => 'inherit'
);
// Create the attachment
$attach_id = wp_insert_attachment( $attachment, $file, $post_id );
// Include image.php
require_once(ABSPATH . 'wp-admin/includes/image.php');
// Define attachment metadata
$attach_data = wp_generate_attachment_metadata( $attach_id, $file );
// Assign metadata to attachment
wp_update_attachment_metadata( $attach_id, $attach_data );
// And finally assign featured image to post
set_post_thumbnail( $post_id, $attach_id );
Lo mejor de este código es que puedes ponerlo en un bucle. Por ejemplo, importe publicaciones desde un archivo CSV o un archivo XML. Esto es muy poderoso y muy útil, pero recuerde una cosa: no use este script en su archivo functions.php sin antes colocar una etiqueta condicional, o creará cientos de publicaciones nuevas en minutos.
¿Te funciona este fragmento? ¡Deja un comentario y cuéntanos qué creaste a partir de este fragmento!


Deja una respuesta