节点 - 无法寻找音频流
Node - Can't seek audio stream
我创建了一个简单的服务器,它使用 fs 模块将 mp3 文件流式传输到浏览器,浏览器在 html5 音频元素中播放它。事实上,音频流非常好,但是,我无法通过流进行搜索,即使我搜索的部分已经被缓冲。
var express = require('express');
var app = express();
var fs = require('fs');
app.get('/', function (req, res) {
var filePath = 'music.mp3';
var stat = fs.statSync(filePath);
res.writeHead(200, {
'Content-Type': 'audio/mpeg',
'Content-Length': stat.size,
});
var readStream = fs.createReadStream(filePath);
readStream.pipe(res);
});
其他类似的问答已建议添加 Content-Range header,但我找不到如何执行此操作的简单示例。其他人说使用 206 Partial-Content header,但当我这样做时,音频根本无法播放。
这是 demo(在 windows 上 chrome 上测试)
根据 this question 中未接受的答案之一调整代码:
var express = require('express'),
fs = require('fs'),
app = express()
app.get('/', function (req, res) {
var filePath = 'music.mp3';
var stat = fs.statSync(filePath);
var total = stat.size;
if (req.headers.range) {
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;
var readStream = fs.createReadStream(filePath, {start: start, end: end});
res.writeHead(206, {
'Content-Range': 'bytes ' + start + '-' + end + '/' + total,
'Accept-Ranges': 'bytes', 'Content-Length': chunksize,
'Content-Type': 'audio/mpeg'
});
readStream.pipe(res);
} else {
res.writeHead(200, { 'Content-Length': total, 'Content-Type': 'audio/mpeg' });
fs.createReadStream(filePath).pipe(res);
}
});
我创建了一个简单的服务器,它使用 fs 模块将 mp3 文件流式传输到浏览器,浏览器在 html5 音频元素中播放它。事实上,音频流非常好,但是,我无法通过流进行搜索,即使我搜索的部分已经被缓冲。
var express = require('express');
var app = express();
var fs = require('fs');
app.get('/', function (req, res) {
var filePath = 'music.mp3';
var stat = fs.statSync(filePath);
res.writeHead(200, {
'Content-Type': 'audio/mpeg',
'Content-Length': stat.size,
});
var readStream = fs.createReadStream(filePath);
readStream.pipe(res);
});
其他类似的问答已建议添加 Content-Range header,但我找不到如何执行此操作的简单示例。其他人说使用 206 Partial-Content header,但当我这样做时,音频根本无法播放。
这是 demo(在 windows 上 chrome 上测试)
根据 this question 中未接受的答案之一调整代码:
var express = require('express'),
fs = require('fs'),
app = express()
app.get('/', function (req, res) {
var filePath = 'music.mp3';
var stat = fs.statSync(filePath);
var total = stat.size;
if (req.headers.range) {
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;
var readStream = fs.createReadStream(filePath, {start: start, end: end});
res.writeHead(206, {
'Content-Range': 'bytes ' + start + '-' + end + '/' + total,
'Accept-Ranges': 'bytes', 'Content-Length': chunksize,
'Content-Type': 'audio/mpeg'
});
readStream.pipe(res);
} else {
res.writeHead(200, { 'Content-Length': total, 'Content-Type': 'audio/mpeg' });
fs.createReadStream(filePath).pipe(res);
}
});