Выбор файла - File select

В HTML, элемент управления выбора файла является компонентом веб-форма с помощью которого пользователь может выбрать локальный файл. Когда форма отправляется (возможно, вместе с другими данными формы), файл загружается в веб сервер. Там, когда файл поступает, обычно происходит какое-то действие, например, сохранение файла на веб-сервере. Однако конкретное действие, которое происходит, определяется серверный скрипт к которому отправляется форма.

Пример кода

Вот пример кода веб-формы с элементом управления выбором файла. Это ввод элемент с type = "файл" который создает элемент управления выбором файла.

<форма действие="form-handler.php" метод="сообщение" enctype="multipart / form-data">	<div>		<ввод мне бы="мой файл" имя="мой файл" тип="файл">		<ввод ценность=«Загрузить ►» тип="Разместить">	</div></форма>

Рендеринг

Когда дело доходит до рендеринга на экране элемента управления выбором файла, есть некоторые различия между веб-браузеры. Обычно на платформе Windows пользовательские агенты отображают элемент управления для выбора файла в виде текстового поля вместе с кнопкой «Обзор». При нажатии кнопки «Обзор» появляется файл диалог открывается, с помощью которого может происходить фактический выбор файла на платформе. После выбора имя выбранного файла отображается в текстовом поле. В качестве альтернативы, вместо использования кнопки «Обзор», имя файла можно ввести непосредственно в текстовое поле.

Некоторые браузеры, особенно Fire Fox,[1] больше не разрешать ввод имени файла напрямую. Это мера безопасности - можно обманом заставить пользователя загрузить конфиденциальную информацию.[2]

Функциональность

Механизм загрузки файлов на основе форм был первоначально предложен в RFC 1867 (опубликовано в ноябре 1995 г.) как расширение HTML 2.0 (RFC 1866 ), после его публикации. Затем загрузка файлов на основе форм была включена в HTML 3.2, который явно ссылается на RFC 1867 для получения дополнительной информации о загрузке файлов на основе форм.

HTML 4.01 сам по себе не описывает, как должен работать элемент управления выбором файла, но он перечисляет RFC 2388 и RFC 1867 как ссылки.[3]

Выбор нескольких файлов

Намерение в RFC 1867 состоит в том, что один элемент управления выбора файла должен позволять выбирать несколько файлов. Это намерение, по-видимому, отражено в HTML 4.01, который для типа элемента управления "выбор файла" утверждает[4]

Этот тип управления позволяет пользователю выбирать файлы, чтобы их содержимое можно было отправить с помощью формы. Элемент INPUT используется для создания элемента управления выбором файла.

Было отмечено[5] То, что множественное число «файлы» в приведенной выше цитате указывает на то, что в HTML 4.01 однофайловый элемент управления выбором по-прежнему должен был обрабатывать выбор нескольких файлов, а не только одного файла.

Эта ситуация проясняется в HTML5 путем добавления атрибута «множественный», когда ввод файла должен принимать несколько файлов. Текущий черновик определяет новое поведение:

Если не установлен атрибут multiple, в списке выбранных файлов должно быть не более одного файла.[6]

Принять атрибут

RFC 1867 также представил принять атрибут для ввод элемент. Это позволит фильтровать типы файлов на основе Тип MIME для элемента управления выбором файла.

Кроме того, предлагается, чтобы тег INPUT имел атрибут ACCEPT, который представляет собой список типов мультимедиа, разделенных запятыми.

Если присутствует атрибут ACCEPT, браузер может ограничить запрашиваемые шаблоны файлов для соответствия шаблонам файлов с соответствующими расширениями файлов для платформы.

Таким образом, пользовательский агент может ограничить выбор файлов, как, например, в следующем примере, только изображениями в формате GIF и PNG или любыми изображениями:

<ввод мне бы="мой файл" имя="мой файл" тип="файл" принять="изображение / gif, изображение / png"><ввод мне бы="мой файл" имя="мой файл" тип="файл" принять="образ/*">

