Реализация скрипта node.js для добавления медиаплеера в веб-интерфейс Kodi

Я пытаюсь реализовать ответ на немного другой вопрос отсюда: Как для потоковой передачи видео в браузер с помощью Kodi

пользователь stackoverflow @YRabl без голосования, озаглавленный Я изменил веб-интерфейс Chorus, чтобы разрешить потоковую передачу с помощью процесса nodejs в фоновом режиме. дает полный сценарий, а также необходимые моды к существующему интерфейсу.

Однако я понятия не имею, как вставить скрипт .js в процесс открытия локального URL-адреса, и когда я пытаюсь просто запустить сам скрипт, он выдает следующие ошибки:

app.listen(<8080>, function () {
       ^
SyntaxError: Unexpected token <
at Module._compile (internal/modules/cjs/loader.js:723:23)
at Object.Module._extensions..js (internal/modules/cjs/loader.js:789:10)
at Module.load (internal/modules/cjs/loader.js:653:32)
at tryModuleLoad (internal/modules/cjs/loader.js:593:12)
at Function.Module._load (internal/modules/cjs/loader.js:585:3)
at Function.Module.runMain (internal/modules/cjs/loader.js:831:12)
at startup (internal/bootstrap/node.js:283:19)
at bootstrapNodeJSCore (internal/bootstrap/node.js:623:3)

У меня абсолютно нулевой опыт работы с node.js. Может ли кто-нибудь помочь мне расшифровать то, что я вижу, и как правильно реализовать это решение? Первоначальная ветка старше 4 лет вряд ли воскреснет. Любая помощь приветствуется. Спасибо заранее!

Для простоты вот оригинальный скрипт .js:

const express = require('express')
const fs = require('fs')
const path = require('path')
const app = express()
const url = require('url')
const gracefulFs = require('graceful-fs')
gracefulFs.gracefulify(fs)

app.get('/video', function(req, res) {
  var q = url.parse(req.url, true).query;
  var filepath = q.src;
  fs.stat(filepath, function(err, stats){
    if (err){
        if (err.code === 'ENOENT'){
            //404 Error if file not found
            res.writeHead(404, {
                "Accept-Ranges" : "bytes",
                "Content-Range" : "bytes " + start + "-" + end + "/" + total,
                "Content-Length" : chunksize,
                "Content-Type" : "video/mp4"
            });
        }
        res.end(err);
    }
    
    var start;
    var end;
    var chunksize;
    var total = stats.size;
    
    var range = req.headers.range;
    if (range) {
        var parts = range.replace(/bytes=/, "").split("-");
        start = parseInt(parts[0], 10);
        end = parts[1] ? parseInt(parts[1], 10) : total - 1;
    } else {
        start = 0;
        end = total - 1;
    }
    
    if (start > end || start < 0 || end > total - 1){
        //error 416 is "Range Not Satisfiable"
        res.writeHead(416, {
            "Accept-Ranges" : "bytes",
            "Content-Range" : "*/" + stats.size,
            "Content-Type" : "video/mp4"
        });
        res.end();
        return;
    }
    
    if (start == 0 && end == (total -1)){
        res.writeHead(200, {
            'Accept-Ranges': 'bytes',
            'Content-Range': `bytes ${start}-${end}/${total}`,
            'Content-Length': total,
            'Content-Type': 'video/mp4'
        });
    } else {
        chunksize = (end - start) + 1;
        res.writeHead(206, {
            'Content-Range': `bytes ${start}-${end}/${total}`,
            'Accept-Ranges': 'bytes',
            'Content-Length': chunksize,
            'Content-Type': 'video/mp4'
        });
    }
    var stream = fs.createReadStream(filepath, {
        start : start, 
        end : end
    }).on("open", function() {
        stream.pipe(res);
    }).on("error", function(err) {
        console.log(err);
        res.end(err);
    });
  });
});

app.listen(<port>, function () {
  console.log('Listening on port <port>!');
});


person macphail    schedule 30.04.2021    source источник


Ответы (1)


Ошибка, которую вы получаете, связана с тем, что вы не заменили заполнитель <port> фактическим портом в последних трех строках кода.

person Jiří Cihelka    schedule 30.04.2021
comment
спасибо за это... чувак, поговорим о чрезмерном размышлении. оценил. Ошибка изменилась. это слишком долго для комментария, я обновил исходный пост. мысли? - person macphail; 01.05.2021
comment
Вам также нужно удалить ‹›, они также были частью заполнителя. - person Jiří Cihelka; 01.05.2021