Поток видео через Websocket в тег <video>

Я использую Node.js для потоковой передачи через Websocket веб-видео в реальном времени на веб-страницу, которая будет воспроизводить его в теге. Ниже приведен код как сервера, так и клиента:

SERVER:

var io = require('./libs/socket.io').listen(8080, {log:false});
var fs = require('fs');
io.sockets.on('connection', function (socket) 
{
console.log('sono entrato in connection');
var readStream = fs.createReadStream("video.webm");

socket.on('VIDEO_STREAM_REQ', function (req) 
{
    console.log(req);

    readStream.addListener('data', function(data)
    {
        socket.emit('VS',data);
    });

});
});

КЛИЕНТ: Я




 



window.URL = window.URL || window.webkitURL;
window.MediaSource = window.MediaSource || window.WebKitMediaSource;

if(!!! window.MediaSource)
{
    alert('MediaSource API is not available!');
    return;
}

var mediaSource = new MediaSource();    
var video = document.getElementById('v');

video.src = window.URL.createObjectURL(mediaSource);

mediaSource.addEventListener('webkitsourceopen', function(e)
{
    var sourceBuffer = mediaSource.addSourceBuffer('video/webm; codecs="vorbis,vp8"');
    var socket = io.connect('http://localhost:8080');

    if(socket)
        console.log('Library retrieved!');

    socket.emit('VIDEO_STREAM_REQ','REQUEST');

    socket.on('VS', function (data) 
    {
        console.log(data);
        sourceBuffer.append(data);
    });
});






Я использую Chrome 26, и я получаю эту ошибку: "Uncaught Ошибка: InvalidAccessError: Исключение DOM 15 ", Кажется, что тип буфера, переданного методу добавления, неправильный. Я уже пытался преобразовать его в Blob, Array и Uint8Array, но безуспешно.

Ответы на вопрос(1)

Ваш ответ на вопрос