使用 Node Media Server 将 IP cam 的 RTSP 重新流式传输到 http/ws 并以 html 形式显示

Hau*_* TM 6 html javascript url rtsp node.js

目标

我的目标是在标准 HTML 页面(html5 + css3 + vanilla javascript,无魔法 = 无插件)上显示 IP 摄像头的 RTSP 输出流。HTML 页面应托管在我的 Raspberry Pi 上的 NGINX Web 服务器中。

我的装备

我使用的设置是 Raspberry Pi 3 B+,带有 Rasbian OS、Node.js 和Node-Media-Server 包、NGINX(但我不认为 N​​GINX 对我的问题很重要?我还没有为 Node 进行任何配置- 无论如何,其中包含媒体服务器。)一个 IP 摄像机和一个浏览器。 在此输入图像描述

我尝试过的

Node-Media-Server-project 中的自述文件很详细,并且有一个教程几乎准确地描述了我想要做的事情。具体来说,有一个关于如何访问实时流的标记示例:

<html>

<head>
    <title>Camera</title>
</head>

<body>
    <script src="https://cdn.bootcss.com/flv.js/1.4.0/flv.min.js"></script>
    <video id="videoElement"></video>
    <script>
        if (flvjs.isSupported()) {
            var videoElement = document.getElementById('videoElement');
            var flvPlayer = flvjs.createPlayer({
                type: 'flv',
                url: 'http://localhost:8000/live/uterum.flv'
            });
            flvPlayer.attachMediaElement(videoElement);
            flvPlayer.load();
            flvPlayer.play();
        }
    </script> 
</body>

</html>
Run Code Online (Sandbox Code Playgroud)

这就是我在 Raspberry PI 上启动媒体服务器的方法kommandoran-mediaserver.js

const { NodeMediaServer } = require('node-media-server');

const config = {
    logType: 3, // 3 - Log everything (debug)
    rtmp: {
        port: 1935,
        chunk_size: 60000,
        gop_cache: true,
        ping: 60,
        ping_timeout: 30
    },
    http: {
        port: 8000,
        allow_origin: '*'
    },
    relay: {
        ffmpeg: '/usr/local/bin/ffmpeg',
        tasks: [
            {
                app: 'cctv',
                mode: 'static',
                edge: 'rtsp://<USER>:<PASSWORD>@10.0.0.111/live1.sdp',
                name: 'uterum',
                rtsp_transport : 'tcp' //['udp', 'tcp', 'udp_multicast', 'http']
            }
        ]
    }
};

var nms = new NodeMediaServer(config)
nms.run();
Run Code Online (Sandbox Code Playgroud)

我的问题和疑问

当我尝试camera.html通过 Raspberry Pi(即本地主机)上的 Chromium 浏览器查看(参见上面的标记)时,没有显示任何内容。在 Chromium 调试检查器中没有 javascript 错误,但我得到了这个:
GET http://localhost:8000/live/uterum.flv net::ERR_EMPTY_RESPONSE

这是节点终端的屏幕截图: 在此输入图像描述 红色区域说明了当我尝试向 发出请求时的输出http://localhost:8000/live/uterum.flv

我想我尝试到达错误的终点,但哪个是正确的?文档指出http://localhost:8000/live/STREAM_NAME.flv。在我的例子中, “”是什么STREAM_NAME

小智 3

从配置中可以看到,您的 RTSP 流被推送到 \xe2\x80\x98cctv\xe2\x80\x99 应用程序。

\n

所以你的播放地址应该是:

\n
rtmp://localhost/cctv/uterum\n
Run Code Online (Sandbox Code Playgroud)\n

或者

\n
http://localhost:8000/cctv/uterum.flv\n
Run Code Online (Sandbox Code Playgroud)\n