前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >动手实现m3u8的浏览器播放器

动手实现m3u8的浏览器播放器

作者头像
the5fire
发布2019-02-28 17:40:28
6.1K0
发布2019-02-28 17:40:28
举报
文章被收录于专栏:Python程序员杂谈

前几天花了点时间研究了下怎么在浏览器中播放m3u8的视频地址,最后终于找到了两个开源的东西可以正常播放,稍稍整理下方便后来人。

m3u8是什么就不介绍了,现在所有视频网站基本都是通过m3u8的方式来播放视频的。

在浏览器上播放m3u8的视频地址有两种方式:

1 html的video标签的方式,这种方式播放很简单:

代码语言:javascript
复制
<!DOCTYPE hmtl>
<html>
<head>
<title>the5fire m3u8 test</title>
</head>
<body>
<video controls autoplay >
    <source src="http://stream.gravlab.net/003119/sparse/v1d30/posts/2014/barcelona/barcelona.m3u8">
</video>
</body>
</html>

上面的代码,你直接贴到一个index.html中,用safari浏览器打开就可以直接播了。

但是, 目前只能只有Safari支持,通用性并不好。因此还得采用flash来播放,也就下面的第二种方法。

2 通过开源的swfobject.js以及两个flash组件:OSMF和HLSProvider来播放,上代码:

代码语言:javascript
复制
<!DOCTYPE html>
<html>
<head>
<title>the5fire m3u8 test</title>
<script src="http://the5fireblog.b0.upaiyun.com/staticfile/swfobject.js"></script>
</head>
<body>
<div id="player">
</div>
<script>
   var flashvars = {
       // M3U8 url, or any other url which compatible with SMP player (flv, mp4, f4m)
       // escaped it for urls with ampersands
       src: escape("http://www.the5fire.com/static/demos/diaosi.m3u8"),
       // url to OSMF HLS Plugin
       plugin_m3u8: "http://www.the5fire.com/static/demos/swf/HLSProviderOSMF.swf",
   };
   var params = {
       // self-explained parameters
       allowFullScreen: true,
       allowScriptAccess: "always",
       bgcolor: "#000000"
   };
   var attrs = {
       name: "player"
   };

   swfobject.embedSWF(
       // url to SMP player
       "http://www.the5fire.com/static/demos/swf/StrobeMediaPlayback.swf",
       // div id where player will be place
       "player",
       // width, height
       "800", "485",
       // minimum flash player version required
       "10.2",
       // other parameters
       null, flashvars, params, attrs
   );
</script>
</body>
</html>

通过这三个东西的配合就可以播m3u8了,结果很简单,但是对于我这个对flash外行的人来说还是搜索尝试了良久的。这个代码通过浏览器访问文件的方式是不能用的,你得起一个web服务比如:python -m SimpleHTTPServer。然后访问你存的index.html就能工作了。

结果是不是很简单?不过在搜索的时候也找不到有人提供这样的方案,反而找到很多基于OSMF而开发的收费的flash播放器。

上面几个开源项目的地址:

  • http://osmf.org
  • http://osmf.org/dev/2.0gm/StrobeMediaPlayback.html
  • https://github.com/mangui/HLSprovider

本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2014-03-29 ,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档