前端使用rtsp视频流接入海康威视摄像头的具体步骤

 更新时间:2025年09月16日 09:12:34   作者:啃火龙果的兔子  
这篇文章主要介绍了前端使用rtsp视频流接入海康威视摄像头的具体步骤,前端调用海康威视摄像头的过程中,主要涉及到摄像头的连接、视频流的获取以及前端页面的展示,文中通过代码介绍的非常详细,需要的朋友可以参考下

前言

在纯前端(Vue 2)中直接通过 RTSP 协议接入海康威视摄像头是不可行的,因为:

  1. 浏览器限制:现代浏览器(Chrome、Firefox等)不支持直接播放 RTSP 流(基于 TCP/UDP 的协议)。
  2. 安全策略:浏览器通常禁止直接访问本地网络设备(如摄像头)。

可行的前端解决方案

需要借助中转服务将 RTSP 转成浏览器支持的格式(如 HLS、WebRTC 或 FLV)。以下是具体实现方案:

方案 1:RTSP → WebSocket + flv.js(推荐)

使用 FFmpegNode.js 中转服务 将 RTSP 转成 FLV,前端用 flv.js 播放。

步骤

1. 后端中转服务(Node.js + FFmpeg)

安装 node-rtsp-stream 或自行搭建转流服务:

npm install node-rtsp-stream

示例代码(Node.js 服务端)

const NodeRTSPStream = require('node-rtsp-stream');
const stream = new NodeRTSPStream({
  name: '海康摄像头',
  streamUrl: 'rtsp://admin:password@192.168.1.64:554/Streaming/Channels/101', // 海康 RTSP 地址
  wsPort: 9999, // WebSocket 端口
  ffmpegOptions: { // FFmpeg 转码选项
    '-stats': '',
    '-r': 30,
    '-f': 'flv',
  },
});

注意streamUrl 格式通常为:
rtsp://[用户名]:[密码]@[IP地址]:[端口]/Streaming/Channels/[通道号]
海康默认端口 554,通道号 101 通常代表主码流。

2. 前端 Vue 2 使用flv.js播放

安装 flv.js

npm install flv.js

Vue 组件示例

<template>
  <div>
    <video ref="videoPlayer" controls autoplay muted width="800"></video>
  </div>
</template>

<script>
import flvjs from 'flv.js';

export default {
  mounted() {
    this.initVideo();
  },
  methods: {
    initVideo() {
      if (flvjs.isSupported()) {
        const videoElement = this.$refs.videoPlayer;
        const flvPlayer = flvjs.createPlayer({
          type: 'flv',
          url: 'ws://localhost:9999', // 对应 Node.js 服务的 WebSocket
        });
        flvPlayer.attachMediaElement(videoElement);
        flvPlayer.load();
        flvPlayer.play();
      }
    },
  },
  beforeDestroy() {
    if (this.flvPlayer) {
      this.flvPlayer.destroy();
    }
  },
};
</script>

方案 2:RTSP → HLS(HTTP Live Streaming)

使用 FFmpeg 将 RTSP 转成 HLS(.m3u8 + .ts),前端用 hls.js 播放。

步骤

1. FFmpeg 转码

ffmpeg -i "rtsp://admin:password@192.168.1.64:554/Streaming/Channels/101" \
  -c:v libx264 -c:a aac -f hls \
  -hls_time 2 -hls_list_size 3 -hls_flags delete_segments \
  ./stream/stream.m3u8

2. 前端 Vue 使用hls.js

<template>
  <video ref="videoPlayer" controls></video>
</template>

<script>
import Hls from 'hls.js';

export default {
  mounted() {
    const video = this.$refs.videoPlayer;
    const hls = new Hls();
    hls.loadSource('http://your-server/stream.m3u8');
    hls.attachMedia(video);
    hls.on(Hls.Events.MANIFEST_PARSED, () => {
      video.play();
    });
  },
};
</script>

