当前位置:   article > 正文

WebRTC实现rtsp流在浏览器中播放_webrtc播放rtsp

webrtc播放rtsp

一般诸如海康威视,大华等监控视频流都是推送的rtsp或rtmp流,这些都是无法在浏览器中直接播放的。因此出现了以下几种方法实现在浏览器端播放。

处理该问题的主流方法大概分为以下几种

PS(由于浏览器的更迭以及Flash不在被支持,所以依赖IE和Flash的方法如使用IE浏览器配合VLC插件,通过video.js配合Flash实现网页播放此处不作介绍)

  1. 通过Nginx+ffmpeg+nginx-http-flv-module模块将rtsp流转为flv格式使用flv.js直接播放
  2. 通过webrtc-streamer将rtsp转为WebRTC流播放
  3. 其他一些插件

通过WebRTC实现播放

  • webrtc-streamer插件开源地址:https://github.com/mpromonet/webrtc-streamer
  • 通过git clone命令下载对应系统webrtc
  • 解压后进入文件目录下,通过CMD打开,输入webrtc-streamer.exe -H 0.0.0.0:9001启动服务(可以指定ip地址和端口号,远程访问注意防火墙)
  • 启动成功后可输入以下地址访问页面预览,注意,如果绑定的不是0.0.0.0请输入对应ip
    http://127.0.0.1:9001/webrtcstreamer.html?video=你的rtsp流地址
  • 如果无法查看视频(确保rtsp流地址正确的情况下,不确定可以先用vlc访问一下),可能是权限问题,尝试用管理员身份打开CMD

通过代码实现

  1. <html>
  2. <head>
  3. <script src="js/adapter.min.js" ></script>
  4. <script src="js/webrtcstreamer.js" ></script>
  5. <script>
  6. var webRtcServer= null;
  7. window.onload= function() {
  8. webRtcServer= new WebRtcStreamer("video","http://ip地址:9001");
  9. webRtcServer.connect("rtsp地址");
  10. }
  11. window.onbeforeunload = function() { webRtcServer.disconnect(); }
  12. </script>
  13. </head>
  14. <body class="body">
  15. <video id="video" autoplay muted ></video>
  16. </body>
  17. <style>
  18. .body{
  19. width:100%;
  20. height:100%;
  21. padding:0;
  22. margin:0;
  23. }
  24. #video{
  25. padding:0;
  26. width:720px;
  27. height:400px;
  28. }
  29. </style>
  30. </html>

声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/繁依Fanyi0/article/detail/659695
推荐阅读
  

闽ICP备14008679号