принятие пользователем загружает лучшие практики! - PullRequest
1 голос
/ 25 января 2010

Я пытаюсь добавить многостраничную форму в php с Zend Framework, где пользователи могут добавить элемент на мой сайт. На первой странице они вводят детали об элементе (который затем сохраняется в сеансе), на второй странице они могут загружать изображения, а затем на третьей странице они могут подтвердить список. Если они подтверждают, тогда добавляется список.

Каков наилучший способ добиться этого с точки зрения предоставления пользователям возможности загружать изображения? Я собираюсь использовать SWFUpload или uploadify, но я должен добавить изображения прямо в базу данных и если да, то под каким идентификатором списка? Я не создаю идентификатор объявления, пока пользователь не нажмет подтверждение. Итак, каковы лучшие практики? я должен хранить их во временной папке, названной после сеанса? хранить в базе данных под временным именем, таким как адрес + сессия или что?

edit: Эй, извините, может быть, я не очень ясно выразился. Я не ищу способ загрузки файлов. Я спрашиваю, как лучше их хранить, прежде чем я узнаю, собирается ли пользователь на самом деле подтвердить листинг. Должен ли я сохранить их во временной папке, а затем обработать их, когда пользователь подтвердит листинг, а затем написать автоматический скрипт, который удаляет папку, созданную более часа назад. Или я должен хранить их в базе данных во временной таблице под каким-то ключом, состоящим из сессии и атрибута листинга? По сути, я спрашиваю, что делает ebay с изображениями, которые вы загружаете при добавлении листинга, но до того, как вы подтвердили и создали его.

Большое спасибо за помощь !!

Ответы [ 2 ]

1 голос
/ 25 января 2010

Я не использовал «Зенд», так что, возможно, я выдуваю дым. Кажется, вопрос не зависит от «зенд».

Загрузка в 3 шага кажется немного неловкой. Есть ли причина использовать 3 формы? Кажется, что эта концепция только вызывает дилемму из-за использования временного файла (что является плохой идеей, кстати).

Как минимум, я бы объединил первые два шага, описание и загрузку картинки. Есть ли причина не включать кнопку «Выбрать файл» на странице описания? Кажется особенно утомительным проходить другую форму, даже если у вас нет изображения. Если у пользователя действительно есть изображение, было бы разумно поместить его и описание в его окончательные места в БД, помеченные как «предварительные». Ваш код презентации будет игнорировать «предварительные» элементы (для любого пользователя, кроме владельца). Это намного чище, чем беспокоиться об отдельных файлах. Если пользователь никогда не подтвердит, у вас будет некоторая очистка, чтобы сделать в конечном счете. Но если пользователь был только временно отвлечен или отключен (думая о днях модемов удаленного доступа), ему будет легко выбрать, где он остановился. Ваш поиск презентации / код презентации будет показывать «предварительные» элементы, принадлежащие самому пользователю. И когда он подтвердит, вам нужно только изменить статус с «предварительный» на «подтвержденный».

Эта третья страница подтверждения - это запрос пароля или страница «Вы уверены / предварительный просмотр»? Я надеюсь, что это не первый. Пользователь должен быть авторизован к моменту появления первой страницы описания. Если последняя страница предназначена только для предварительного просмотра текста, вы можете устранить ее, одновременно показывая предварительный просмотр, как это делает StackOverflow. Если это вступит в конфликт с «zend» или вы захотите показать полный макет с изображением, тогда вы можете поместить кнопку «Предварительный просмотр» на единственную страницу.

Самым чистым дизайном будет отдельная страница с текстовым полем для описания, кнопкой «Выбрать файл» для необязательного изображения, кнопкой «Предварительный просмотр» и кнопкой «Завершить». Пользователь может ввести свое описание и, возможно, выбрать файл изображения. Передача данных не происходит, пока он не выберет «Завершить» или «Предварительный просмотр». Если он чувствует себя смелым, он нажимает «Завершить», данные передаются и помечаются как «подтвержденные». Если он хотел предварительный просмотр, происходят такие же передачи, за исключением того, что данные помечены как «предварительные» в БД. Страницу дисплея, вероятно, придется изменить, чтобы включить изображение. Вы не хотели бы тратить место на странице «Описание» для изображения до его загрузки. Но это был бы простой условный шаг в коде, который выплевывал <IMG...> для картинки только тогда, когда картинка была доступна.

1 голос
/ 25 января 2010

Поскольку вы упомянули Zend Framework, я включаю ссылки на документацию вместе с выдержкой:

Zend_File_Transfer предоставляет обширные поддержка загрузки файлов и загрузки. Он поставляется со встроенным валидаторы для файлов плюс функциональность для изменения файлов с фильтры. Адаптеры протокола позволяют Zend_File_Transfer, чтобы выставить то же самое API для транспортных протоколов, таких как HTTP, FTP, WEBDAV и др.

Подробнее: http://framework.zend.com/manual/en/zend.file.html

Zend_File_Transfer поставляется с несколько связанных с файлом валидаторов, которые может быть использован для повышения безопасности и предотвратить возможные атаки.

Подробнее: http://framework.zend.com/manual/en/zend.file.transfer.validators.html

И пример: http://ahsangill.wordpress.com/2009/02/17/zend-framework-file-upload-using-zend_form_element_file/

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...