В этом уроке мы с Вами научимся использовать форму обратной связи не только для отправки текстовых сообщений, но и для отправки файлов на сервер.Форма обратной связи с аттачами
Итак, приступим к созданию простой формы, основная функция которой загружать файлы определенного типа и размера в определенную папку на сервере.
Шаг 1.
Для начала нам нужно создать форму для загрузки файлов на сервер. Код, который будет отвечать за форму, будет выглядеть примерно так:
<form action=»./upload.php» method=»post» enctype=»multipart/form-data»>
<p><input type=»file» name=»userfile» id=»file»></p>
<p><input type=»submit» value=»Загрузить фаил»></p>
</form>
Обработчиком этой формы будет фаил upload.php. Т.к. мы собираемся передавать через форму файлы, то атрибут enctype нужно обязательно установить в значение multipart/form-data.
Форма, которую мы только что создали будет выглядеть примерно так:
Шаг 2.
Теперь мы можем приступать к созданию обработчика, которым у нас является фаил upload.php. Начнем мы с того, что пропишем допустимые типы файлов, которые можно будет загружать на наш сервер. Этим мы защитим себя от угрозы, которую таят в себе некоторые типы файлов, такие как .php, .pl и т.д.
$allowed_filetypes = array(‘.jpg’,’.gif’,’.bmp’,’.png’); // Здесь мы перечисляем допустимые типы файлов
$max_filesize = 524288; // Максимальный размер загружаемого файла в байтах (в данном случае он равен 0.5 Мб).
$upload_path = ‘./files/’; // Место, куда будут загружаться файлы (в данном случае это папка ‘files’).
$filename = $_FILES[’userfile’][‘name’]; // В переменную $filename заносим точное имя файла (включая расширение).
$ext = substr($filename, strpos($filename,’.’), strlen($filename)-1); // В переменную $ext заносим расширение загруженного файла.
// Сверяем полученное расширение со списком допутимых расширений, которые мы определили в самом начале. Если расширение загруженного файла не входит в список разрешенных, то прерываем выполнение программы и выдаем соответствующее сообщение.
if(!in_array($ext,$allowed_filetypes))
die(‘Данный тип файла не поддерживается.’);
// Теперь проверим размер загруженного файла и если он больше максимально допустимого, то прерываем выполнение программы и выдаем сообщение.
if(filesize($_FILES[‘userfile’][‘tmp_name’]) > $max_filesize)
die(‘Фаил слишком большой.’);
// Проверяем, доступна ли на запись папка, определенная нами под загрузку файлов (папка files). Если вдруг недоступна, то выдаем сообщение, что на папку нужно поставить права доступа 777.
if(!is_writable($upload_path))
die(‘Невозможно загрузить фаил в папку. Установите права доступа — 777.’);
// Загружаем фаил в указанную папку.
if(move_uploaded_file($_FILES[‘userfile’][‘tmp_name’],$upload_path . $filename))
echo ‘Ваш фаил успешно загружен <a href=»‘ . $upload_path . $filename . ‘»>смотреть</a>’;
else
echo ‘При загрузке возникли ошибки. Попробуйте ещё раз.’;
?>
Ещё один момент, который Вам стоит знать. PHP по умолчанию не позволяет загружать файлы больше чем 2 Мб. Чтобы увеличить этот показатель, Вам нужно подправить параметры set upload_max_filesize и post_max_size в файле php.ini.