網站首頁 編程語言 正文
所需環境
node.js + FFmpeg
此方式客戶端只需要通過video標簽就可播放
ffmpeg下載鏈接:https://pan.baidu.com/s/1ntOVSpxmtHO861V-dT5Kyg?pwd=nx7y?
提取碼:nx7y?
FFmpeg環境安裝
1. 安裝FFmpeg的依賴yasm
?yum方式安裝yasm,也可以通過Download - The Yasm Modular Assembler Project下載安裝
yum install yasm -y
# 編譯
./configure
# 安裝
make && make install
2. 安裝FFmpeg
?wget獲取ffmpeg,有可能下載不下來,建議用我提供的ffmpeg-4.1.8.tar.bz2手動上傳到服務器
wget https://ffmpeg.org/releases/ffmpeg-4.1.8.tar.bz2
# 解壓
tar -xjvf ffmpeg-4.1.8.tar.bz2
# 進入解壓目錄
cd ffmpeg-4.1.8
# 編譯
./configure
# 安裝
make && make install
3. 驗證是否安裝成功
輸入ffmpeg命令,查看控制臺是否有輸出,有則代表安裝ffmpeg成功。
NodeJS環境安裝
1. NodeJS的安裝步驟忽略。。
2. 安裝rtsp2web插件
# 創建一個目錄,目錄名稱不能是rtsp2web,進入目錄執行以下命令安裝rtsp2web插件
npm init --yes
npm i rtsp2web
3. 創建?index.js,并運行,運行命令node index.js
// index.js
const RTSP2web = require('rtsp2web')
// 服務端長連接占據的端口號;端口號可以自定義
const port = 9999
new RTSP2web({
port
})
至此視頻轉碼服務安裝完成。
在此提供公開的rtsp流可用于測試:
rtsp://wowzaec2demo.streamlock.net/vod/mp4:BigBuckBunny_115k.mp4
驗證html播放實時視頻
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="utf-8">
<meta http-equiv="X-UA-Compatible" content="IE=edge">
<meta name="viewport" content="width=device-width, initial-scale=1, maximum-scale=1, minimum-scale=1, user-scalable=no,viewport-fit=cover">
<script src="https://jsmpeg.com/jsmpeg.min.js" charset="utf-8"></script>
<title>播放rtsp</title>
</head>
<body>
<canvas id="canvas" style="width: 600px; height: 600px;"></canvas>
</body>
<script>
// 改成你的rtsp流
var rtsp = 'rtsp://wowzaec2demo.streamlock.net/vod/mp4:BigBuckBunny_115k.mp4'
window.onload = () => {
// location為node服務所在的服務地址,端口為rtsp2web設置的端口
new JSMpeg.Player("ws://localhost:9999/rtsp?url="+btoa(rtsp), {
canvas: document.getElementById("canvas")
})
}
</script>
</html>
將該html copy到桌面打開看看效果。
原文鏈接:https://blog.csdn.net/qq_36881887/article/details/125423111
- 上一篇:跨域的五種解決方案
- 下一篇:jenkins數據遷移和備份
相關推薦
- 2022-04-21 sql更新語句中update?set?from用法實現_MsSql
- 2022-11-13 Framework源碼面試之activity啟動流程_Android
- 2023-05-17 一文速學Python+Pyecharts繪制樹形圖_python
- 2022-12-25 python字典中items()函數用法實例_python
- 2024-07-15 Spring中的單例模式應用詳解
- 2022-12-27 React組件間通訊傳值實現詳解_React
- 2023-05-06 Python格式化輸出的幾種匯總_python
- 2022-01-28 寶塔的定時任務,如何設置秒數級別執行?
- 最近更新
-
- window11 系統安裝 yarn
- 超詳細win安裝深度學習環境2025年最新版(
- Linux 中運行的top命令 怎么退出?
- MySQL 中decimal 的用法? 存儲小
- get 、set 、toString 方法的使
- @Resource和 @Autowired注解
- Java基礎操作-- 運算符,流程控制 Flo
- 1. Int 和Integer 的區別,Jav
- spring @retryable不生效的一種
- Spring Security之認證信息的處理
- Spring Security之認證過濾器
- Spring Security概述快速入門
- Spring Security之配置體系
- 【SpringBoot】SpringCache
- Spring Security之基于方法配置權
- redisson分布式鎖中waittime的設
- maven:解決release錯誤:Artif
- restTemplate使用總結
- Spring Security之安全異常處理
- MybatisPlus優雅實現加密?
- Spring ioc容器與Bean的生命周期。
- 【探索SpringCloud】服務發現-Nac
- Spring Security之基于HttpR
- Redis 底層數據結構-簡單動態字符串(SD
- arthas操作spring被代理目標對象命令
- Spring中的單例模式應用詳解
- 聊聊消息隊列,發送消息的4種方式
- bootspring第三方資源配置管理
- GIT同步修改后的遠程分支