Как сделать загрузку файлов с помощью PHP и Zend Framework?
я использую Zend Framework 1.9.6. Я думаю, что я почти все понял, за исключением конца. Это то, что у меня есть до сих пор:
форма:
<?php
class Default_Form_UploadFile extends Zend_Form
{
public function init()
{
$this->setAttrib('enctype', 'multipart/form-data');
$this->setMethod('post');
$description = new Zend_Form_Element_Text('description');
$description->setLabel('Description')
->setRequired(true)
->addValidator('NotEmpty');
$this->addElement($description);
$file = new Zend_Form_Element_File('file');
$file->setLabel('File to upload:')
->setRequired(true)
->addValidator('NotEmpty')
->addValidator('Count', false, 1);
$this->addElement($file);
$this->addElement('submit', 'submit', array(
'label' => 'Upload',
'ignore' => true
));
}
}
:
public function uploadfileAction()
{
$form = new Default_Form_UploadFile();
$form->setAction($this->view->url());
$request = $this->getRequest();
if (!$request->isPost()) {
$this->view->form = $form;
return;
}
if (!$form->isValid($request->getPost())) {
$this->view->form = $form;
return;
}
try {
$form->file->receive();
//upload complete!
//...what now?
$location = $form->file->getFileName();
var_dump($form->file->getFileInfo());
} catch (Exception $exception) {
//error uploading file
$this->view->form = $form;
}
}
теперь что мне делать с файлом? Он был загружен в мой /tmp
каталог по умолчанию. Очевидно, я не хочу держать его там. Я хочу, чтобы пользователи моего приложения могли его скачать. Итак, я думаю, что это означает, что мне нужно переместить загруженный файл на публику каталог моего приложения и сохраните имя файла в базе данных, чтобы я мог отобразить его как url-адрес.
или установите это как каталог загрузки в первую очередь (хотя я столкнулся с ошибками при попытке сделать это раньше).
вы работали с загруженными файлами раньше? Какой следующий шаг я должен сделать?
устранение:
я решил поместить загруженные файлы в data/uploads
(который является ссылкой sym на каталог вне моего приложения, в чтобы сделать его доступным для всех версии моего приложения).
# /public/index.php
# Define path to uploads directory
defined('APPLICATION_UPLOADS_DIR')
|| define('APPLICATION_UPLOADS_DIR', realpath(dirname(__FILE__) . '/../data/uploads'));
# /application/forms/UploadFile.php
# Set the file destination on the element in the form
$file = new Zend_Form_Element_File('file');
$file->setDestination(APPLICATION_UPLOADS_DIR);
# /application/controllers/MyController.php
# After the form has been validated...
# Rename the file to something unique so it cannot be overwritten with a file of the same name
$originalFilename = pathinfo($form->file->getFileName());
$newFilename = 'file-' . uniqid() . '.' . $originalFilename['extension'];
$form->file->addFilter('Rename', $newFilename);
try {
$form->file->receive();
//upload complete!
# Save a display filename (the original) and the actual filename, so it can be retrieved later
$file = new Default_Model_File();
$file->setDisplayFilename($originalFilename['basename'])
->setActualFilename($newFilename)
->setMimeType($form->file->getMimeType())
->setDescription($form->description->getValue());
$file->save();
} catch (Exception $e) {
//error
}
3 ответов
по умолчанию файлы загружаются во временный каталог системы, что означает, что вы будете либо:
- использовать
move_uploaded_file
чтобы переместить файлы в другое место, - или настройте каталог, в который Zend Framework должен переместить файлы ; ваш элемент формы должен иметь
setDestination
метод, который можно использовать для этого.
для второго пункта есть пример в руководство :
$element = new Zend_Form_Element_File('foo');
$element->setLabel('Upload an image:')
->setDestination('/var/www/upload')
->setValueDisabled(true);
(но прочитайте эту страницу : есть и другие полезные сведения)
Если вы переместите файл в общедоступный каталог, любой сможет отправить ссылку на этот файл кому-либо еще, и у вас нет контроля над тем, кто имеет доступ к файлу.
вместо этого вы можете сохранить файл в БД как longblob, а затем использовать Zend Framework для предоставления пользователям доступа к файлу через контроллер/действие. Это позволит вам обернуть собственную логику аутентификации и разрешения пользователя вокруг доступа к файлам.
вам нужно будет получить файл из каталога /tmp, чтобы сохранить его в БД:
// I think you get the file name and path like this:
$data = $form->getValues(); // this makes it so you don't have to call receive()
$fileName = $data->file->tmp_name; // includes path
$file = file_get_contents($fileName);
// now save it to the database. you can get the mime type and other
// data about the file from $data->file. Debug or dump $data to see
// what else is in there
ваше действие в контроллере для просмотра будет иметь вашу логику авторизации, а затем загрузить строку из БД:
// is user allowed to continue?
if (!AuthenticationUtil::isAllowed()) {
$this->_redirect("/error");
}
// load from db
$fileRow = FileUtil::getFileFromDb($id); // don't know what your db implementation is
$this->view->fileName = $fileRow->name;
$this->view->fileNameSuffix = $fileRow->suffix;
$this->view->fileMimeType = $fileRow->mime_type;
$this->view->file = $fileRow->file;
затем в вид:
<?php
header("Content-Disposition: attachment; filename=".$this->fileName.".".$this->fileNameSuffix);
header('Content-type: ".$this->fileMimeType."');
echo $this->file;
?>
$this->setAction('/example/upload')->setEnctype('multipart/form-data');
$photo = new Zend_Form_Element_File('photo');
$photo->setLabel('Photo:')->setDestination(APPLICATION_PATH ."/../public/tmp/upload");
$this->addElement($photo);