谷歌瀏覽器中預覽海康大華等監控視頻的思路與方法

来源:https://www.cnblogs.com/Mo-MaTure/archive/2020/04/28/12793960.html
-Advertisement-
Play Games

隨著現代社會不斷發展,對於安防行業的需求也越來越多。 近年來,各大安防廠商如雨後春筍一般不斷涌現,以視頻監控為主的海康、大華、宇視;以門禁為主的鈕貝爾等。 各大平臺也都在介入安防行業,像阿裡,騰訊的數字城市。其他各種針對安防行業的解決方案也是層出不窮,如雪亮工程,智慧交通,智慧社區等等。 如今安防行 ...


隨著現代社會不斷發展,對於安防行業的需求也越來越多。

近年來,各大安防廠商如雨後春筍一般不斷涌現,以視頻監控為主的海康、大華、宇視;以門禁為主的鈕貝爾等。

各大平臺也都在介入安防行業,像阿裡,騰訊的數字城市。其他各種針對安防行業的解決方案也是層出不窮,如雪亮工程,智慧交通,智慧社區等等。

如今安防行業應用的存在於各行各業中,各種安防設備也是五花八門,層出不窮,但目前視頻監控仍是最主要的市場。

 

本人近些年來對海康,大華,宇視等視頻廠商做過一些視頻對接的開發,但始終存在一個問題,在谷歌瀏覽器中如何進行視頻監控的預覽。

本文將主要解決在谷歌,火狐等非IE瀏覽器中預覽視頻監控問題,給廣大開發者提供一個思路方法。


在此之前本人也百度過很多方案,但效果都不是很好,多多少少都存在些問題。

文中將這些方法進行了一個大概的彙總,以便供大家參考。

 

在軟體開發中分為 C/S 架構和 B/S 架構,即客戶端程式與網頁端程式。

客戶端在對接監控視頻時比較方便也比較簡單,直接對接廠商的視頻控制項或是 SDK 就可以了。

網頁端最常用的就是通過廠商平臺的視頻控制項進行預覽回放,這種通過視頻控制項的方式優點有很多,比如穩定性強,可使用視頻控制項進行錄像,截圖,雲台控制等操作。

但是網頁端調用視頻控制項有一個比較嚴重的問題,只支持IE瀏覽器。

視頻控制項一般都是 OCX 的組件,註冊到註冊表中後頁面通過 ActiveXObject 進行創建並調用裡面的方法。

現在谷歌瀏覽器中現已不支持 ActiveXObject 的創建及調用,這是由於 chrome 瀏覽器在 45 版本後不再提供對 npapi 插件的支持。

網上也有一些手動啟動 npapi 的方法,但是操作比較繁瑣,不可能針對用戶去大面積鋪開使用。

 

針對谷歌瀏覽器預覽視頻監控的方法大概有以下幾種

1.使用 ffmpeg

地址:https://blog.csdn.net/weixin_43237948/article/details/89308678

該方案是將 RTSP 視頻轉成 HLS 格式,前端通過第三方js再去從服務中取流。

這種方式在配置的這部分相對來說比較複雜,而且網上相關的資料也不是很多。

 

2.VLC控制項進行

安裝 VLC 客戶端,直接在瀏覽器中調用 VLC 的視頻控制項,通過監控視頻 RTSP 串流進行預覽。

該方式調用時比較方便,在360安全瀏覽器的極速模式下是可運行的,但是在谷歌瀏覽器依舊因為插件的原因不能預覽

 

3.WebSocket視頻流轉發

開發一個服務端,通過攝像頭的設備 SDK 去取流,在將視頻流通過 WebSocket 發送到前端頁面,頁面中再將獲取到的視頻流繪製到 DIV 中。

參考地址:https://download.csdn.net/download/qq30886226/10617007

該方式對於瀏覽器端壓力較大,而且視頻畫面也會出現丟幀模糊的現象。多個視頻調用時服務端的壓力也會過大甚至崩掉。

 

