/html5-dash-hls-rtmp

:sunflower: HTML5播放器、M3U8直播/点播、RTMP直播、低延迟、推流/播流地址鉴权、优化浏览器兼容性,HLS+扩展

Primary LanguageJavaScriptMIT LicenseMIT

💐 多媒体架构设计

多媒体架构设计

🐦 支持的直播流输入协议
  • RTMP 用于拉取和发布的流
  • RTSP 为拉和宣布的流
  • 用于HTTP和UDP流的 MPEG-TS
  • SRT 用于听,拉和集合模式
  • UDT 用于听,拉和集合模式
  • HLS 为拉流
🐤 单路路实时编码流传递(RTMP)

单路路实时编码流传递

🐧 多路实时编码流传递(RTMP)

多路实时编码流传递

🐔 HLS、MPEG-DASH多路输入/输出流

Markdown

🐥 通过SSL加密和公开HLS媒体的来源(HLS)

Markdown

🌺 点播设计

Markdown

🍀 更新列表

🍅 直播源

  •  HLS-001:http://hls-live.jia.360.cn/live_jia_public/_LC_RE_non_3605277091515101384821337866_BX/index.m3u8
  • 香港卫视 http://live.hkstv.hk.lxdns.com/live/hks/playlist.m3u8
  • CCTV1高清 http://ivi.bupt.edu.cn/hls/cctv1hd.m3u8
  • CCTV5高清 http://ivi.bupt.edu.cn/hls/cctv5hd.m3u8
  • 杭康 http://live.hkstv.hk.lxdns.com/live/hks/playlist.m3u8

🐠 详细介绍

  • 以下测试延迟多为局域网测试环境(线上为阿里云平台测试)
  • M3U8 直播或者点播DEMO

☀️ VideoJs-M3U8

  • 1、支持直播流:HSL的 m3u8
  • 2、如何使用:直接下载即可使用,注意点: m3u8 播放必须放在服务器下面
  • 3、默认:m3u8播放
  • 4、延迟测试(局域网测试)
    • RTMP 延迟:2s
    • HLS 延迟: 18s
    • VLC 延迟(不推荐): 18s
  • 5、鉴权:可以
  • 皮肤支持

☁️ m3u8-IE-Support

  • 兼容所有浏览器
  • 支持IE11 浏览器播放
  • 测试结果:通过

🌀 VideoJs2017

  • 1、RTMP 支持播放
  • 2、支持鉴权
  • 3、M3U8 IE 暂时不支持播放
  • 4、延迟测试(局域网测试)
    • RTMP 延迟:2s
    • HLS 延迟: 18s
    • VLC 延迟(不推荐): 18s
  • 测试播放列表
    • [1] RTMP直播流:rtmp-stream.html
    • [2] HLS直播和点播:hls-stream.html
    • [3] 直播和点播HLS的M3U8播放(可输入动态改变HLS地址):auto-input-hls-player.html
      • 遇到JS跨域的问题:
        • The value of the 'Access-Control-Allow-Origin' header in the response must not be the wildcard '*' when the request's credentials mode is 'include'. Origin 'http://127.0.0.1
      • 解决办法(Nginx 服务器配置方法,Apache自行百度):
      location /record {
          add_header Cache-Control no-cache;
          add_header 'Access-Control-Allow-Origin' '*' always;
          add_header 'Access-Control-Expose-Headers' 'Content-Length,Content-Range';
          add_header 'Access-Control-Allow-Headers' 'Range';
          types{
                  application/dash+xml mpd;
                  application/vnd.apple.mpegurl m3u8;
                  video/mp2t ts;
           }
          alias /home/tinywan/hls;
       }
      
      
      • 测试地址:http://192.168.18.143/record/stream_name/index.m3u8
  • 测试进度
    • [2017年4月10日 下午 16:00 ] 局域网的HSL和RTMP流延迟的测试

      测试结果:RTMP 延迟:2s ,HLS 延迟: 18s

    • [2017年4月11日 下午 13:00 ] 直播和点播HLS的M3U8播放(可输入动态改变HLS地址),JS 跨域问题

☔ Play-RTMP-HLS-Stream(Obj-Flash)

  • 支持 RTMP 和 M3U8 直播兼容播放
  • 参数说明
    • 语法:embedSWF: function(swfUrlStr, replaceElemIdStr, widthStr, heightStr, swfVersionStr, xiSwfUrlStr, flashvarsObj, parObj, attObj, callbackFn)
      1. swfUrlStr:指定您的SWF的URL(StrobeMediaPlayback.swf)
      2. replaceElemIdStr:指定包含替换元素的html元素的ID,能用你的flash的内容来替换
      3. widthStr:指定SWF的宽度
      4. heightStr:指定SWF的高度
      5. swfVersionStr:指定SWF 发布所需的flash播放器的版本
      6. xiSwfUrlStr:指定快速安装的路径,激活快速安装. 请注意,快速安装只会触发一次(他第一次被调用)
      7. flashvarsObj:指定需要传递给flash的变量(用键值对)
      8. parObj:指定嵌入对象的参数(用键值对)
      9. attObj:指定对象的属性(用键值对)
      10. callbackFn: (JavaScript function, optional)能定义一个回调函数,不管调用flash创建成功或者失败都可以调用该函数
  • 文档
    • 1、支持:播放RTMP直播流和HSL直播流
    • 2、如何使用:直接下载即可使用,注意点:m3u8 播放必须放在服务器下面,负载存在跨域问题
    • 3、默认:RTMP播放
    • 4、延迟:
      • RTMP 延迟:3s
      • HLS 延迟: 20s
    • 5、跨域:OK
    • 6、鉴权:OK (服务添加xml跨域文件)
    • 7、待解决问题:js 调用swf问题~~~~~~~~~~~
    • 测试进度
      • [2017年4月10日 下午 16:00 ] 局域网的HSL和RTMP流延迟的测试,测试结果:RTMP 延迟:3s ,HLS 延迟: 20s
      • [2017年6月7日 下午 16:00 ] 代码优化,该页面进行过优化play2video2.html,默认静音播放

🍎 音频和视频技术文档

🍈 FFmpeg HLS 命令记录

  • https://github.com/video-dev/hls.js
  • 官方文档http://www.ffmpeg.org/ffmpeg-formats.html
  • hls_segment_filename 文件名
    • 设置段文件名。除非hls_flags single_file设置, 文件名将被用作具有段号的字符串格式:
    • 格式:ffmpeg -i in.nut -hls_segment_filename'file%03d.ts'out.m3u8
    • 此示例将生成播放列表, out.m3u8,和段文件: file000.ts, file001.ts, file002.ts等等
  • use_localtime 文件名
    • 对文件名使用strftime()来扩展本地时间段的文件名。段号也可在此模式下使用,但要使用它,您需要指定second_level_segment_index hls_flag,而%% d将是说明符。
    • 格式:ffmpeg -i in.nut -use_localtime 1 -hls_segment_filename'file-%Y%m%d-%s.ts'out.m3u8
    • 此示例将生成播放列表, out.m3u8,和段文件: 文件20160215-1455569023.ts, 文件20160215-1455569024.ts等等。注意:在某些系统/环境中,说明%s符不可用。见 strftime()文件。
  • ts 文件转换成m3u8文件:ffmpeg -i 854-1496985395500.ts -c copy -map 0 -f segment -segment_list playlist.m3u8 -segment_time 10 output%03d.ts
  • 码云提交代码==Github 同步diamante