Загружает переданный в форме файл в папку загрузок WordPress и создает запись о файле в базе данных (добавляет файл в медиатеку WP).
Работает c глобальной переменной $_FILES, функции нужно указать индекс массива $_FILES, который содержит данные о загружаемом файле и функция сама загрузит файл в папку загрузок WordPress и создаст запись о вложении в таблице wp_posts в базе данных. Во втором параметре нужно указать id записи (поста), к которой загруженный медиафайл должен быть прикреплен.
Для работы этой функции во фронте нужно подключить файлы:
Индекс элемента массива $_FILES, который содержит данные о принятом файле (название, тип, размер, временное расположение).
$post_id(число) (обязательный)
ID поста, к которому будет прикреплен медиафайл. Если не нужно, чтобы файл был прикреплен к посту, то укажите в параметре 0.
$post_data(массив)
Позволяет перезаписать данные создаваемого вложения. Тут указываются данные которые будут записаны в таблицу wp_posts для создаваемого вложения: post_parent, post_title, post_excerpt и т.д. По умолчанию: array() (данные по умолчанию)
$overrides(массив)
Позволяет изменить поведение функции wp_handle_upload(), на основе которой работает текущая функция. По умолчанию: array( 'test_form' => false )
Убедитесь, что вы используете атрибут enctype="multipart/form-data" для формы.
Если его не указать, то $_FILES будет пустым и функция media_handle_upload() вернет ошибку.
Теперь, код для сохранения файла вложения:
<?php
// Проверим защиту nonce и что пользователь может редактировать этот пост.
if (
isset( $_POST['my_image_upload_nonce'], $_POST['post_id'] )
&& wp_verify_nonce( $_POST['my_image_upload_nonce'], 'my_image_upload' )
&& current_user_can( 'edit_post', $_POST['post_id'] )
) {
// все ок! Продолжаем.
// Эти файлы должны быть подключены в лицевой части (фронт-энде).
require_once( ABSPATH . 'wp-admin/includes/image.php' );
require_once( ABSPATH . 'wp-admin/includes/file.php' );
require_once( ABSPATH . 'wp-admin/includes/media.php' );
// Позволим WordPress перехватить загрузку.
// не забываем указать атрибут name поля input - 'my_image_upload'
$attachment_id = media_handle_upload( 'my_image_upload', $_POST['post_id'] );
if ( is_wp_error( $attachment_id ) ) {
echo "Ошибка загрузки медиафайла.";
} else {
echo "Медиафайл был успешно загружен!";
}
} else {
echo "Проверка не пройдена. Невозможно загрузить файл.";
}
?>
0
#2 Создание множественной загрузки файлов в WordPress
WordPress позволяет загружать сразу несколько файлов даже с возможностью drag-and-drop, в Админ-панели. Если вам нужно добавить такую возможность на внешнюю часть сайта, то сделать это не так сложно. Для этого допустим, создадим шаблон страницы (my-upload-page.php) и разместим на нем форму:
Эта форма отправляет данные на свою же страницу (action=""), поэтому в коде этого же файла (my-upload-page.php) шаблона нужно разместить обработчик, см. пример выше.
Список изменений
С версии 2.5.0
Введена.
Код media_handle_upload() media handle upload WP 6.7.1