以上三種方式是題主在開發過程中所接觸到的一些方法,這幾個方法都有一個共同的問題,視頻預覽相對來說容易,但錄像回放的功能不太好實現。

 

題主最近發現一種新的方式,這中方式可以較好的解決大部分瀏覽器預覽視頻監控中的問題,其中包括回放,錄像抓圖,雲台控制等。

思路很簡單

1、開發一個客戶端程式,用程式去對接視頻監控(推薦使用廠商自己的視頻控制項)。

2、客戶端程式啟動一個 WebSocket 服務。

3、網頁中連接 WebSocket 服務,通過 WebSocket 發送消息。客戶端收到消息解析後在進行相對應的操作。

 

這種方式基本上解決了現有瀏覽器預覽監控視頻的絕大部分問題。

1、瀏覽器支持:WebSocket 是 HTML5 開始提供的一種在單個 TCP 連接上進行全雙工通訊的協議,,只要是支持HTML5,WebSocket就可以使用。

2、穩定性,功能完整性:因為客戶端是調用的廠商視頻控制項,所以無論是在取流的穩定性,視頻清晰度等各個方面,肯定要比自己去取流在做操作方便的多。而且大部分視頻控制項都是包括一些功能,例如雲台控制、抓圖、錄像等操作。

 

這種方式題主已經測試成功並且已應用在項目上。

各大廠商自己個視頻控制項能在谷歌瀏覽器上運行其實也是這個原理,通過 WebSocket 來操作視頻客戶端。

 


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 一、包括下線數字(lower)不包括上限數字(upper) /** * 產生隨機整數,包含下限值,但不包括上限值 * @param {Number} lower 下限 * @param {Number} upper 上限 * @return {Number} 返回在下限到上限之間的一個隨機整數 */ ...
  • 今天來和大家講講web前端開發需要學習什麼?前端開發又需要用到哪些開發工具?然後也簡單的和大家介紹下前端開發的前景和薪水工資情況,下麵就簡單和大家介紹一下。 web前端的職能 web前端工程師其實在不同的公司,有不同的職能,但是稱呼都是類似的。 1.做網站設計、網頁界面開發 2.做網頁界面開發 3. ...
  • Javascript怎麼得到數組長度(也就是數組的元素個數)? Javascript怎麼獲取對象的成員個數? 你肯定想到了array.length!? 那麼我們來測試一下下麵這個例子. <script type="text/javascript"> var a = []; a[50] = 50; a ...
  • // 生成隨機姓名和性別 function getName(){ var familyNames = new Array("趙", "錢", "孫", "李", "周", "吳", "鄭", "王", "馮", "陳", "褚", "衛", "蔣", "沈", "韓", "楊", ...
  • JavaScript使用setTimeout函數做出計時效果: <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <meta name="viewport" content="width=device-width, init ...
  • 寫在前面 這一講是 Vuex 基礎篇的最後一講,也是最為複雜的一講。如果按照官方來的話,對於新手可能有點難以接受,所以想了下,決定乾脆多花點時間,用一個簡單的例子來講解,順便也複習一下之前的知識點。 首先還是得先瞭解下 Module 的背景。我們知道,Vuex 使用的是單一狀態樹,應用的所有狀態會集 ...
  • 上一篇只是大概介紹了一下斷路器Hystrix Dashboard監控,如何使用Hystrix Dashboard監控微服務的狀態呢?這篇看看Ribbon如何整合斷路器監控Hystrix Dashboard。今天的項目主要整合sc-eureka-client-consumer-ribbon-hystr ...
  • 設計模式簡介 設計模式(Design pattern)代表了最佳的實踐,通常被有經驗的面向對象的軟體開發人員所採用。設計模式是軟體開發人員在軟體開發過程中面臨的一般問題的解決方案。這些解決方案是眾多軟體開發人員經過相當長的一段時間的試驗和錯誤總結出來的。 設計模式是一套被反覆使用的、多數人知曉的、經 ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...