保存巨大的文件
Saving Huge Files
我需要在JS中保存一个未知大小的文件,可能有多个GB。数据源是使用mediarecorder捕获的媒体流。
在Chrome中,这可以通过使用文件系统和filewriter api和filesystem:url来实现,方法是在收到blob块时将其写入文件条目,然后设置文件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>
用户仍然需要单击下载链接。我还没有试验过这个文件能有多大。
相关文章:
- 如何播放部分音频文件
- 从桌面读取python文件时高亮显示代码
- 使用JS如何动态更改显示的html文件中的文本背景颜色
- 如何使用WCF服务和javascript表单post上传.doc文件
- 当包含另一个asp文件时,是否也包含所有引用的样式和脚本页面
- 如何在生成下载文件时显示加载动画
- 有没有任何方法可以将控制器从文件加载到ui路由器$stateProvider中
- 如何用javascript下载巨大的CSV文件
- D3 Javascript可视化巨大XML文件的性能
- 我可以使用javascript在本地创建和保存一个巨大的文件吗
- 保存巨大的文件
- Browserify生成一个*巨大的*输出文件
- 用PHP或任何其他语言上传巨大的文件
- 如何通过javascript或jquery读取一个巨大的文本文件
- 使用Javascript FileReader处理巨大的文件
- 充满事件处理程序的巨大文件!如何在AJAX web应用程序中组织一个大型jQuery文件
- 解析巨大的xml文件原生vs javascript
- 如何使用 php 有效地将一个巨大的 JavaScript 字符串存储到文件中
- 在Node.js中解析巨大的二进制文件
- Angularjs获取一个巨大json文件的请求