2017-02-16 11 views
0

Я загрузил много аудиозаписей на свой сервер. Каждая запись имеет продолжительность около 45 мин. Я хотел бы воспроизводить эти файлы на своем веб-сайте, например youtube, но только в аудиоформате. Я использую API веб-аудио, и я слышал о локальном хранилище html5. Лучше ли использовать это локальное хранилище html или воспроизводить файлы непосредственно из хранилища сервера? Как играть файл с абсолютного пути на сервере, где хранится мой сайт? Можно ли это сделать с помощью xmlHttpRequest или что?Каков наилучший способ воспроизведения аудиофайлов, хранящихся на серверной машине?

ответ

0

Это полностью функционирующий nodejs сервер может дать вам некоторую тягу ... сохранить следующий код на сервере в качестве media_server.js файла

// usage 
// node this_file.js 


var http = require('http'), 
    fs = require('fs'), 
    util = require('util'); 

// var path = "/path/to/audio/or/video/file/local/to/server/cool.mp4"; // put any audio or video file here 
var path = "/home/stens/Dropbox/Documents/data/audio/Justice_Genesis_first_10_seconds_june.flac"; 

var port = 8888; 
var host = "localhost"; // update if using a real server not your laptop 

http.createServer(function (req, res) { 

    var stat = fs.statSync(path); 
    var total = stat.size; 

    if (req.headers.range) { // meaning client (browser) has moved the forward/back slider 
          // which has sent this request back to this server logic ... cool 
    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; 
    console.log('RANGE: ' + start + ' - ' + end + ' = ' + chunksize); 

    var file = fs.createReadStream(path, {start: start, end: end}); 
    res.writeHead(206, { 'Content-Range': 'bytes ' + start + '-' + end + '/' + total, 'Accept-Ranges': 'bytes', 'Content-Length': chunksize, 'Content-Type': 'video/mp4' }); 
    file.pipe(res); 

    } else { 

    console.log('ALL: ' + total); 
    res.writeHead(200, { 'Content-Length': total, 'Content-Type': 'video/mp4' }); // muck with making this dynamically match source media type 
    fs.createReadStream(path).pipe(res); 
    } 
}).listen(port, host); 

console.log("Server running at http://" + host + ":" + port + "/"); 

затем выполнить его путем выдачи nodejs вызова на стороне сервера (ваш ноутбук прекрасно работает здесь ;-)

node media_server.js 

, который будет раскручивать сервер прослушивания выбранного порта 8888 ... теперь просто указать свой браузер на этот хост и порт, как в URL

http://localhost:8888/

и будет течь (не загружать) средства массовой информации на ваш браузер и сделать аудио или видео ... наслаждаться

+0

Это хорошо, но у меня есть вся раскладка написана и мой заказ аудиоплеер, но Основная проблема заключается в том, что клиенту нужно дождаться загрузки файла в браузер, поэтому время отклика плохое. Могу ли я сохранить макет и мой аудиоплеер, но сразу же начните аудио. Вы можете посмотреть здесь http://naucikako.com/audio/RTI/3/SS/V/2013-2014/3-dvocas/1?id=557 –