多媒体架构设计
facebook-player
m3u8-IE-Support
兼容所有浏览器
支持IE11 浏览器播放
测试结果:通过
VideoJs2017
1、RTMP 支持播放
2、支持鉴权
3、M3U8 IE 暂时不支持播放
4、延迟测试(局域网测试)
RTMP 延迟:2s
HLS 延迟: 18s
VLC 延迟(不推荐): 18s
测试播放列表
[1] RTMP直播流:
hls, dash, ogg, webm, mp4, rtmp either live or video on demand
在线预览
mediaelement player 播放器
支持格式:支持MP4,WebM和MP3以及HLS,Dash,YouTube,Facebook,SoundCloud和其他HTML5 MediaElement API的HTML5 <audio>或<video>播放器,可在所有浏览器中实现一致的UI
在线预览
2017年06月07日 星期三 Play-RTMP-HLS-Stream 代码方法优化
直播源
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、鉴权:可以
皮肤支持
官方皮肤
YouTouBe


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流延迟的测试
[2017年4月11日 下午 13:00 ] 直播和点播HLS的M3U8播放(可输入动态改变HLS地址),JS 跨域问题 Play-RTMP-HLS-Stream(Obj-Flash) 支持 RTMP 和 M3U8 直播兼容播放 参数说明 语法:测试结果:RTMP 延迟:2s ,HLS 延迟: 18s
embedSWF: function(swfUrlStr, replaceElemIdStr, widthStr, heightStr, swfVersionStr, xiSwfUrlStr, flashvarsObj, parObj, attObj, callbackFn)
swfUrlStr
:指定您的SWF的URL(StrobeMediaPlayback.swf)
replaceElemIdStr
:指定包含替换元素的html元素的ID,能用你的flash的内容来替换
widthStr
:指定SWF的宽度
heightStr
:指定SWF的高度
swfVersionStr
:指定SWF 发布所需的flash播放器的版本
xiSwfUrlStr
:指定快速安装的路径,激活快速安装. 请注意,快速安装只会触发一次(他第一次被调用)
flashvarsObj
:指定需要传递给flash的变量(用键值对)
parObj
:指定嵌入对象的参数(用键值对)
attObj
:指定对象的属性(用键值对)
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
,默认静音播放
音频和视频技术文档
HLS-iOS视频播放服务架构深入探究(二)
HLS-iOS视频播放服务架构深入探究(一)
HTTP Live Streaming (HLS) - 概念
服务器端流媒体技术
GStreamer
Nginx RTMP模块
SHOUTcast
为 HTML 5 视频提供的 DASH 自适应串流
HTTP访问控制(CORS)
使用 canvas 处理视频
音频和视频内容
基于HTTP的动态自适应流媒体
P2P如何将视频直播带宽降低75%?
展望2018音视频技术:AV1,AI,区块链,WebRTC
怎么让不可靠的UDP可靠?
Twitch如何实现转码器比FFmepg性能提升65%?(上)
Twitch如何实现转码器比FFmpeg性能提升65%?(下)
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
版权声明:
1、该文章(资料)来源于互联网公开信息,我方只是对该内容做点评,所分享的下载地址为原作者公开地址。2、网站不提供资料下载,如需下载请到原作者页面进行下载。