Сохранение огромных файлов
Мне нужно сохранить файл неизвестного размера, потенциально несколько гигабайт, в JS. Источник данных - это медиапоток, захваченный с помощью медиа-рекордера.
В Chrome это может быть достигнуто с помощью файловой системы и файловой системы apis с файловой системой: URL-адреса путем записи кусочков больших двоичных объектов в запись файла по мере их получения, а затем путем установки ссылки на скачивание для URL-адреса файла.
Тем не менее, я не могу найти способ сделать это в Firefox или Edge (всякий раз, когда он получает медиа-рекордер).
1 ответ
Это работает для меня в Firefox:
navigator.mediaDevices.getUserMedia({ video: true })
.then(stream => record(stream, 5000)
.then(recording => {
stop(stream);
video.src = link.href = URL.createObjectURL(new Blob(recording));
link.download = "recording.webm";
link.innerHTML = "Download blob";
log("Playing "+ recording[0].type +" recording.");
})
.catch(log).then(() => stop(stream)))
.catch(log);
var record = (stream, ms) => {
var rec = new MediaRecorder(stream), data = [];
rec.ondataavailable = e => data.push(e.data);
rec.start();
log(rec.state + " for "+ (ms / 1000) +" seconds...");
var stopped = new Promise((r, e) => (rec.onstop = r, rec.onerror = e));
return Promise.all([stopped, wait(ms).then(() => rec.stop())])
.then(() => data);
};
var stop = stream => stream.getTracks().forEach(track => track.stop());
var wait = ms => new Promise(resolve => setTimeout(resolve, ms));
var log = msg => div.innerHTML += "<br>" + msg;
<video id="video" height="120" width="160" autoplay></video>
<a id="link"></a><br>
<div id="div"></div>
Пользователь все еще должен нажать на ссылку для скачивания. Я не экспериментировал с тем, насколько большим может быть файл.