media_handle_upload()
Загружает переданный в форме файл в папку загрузок WordPress и создает запись о файле в базе данных (добавляет файл в медиатеку WP).
Работает c глобальной переменной $_FILES, функции нужно указать индекс массива $_FILES, который содержит данные о загружаемом файле и функция сама загрузит файл в папку загрузок WordPress и создаст запись о вложении в таблице wp_posts в базе данных. Во втором параметре нужно указать 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';
Когда нужно работать с произвольными данными файла, а не с массовом $_FILES, используйте media_handle_sideload().
Хуков нет.
Возвращает
int|WP_Error. ID созданного вложения. WP_error, если загрузка не удалась.
Использование
media_handle_upload( $file_id, $post_id, $post_data, $overrides );
- $file_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 )
Примеры
#1 Форма загрузки файла и его сохранение
Для начала приведем пример кода формы с полем загрузки файла. Предположительно код установлен в лицевой части сайта:
<form id="featured_upload" method="post" action="#" enctype="multipart/form-data"> <input type="file" name="my_image_upload" id="my_image_upload" multiple="false" /> <input type="hidden" name="post_id" id="post_id" value="55" /> <?php wp_nonce_field( 'my_image_upload', 'my_image_upload_nonce' ); ?> <input id="submit_my_image_upload" name="submit_my_image_upload" type="submit" value="Upload" /> </form>
Убедитесь, что вы используете атрибут 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 "Проверка не пройдена. Невозможно загрузить файл.";
}
?> #2 Создание множественной загрузки файлов в WordPress
WordPress позволяет загружать сразу несколько файлов даже с возможностью drag-and-drop, в Админ-панели. Если вам нужно добавить такую возможность на внешнюю часть сайта, то сделать это не так сложно. Для этого допустим, создадим шаблон страницы (my-upload-page.php) и разместим на нем форму:
<form action="" method="post" enctype="multipart/form-data" name="front_end_upload" > <label> Добавьте все файлы здесь: <input type="file" name="kv_multiple_attachments[]" multiple="multiple" > </label> <input type="submit" name="Загрузить" > </form>
Эта форма отправляет данные на свою же страницу (action=""), поэтому в коде этого же файла (my-upload-page.php) шаблона нужно разместить обработчик, см. пример выше.
Список изменений
| С версии 2.5.0 | Введена. |