当前位置: 移动技术网 > IT编程>开发语言>JavaScript > nodejs实现大文件(在线视频)的读取

nodejs实现大文件(在线视频)的读取

2018年03月01日  | 移动技术网IT编程  | 我要评论

nodejs进行视频读取时不能像读取图片之类的一次性读取,而是必须读取一部分返回一部分,这样客户端的播放才会边缓冲边播放,而不必等待全部缓冲完再播放。

老规矩,直接贴代码讲解:

var fs = require('fs'); 

function readbigfileentry(filename, response) { 
path.exists(filename, function(exists) { 
if (!filename || !exists) { 
response.writehead(404); 
response.end(); 
return; 
} 

var readstream = fs.readstream(filename); 

var contenttype = 'none'; 
var ext = path.extname(filename); 
switch (ext) { 
case ".flv": 
contenttype = "video/flv"; 
break; 
} 

response.writehead(200, { 
'content-type' : contenttype, 
'accept-ranges' : 'bytes', 
'server' : 'microsoft-iis/7.5', 
'x-powered-by' : 'asp.net' 
}); 



readstream.on('close', function() { 
response.end(); 
console.log("stream finished."); 
}); 
readstream.pipe(response); 
}); 
}

通过fs模块的readstream方法,拿到视频流,然后绑定关闭事件:当流读取到结尾的时候结束response请求,最后通过pipe方法进行小块小块的读取。这里的head信息不能添加content-length属性,因为必须分段读取,如果加了这个属性,浏览器就会以为请求结束了从而关闭请求。

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持移动技术网。

如对本文有疑问, 点击进行留言回复!!

相关文章:

验证码:
移动技术网