方案 3:WebRTC 实时流(更复杂,需后端支持)

使用 WebRTC(如 Janus GatewayMediasoup)实现低延迟播放,但需要额外搭建信令服务器。

海康 RTSP 地址格式

海康威视摄像头的 RTSP URL 通常为:

rtsp://[用户名]:[密码]@[IP地址]:[端口]/Streaming/Channels/[通道号]
  • 主码流/Streaming/Channels/101
  • 子码流/Streaming/Channels/102(低分辨率)
  • 默认用户名/密码admin + 设备背面密码

总结

方案技术延迟适用场景
RTSP → WebSocket + flv.jsNode.js + FFmpeg2-5s局域网/内网
RTSP → HLSFFmpeg + hls.js10-30s录播/高兼容
WebRTCJanus/Mediasoup<1s超低延迟

推荐

  • 内网/低延迟flv.js
  • 公网/高兼容HLS

如果有后端支持,可进一步优化(如鉴权、CDN 分发)。

到此这篇关于前端使用rtsp视频流接入海康威视摄像头的文章就介绍到这了,更多相关前端接入海康威视摄像头内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • Vue3结合TypeScript项目开发实战记录

    Vue3结合TypeScript项目开发实战记录

    听说有的公司已经开始用vue3了 赶紧打开B站学一下,下面这篇文章主要给大家介绍了关于Vue3结合TypeScript项目开发实战的相关资料,文中通过示例代码介绍的非常详细,需要的朋友可以参考下
    2021-09-09
  • Electron+Vue实现截屏功能的两种方式

    Electron+Vue实现截屏功能的两种方式

    在Electron环境下,截屏功能相对强大,可以通过desktopCapturer获取应用视频流,实现对整个应用的截屏,而在非Electron环境下,截屏功能受限,只能截取浏览器内容,且存在iframe或base64图片加载问题
    2024-10-10
  • Vue3播放m3u8视频的两种实现方式示例

    Vue3播放m3u8视频的两种实现方式示例

    这篇文章主要介绍了Vue3播放m3u8视频的两种实现方式,两种视频播放器组件分别是vue3-video-play和chimee-player,文中通过代码介绍的非常详细,需要的朋友可以参考下
    2025-01-01
  • Vue组件封装方案实现浅析

    Vue组件封装方案实现浅析

    这篇文章主要介绍了Vue组件封装方案实现,我们将从分析组件封装的优势开始,然后依次介绍 vue.js 的基本概念,以及如何创建、封装和使用自定义组件
    2023-03-03
  • Vue服务端渲染实践之Web应用首屏耗时最优化方案

    Vue服务端渲染实践之Web应用首屏耗时最优化方案

    这篇文章主要介绍了Vue服务端渲染实践之Web应用首屏耗时最优化方案,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2019-03-03
  • Vue自定义加水波纹效果指令实例代码

    Vue自定义加水波纹效果指令实例代码

    这篇文章主要给大家介绍了关于Vue自定义加水波纹效果指令的相关资料,文中通过实例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下
    2022-02-02
  • vue中用js如何实现循环可编辑表格

    vue中用js如何实现循环可编辑表格

    这篇文章主要介绍了vue中用js如何实现循环可编辑表格,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2022-09-09
  • VUE使用draggable实现组件拖拽

    VUE使用draggable实现组件拖拽

    这篇文章主要为大家详细介绍了VUE使用draggable实现组件拖拽,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2022-04-04
  • vue实现分环境打包步骤(给不同的环境配置相对应的打包命令)

    vue实现分环境打包步骤(给不同的环境配置相对应的打包命令)

    这篇文章主要介绍了vue实现分环境打包步骤(给不同的环境配置相对应的打包命令),小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2019-06-06
  • vue实现鼠标滑动展示tab栏切换

    vue实现鼠标滑动展示tab栏切换

    这篇文章主要为大家详细介绍了vue实现鼠标滑动展示tab栏切换,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2022-04-04

最新评论