На платформе Windows это может означать, что пользовательский агент будет отображать файлы только тех типов, которые указаны в диалоговом окне просмотра файлов.

Ограничения браузера

Базовая поддержка элемента управления выбором файлов была быстро принята поставщиками браузеров. Например, уже Internet Explorer 4,[7] Netscape Navigator 2.0 и Опера 3.5[8] признал ввод элемент type = "файл" как элемент управления для выбора файла.

Однако большинство современных браузеров по-прежнему не реализуют элемент управления выбором файлов, как это было задумано, или в них отсутствуют определенные функции.[5]

Невозможно выбрать несколько файлов

Загрузка нескольких файлов на основе форм с помощью одного элемента управления выбором файлов поддерживается в текущих версиях Chrome, Firefox, Internet Explorer, Safari и Opera. Один источник утверждает[5] что Opera поддерживает выбор нескольких файлов с помощью единого элемента управления выбором файлов. Это было верно для версий Opera, начиная с 3.5, в которых была представлена ​​функция загрузки файлов.[8] Однако с выходом первой бета-версии Opera 7 эта функция больше не была доступна. Firefox версии 3.6 начал поддерживать выбор нескольких файлов,[9] разрешая разработчику некоторый ограниченный доступ к самим файлам до их загрузки на сервер через HTML5 File API.[10] Эта функция также позволяет пользователям перетаскивать файлы из внешних приложений (таких как проводник Виндоус ) прямо в веб-приложение. Одним из ярких примеров поддержки этой функции является Gmail позволяя таким образом добавлять вложения.

HTML5 позволяет загружать несколько файлов с помощью множественный атрибут на входных элементах.[11]

Альтернатива JavaScript

Одно из решений - использовать клиентские сценарии такие как JavaScript для создания дополнительного элемента управления выбором файла для каждого файла, который пользователь выбирает для загрузки. С помощью CSS, эти дополнительные элементы управления выбором файлов могут быть отключены от отображения. Пример этого метода продемонстрирован в Плагин для загрузки нескольких файлов для jQuery. Таким образом, проблема загрузки нескольких файлов решается за счет предоставления такого количества элементов управления для выбора файлов, сколько у пользователя есть файлов для загрузки. Тем не менее, это не решает проблему выбора нескольких файлов для загрузки в Internet Explorer.

Принять поддержку атрибута

Атрибут accept в настоящее время поддерживается Opera 11+, Chrome 16+, Safari 6+, Firefox 9+ и Microsoft Internet Explorer 10+.

использованная литература

  1. ^ «388784 - (CVE-2007-3511) Уязвимость кражи фокуса ввода файла Firefox». Bugzilla.mozilla.org. Получено 2013-09-02.
  2. ^ "Уязвимость при загрузке файла события Mozilla Firefox OnKeyDown". Juniper.net. 2010-11-15. Архивировано из оригинал на 21.02.2013. Получено 2013-09-02.
  3. ^ «Ссылки на спецификации HTML 4». W3.org. Получено 2013-09-02.
  4. ^ «Формы в HTML-документах». W3.org. Получено 2013-09-02.
  5. ^ а б c «Ввод файла (или« загрузка ») в HTML-формах». Cs.tut.fi. Получено 2013-09-02.
  6. ^ «Спецификация HTML 5.1». W3C.
  7. ^ "тип ввода = объект файла". Msdn2.microsoft.com. 2013-07-22. Получено 2013-09-02.
  8. ^ а б "История браузера: Opera". Blooberry.com. Получено 2013-09-02.
  9. ^ 10 декабря 2009 г. Пол Руже (2009-12-10). "ввод нескольких файлов в Firefox 3.6 ✩ Mozilla Hacks - блог веб-разработчиков". Hacks.mozilla.org. Получено 2013-09-02.
  10. ^ «Использование файлов из веб-приложений - MDC». Developer.mozilla.org. 2013-08-23. Получено 2013-09-02.
  11. ^ Спецификация HTML 5.1: 4.10.5.3 Общие атрибуты элемента ввода

внешние ссылки