Как загрузить файл (вложение) из браузера?
Я не получаю загрузку вложений для работы браузера.
некоторые подсказки здесь, другие здесь. документы довольно хорошо, но я не могу перевести это на загрузку AJAX.
Я ищу супер простой пример HTML / JavaScript (с или без jQuery) о том, как загрузить файл из (относительно современного) браузера в db без использование jquery.проращивать.приложение.в JS-wrapper или вещи. Чем проще Бессер.
любая помощь ценится.
1 ответов
хорошо, вот ваша чистая реализация загрузки файла JavaScript.
основной алгоритм выглядит так:
- получить файл из элемента ввода файла
- получить имя файла и введите off объекта file
- получите последнюю редакцию документа, к которому вы хотите прикрепить файл
- прикрепите файл к документу, используя извлеченную ревизию
HTML-часть в основном состоит из простая форма с двумя элементами, вход типа file
и кнопка типа submit
.
<form action="/" method="post" name="upload">
<input type="file" name="file" />
<button type="submit" name="submit">Upload</button>
</form>
теперь к части JavaScript.
window.onload = function() {
var app = function() {
var baseUrl = 'http://127.0.0.1:5984/playground/';
var fileInput = document.forms['upload'].elements['file'];
document.forms['upload'].onsubmit = function() {
uploadFile('foo', fileInput.files[0]);
return false;
};
var uploadFile = function(docName, file) {
var name = encodeURIComponent(file.name),
type = file.type,
fileReader = new FileReader(),
getRequest = new XMLHttpRequest(),
putRequest = new XMLHttpRequest();
getRequest.open('GET', baseUrl + encodeURIComponent(docName),
true);
getRequest.send();
getRequest.onreadystatechange = function(response) {
if (getRequest.readyState == 4 && getRequest.status == 200) {
var doc = JSON.parse(getRequest.responseText);
putRequest.open('PUT', baseUrl +
encodeURIComponent(docName) + '/' +
name + '?rev=' + doc._rev, true);
putRequest.setRequestHeader('Content-Type', type);
fileReader.readAsArrayBuffer(file);
fileReader.onload = function (readerEvent) {
putRequest.send(readerEvent.target.result);
};
putRequest.onreadystatechange = function(response) {
if (putRequest.readyState == 4) {
console.log(putRequest);
}
};
}
};
};
};
app();
};
в основном, я перехватываю submit
событие формы путем привязки моей собственной функции к форме onsubmit
событие и возврат false.
в этом обработчике событий я вызываю свою основную функцию с двумя параметрами. Первый - это имя документа, а второй - файл для загрузки.
в моем uploadFile()
функция я устанавливаю имя файла, тип файла и хватаю некоторые экземпляры. Первый HTTP-запрос-это запрос GET для получения текущей редакции документа. Если этот запрос будет успешным, я подготовлю запрос PUT (фактический запрос на загрузку), установив ранее полученную ревизию, правильный тип контента, а затем преобразую файл в ArrayBuffer. Как только это будет сделано, я просто отправлю HTTP-запрос, который я только что подготовил, а затем расслаблюсь.
автономная схема загрузки вложений выглядит так:
PUT host/database/document/filename?revision=latest-revision
конечно, используя правильный тип контента в заголовке HTTP-запроса.
примечание: Я хорошо знаю, что я не использую защитное программирование здесь вообще, я сделал это намеренно для краткости.