¿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