gpt4 book ai didi

javascript - 保存大文件

转载 作者:行者123 更新时间:2023-11-29 14:42:55 24 4
gpt4 key购买 nike

我需要在 JS 中保存一个未知大小的文件,可能有数 GB。数据源是使用 mediarecorder 捕获的媒体流。

在 Chrome 中,这可以使用文件系统和文件编写器 api 与文件系统来完成:通过在收到 blob block 时将 blob block 写入文件条目,然后将下载链接设置为文件 url。

但是,我找不到在 Firefox 或 Edge 中执行此操作的方法(无论何时获取 mediarecorder)。

最佳答案

这在 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>

用户仍然需要点击下载链接。我还没有试验过文件可以有多大。

关于javascript - 保存大文件,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/36317046/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com