欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

前端使用rtsp視頻流接入??低晹z像頭的具體步驟

 更新時(shí)間:2025年09月16日 09:12:34   作者:啃火龍果的兔子  
這篇文章主要介紹了前端使用rtsp視頻流接入海康威視攝像頭的具體步驟,前端調(diào)用??低晹z像頭的過程中,主要涉及到攝像頭的連接、視頻流的獲取以及前端頁面的展示,文中通過代碼介紹的非常詳細(xì),需要的朋友可以參考下

前言

在純前端(Vue 2)中直接通過 RTSP 協(xié)議接入??低晹z像頭是不可行的,因?yàn)椋?/p>

  1. 瀏覽器限制:現(xiàn)代瀏覽器(Chrome、Firefox等)不支持直接播放 RTSP 流(基于 TCP/UDP 的協(xié)議)。
  2. 安全策略:瀏覽器通常禁止直接訪問本地網(wǎng)絡(luò)設(shè)備(如攝像頭)。

可行的前端解決方案

需要借助中轉(zhuǎn)服務(wù)將 RTSP 轉(zhuǎn)成瀏覽器支持的格式(如 HLS、WebRTC 或 FLV)。以下是具體實(shí)現(xiàn)方案:

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

使用 FFmpegNode.js 中轉(zhuǎn)服務(wù) 將 RTSP 轉(zhuǎn)成 FLV,前端用 flv.js 播放。

步驟

1. 后端中轉(zhuǎn)服務(wù)(Node.js + FFmpeg)

安裝 node-rtsp-stream 或自行搭建轉(zhuǎn)流服務(wù):

npm install node-rtsp-stream

示例代碼(Node.js 服務(wù)端)

const NodeRTSPStream = require('node-rtsp-stream');
const stream = new NodeRTSPStream({
  name: '??禂z像頭',
  streamUrl: 'rtsp://admin:password@192.168.1.64:554/Streaming/Channels/101', // 海康 RTSP 地址
  wsPort: 9999, // WebSocket 端口
  ffmpegOptions: { // FFmpeg 轉(zhuǎn)碼選項(xiàng)
    '-stats': '',
    '-r': 30,
    '-f': 'flv',
  },
});

注意streamUrl 格式通常為:
rtsp://[用戶名]:[密碼]@[IP地址]:[端口]/Streaming/Channels/[通道號(hào)]
??的J(rèn)端口 554,通道號(hào) 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', // 對(duì)應(yīng) Node.js 服務(wù)的 WebSocket
        });
        flvPlayer.attachMediaElement(videoElement);
        flvPlayer.load();
        flvPlayer.play();
      }
    },
  },
  beforeDestroy() {
    if (this.flvPlayer) {
      this.flvPlayer.destroy();
    }
  },
};
</script>

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

使用 FFmpeg 將 RTSP 轉(zhuǎn)成 HLS(.m3u8 + .ts),前端用 hls.js 播放。

步驟

1. FFmpeg 轉(zhuǎn)碼

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 實(shí)時(shí)流(更復(fù)雜,需后端支持)

使用 WebRTC(如 Janus GatewayMediasoup)實(shí)現(xiàn)低延遲播放,但需要額外搭建信令服務(wù)器。

???RTSP 地址格式

海康威視攝像頭的 RTSP URL 通常為:

rtsp://[用戶名]:[密碼]@[IP地址]:[端口]/Streaming/Channels/[通道號(hào)]
  • 主碼流/Streaming/Channels/101
  • 子碼流/Streaming/Channels/102(低分辨率)
  • 默認(rèn)用戶名/密碼admin + 設(shè)備背面密碼

總結(jié)

方案技術(shù)延遲適用場(chǎng)景
RTSP → WebSocket + flv.jsNode.js + FFmpeg2-5s局域網(wǎng)/內(nèi)網(wǎng)
RTSP → HLSFFmpeg + hls.js10-30s錄播/高兼容
WebRTCJanus/Mediasoup<1s超低延遲

推薦

  • 內(nèi)網(wǎng)/低延遲flv.js
  • 公網(wǎng)/高兼容HLS

如果有后端支持,可進(jìn)一步優(yōu)化(如鑒權(quán)、CDN 分發(fā))。

到此這篇關(guān)于前端使用rtsp視頻流接入??低晹z像頭的文章就介紹到這了,更多相關(guān)前端接入??低晹z像頭內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

最新評(píng)論