Ich habe mit binären Streams in Node.js experimentiert, und zu meinem Erstaunen habe ich tatsächlich eine funktionierende Demo, einen Shoutcast-Stream mit Node-Radio-Stream aufzunehmen und schieben Sie es in ein HTML5-Element mit Chunked-Codierung. Aber es funktioniert nur in Safari!Streaming von Audio von einem Node.js-Server nach HTML5
Hier ist mein Server-Code:
var radio = require("radio-stream");
var http = require('http');
var url = "http://67.205.85.183:7714";
var stream = radio.createReadStream(url);
var clients = [];
stream.on("connect", function() {
console.error("Radio Stream connected!");
console.error(stream.headers);
});
// When a chunk of data is received on the stream, push it to all connected clients
stream.on("data", function (chunk) {
if (clients.length > 0){
for (client in clients){
clients[client].write(chunk);
};
}
});
// When a 'metadata' event happens, usually a new song is starting.
stream.on("metadata", function(title) {
console.error(title);
});
// Listen on a web port and respond with a chunked response header.
var server = http.createServer(function(req, res){
res.writeHead(200,{
"Content-Type": "audio/mpeg",
'Transfer-Encoding': 'chunked'
});
// Add the response to the clients array to receive streaming
clients.push(res);
console.log('Client connected; streaming');
});
server.listen("8000", "127.0.0.1");
console.log('Server running at http://127.0.0.1:8000');
Code Mein Kunde ist einfach:
<audio controls src="http://localhost:8000/"></audio>
Dies funktioniert in Safari 5 auf dem Mac in Ordnung, aber scheint nicht, etwas in Chrome zu tun oder Firefox. Irgendwelche Ideen?
Mögliche Kandidaten einschließlich Codierung Fragen, oder nur teilweise umgesetzt HTML5-Funktionen ...
Haben Sie das schon einmal gemacht? – abeger
Ja, sehen Sie sich Nates Antwort unten für weitere Informationen an. –
+1 Ausgezeichnete Arbeit. –