首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >Webtorrent的流MP4s问题

Webtorrent的流MP4s问题
EN

Stack Overflow用户
提问于 2016-04-03 08:34:07
回答 1查看 1.2K关注 0票数 10

我正在运行一个节点服务器,我想从使用WebTorrent(https://webtorrent.io/docs)的magnet链接上流式传输视频。当我运行这段代码时,即使我设置了一个变量作为.mp4文件,它看起来好像没有正确引用该文件。

为了清楚起见,我在本例中添加了一个给定的torrentID(磁铁链接),以消除我在使用express和URL时可能遇到的任何问题。这个磁性链接可以下载MP4格式的音乐视频。

视频播放器正在显示,但未播放任何视频。我假设这意味着我没有试图访问正确的文件。如果你需要了解更多关于WebTorrent的知识来帮助我,你可以在https://webtorrent.io/docs上阅读它

代码语言:javascript
复制
var fs = require("fs"),
    http = require("http"),
    url = require("url"),
    path = require("path"),
    request = require('request'),
    host = '127.0.0.1',
    port = 3000,
    express = require("express"),
    app = express(),
    server = http.createServer(app),
    WebTorrent = require('webtorrent'),
    client = new WebTorrent();

app.get('/streamvid/:magLink', function(req, res){
    //var torrentID = req.params.magLink;
    var torrentID = 'magnet:?xt=urn:btih:84123E8B4E850A796403736E0CF02E409F0EF00B';


    client.add(torrentID, function (torrent) {  
        var file = torrent.files[0]
        file.name = 'movie.mp4';
        if (req.url != "/movie.mp4") {
            res.writeHead(200, { "Content-Type": "text/html" });
            res.end('<video width="1024" height="768" controls> <source src="movie.mp4" type="video/mp4"> <source src="movie.ogg" type="video/ogg"> Your browser does not support the video tag. </video>');
        } else {
            var range = req.headers.range;
            var positions = range.replace(/bytes=/, "").split("-");
            var start = parseInt(positions[0], 10);

        fs.stat(file, function(err, stats) {
            var total = stats.size;
            var end = positions[1] ? parseInt(positions[1], 10) : total - 1;
            var chunksize = (end - start) + 1;

        res.writeHead(206, {
            "Content-Range": "bytes " + start + "-" + end + "/" + total,
            "Accept-Ranges": "bytes",
            "Content-Length": chunksize,
            "Content-Type": "video/mp4"
        });

        var stream = fs.createReadStream(file, { start: start, end: end })
            .on("open", function() {
                stream.pipe(res);
            }).on("error", function(err) {
                res.end(err);
            });
        });
     }
     })
});

var server = http.createServer(app);

var server = app.listen(port, host);

server.on('error', function(err) {
    console.log('error:' + err);
});

server.on('listening', function(){
    console.log('Server is Up and Running');
});
EN

回答 1

Stack Overflow用户

发布于 2018-06-28 02:29:42

您需要通过读取文件数据来传输数据。

代码语言:javascript
复制
var readFile = fs.createReadStream("path/to/movie.mp4");
readFile.pipe(res);

或者将文件放在公共路径中。app.use(express.static('public'))并将movie.mp4放在app.use(express.static('public'))/文件夹中。然后在你的src中,做一个完整的url链接。http://localhost:3000/movie.mp4

票数 2
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/36380305

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档