gpt4 book ai didi

javascript - 如何使用 Node 将视频发送到客户端 JavaScript blob,然后显示它?

转载 作者:搜寻专家 更新时间:2023-10-31 22:54:42 25 4
gpt4 key购买 nike

我想向客户端发送一个视频文件并使用.createObjectURL() 显示视频。

Node 服务器.js:

var fs = require("fs"),
http = require("http");

http.createServer(function (req, res) {

if (req.url == "/") {
res.writeHead(200, { "Content-Type": "text/html" });

res.end('<video id="video" src="" autoplay controls loop width="200px" height="200px" muted></video>' +
'<script src="https://code.jquery.com/jquery-2.1.4.min.js"></script>' +
'<script src="blobvideo.js"></script>');
}

else if (req.url == "/blobvideo.js") {
res.writeHead(200, { "Content-Type": "application/javascript" });
fs.readFile('./blobvideo.js', function(err, data) {
res.end(data.toString());
});

}

else if (req.url == "/video") {
fs.readFile('video.mp4', function(err, data) {
res.end(data);
});
}
}).listen(3000);

客户端 blobvideo.js:

$.ajax( "/video" ).done(function(data) {
var ab = new ArrayBuffer(data.length);
var view = new Uint8Array(ab);

for(var i = 0; i < data.length; ++i) {
view[i] = data[i];
}

blob = new Blob([ab], { type: "video/mp4" });
document.getElementById("video").src = (window.URL || window.webkitURL).createObjectURL(blob);
});

在这段代码中,视频是一次性全部发送出去的,视频没有播放。我的问题:

  1. 如何解决此问题以播放视频?

  2. 如何更改它以流式传输文件而不是等待整个视频下载?

编辑澄清

我想在客户端使用 Blob.createObjectURL() 因为我正在尝试构建 WebRTC RTCPeerConnection 的点对点视频实现,所以静态视频数据可以从客户端发送到另一个客户端,而无需通过服务器发送。

最佳答案

这是纯 nodejs javascript,无需外部库依赖即可流式传输视频/音频,并且不需要客户端代码...使用以下方式启动它:

node this_code.js

然后将您的客户端浏览器指向

http://localhost:8888

巨大的好处是浏览器客户端视频渲染 UI 小部件可以正常工作——(能够跳转到某个随机媒体位置等)

var http = require('http'),
fs = require('fs'),
util = require('util');

// put any audio or video file here
var path = "/path/to/audio/or/video/file/local/to/server/cool.mp4";

var port = 8888;
var host = "localhost";

http.createServer(function (req, res) {

var stat = fs.statSync(path);
var total = stat.size;

if (req.headers.range) {

// meaning client (browser) has moved the forward/back slider
// which has sent this request back to this server logic ... cool

var range = req.headers.range;
var parts = range.replace(/bytes=/, "").split("-");
var partialstart = parts[0];
var partialend = parts[1];

var start = parseInt(partialstart, 10);
var end = partialend ? parseInt(partialend, 10) : total-1;
var chunksize = (end-start)+1;
console.log('RANGE: ' + start + ' - ' + end + ' = ' + chunksize);

var file = fs.createReadStream(path, {start: start, end: end});
res.writeHead(206, { 'Content-Range': 'bytes ' + start + '-' + end + '/' + total, 'Accept-Ranges': 'bytes', 'Content-Length': chunksize, 'Content-Type': 'video/mp4' });
file.pipe(res);

} else {

console.log('ALL: ' + total);
res.writeHead(200, { 'Content-Length': total, 'Content-Type': 'video/mp4' });
fs.createReadStream(path).pipe(res);
}
}).listen(port, host);

console.log("Server running at http://" + host + ":" + port + "/");

享受,

关于javascript - 如何使用 Node 将视频发送到客户端 JavaScript blob,然后显示它?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/32429708/

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