javascript - 从 WebRTC 发送文件后获取文件类型

标签 javascript download webrtc filereader

我正在使用 WebRTC 让两个客户端使用peer.js 进行通信

var peer = new Peer(
{
    key: "XXX",
    config: {"XXX": [{ url: "XXXXXXX" }]}
});

我的主要目标是将文件从一个客户端发送到另一个客户端。为此,我使用以下代码:

$("#box").on("drop", function(e)
{
    e.originalEvent.preventDefault();
    var file = e.originalEvent.dataTransfer.files[0];
    console.log(file);
    connection.send(file);
});

在接收端我使用以下代码:

conn.on("data", function(data)
{
    if (data.constructor === ArrayBuffer)
    {
        var dataView = new Uint8Array(data);
        var dataBlob = new Blob([dataView]);
        var reader = new window.FileReader();
        reader.readAsText(dataBlob); 

        console.log(reader);
    }
}

现在我的问题是我想获取文件类型,以便可以以正确的格式保存它。我正在使用 download.js 保存文件。

最佳答案

除非数据中嵌入了某些文件类型/提示(例如 ZIP、PDF),否则无法从原始数据中获取类型。您还应该创建自己的协议(protocol)来发送文件名。

我所做的是使用 channel 的协议(protocol)属性来设置带有扩展名的文件名来传输这些类型的元数据信息。

请注意,几周前 Chrome 还没有完全支持发送 blob(至少在我的一个示例应用程序中)。

关于javascript - 从 WebRTC 发送文件后获取文件类型,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/29867226/

相关文章:

python请求检查文件是否正确下载

sockets - React-Native:语音聊天

javascript - 根据变量 onclick 更改颜色选择器的值

C# 使用 byte[] 变量后清除系统内存

javascript - 从一个输入到另一个输入动态生成值

r - 尽管有弹出窗口,但仍通过 R 从 Internet 下载文件

html5-video - 使用 HTML5 中的 MediaRecorder API 录制最高质量的视频

javascript - 使用 AudioContext.createMediaStreamSource 与 HTMLAudioElement.srcObject 播放 MediaStream

javascript - jQuery 动画只能工作一次或两次?

javascript - JS : Getting filename from URL - JS seems to carry on working in the background?