HTML5上传视频无法播放以及兼容的解决方法(图)


本文摘自PHP中文网,作者黄舟,侵删。

一、视频无法播放原因分析

1、路径不对

1

2

3

<video width="100%" height="100%" controls="controls">

   <source src="images/apply.mp4" type="video/mp4"></source>

  </video>

在images前面不加斜杠,使用相对路径,不要使用绝对路径

2、视频格式不对

解决方法:当前,video 元素支持三种视频格式:
格式 IE Firefox Opera Chrome Safari

1

2

3

Ogg No 3.5+ 10.5+ 5.0+ No

MPEG 4 9.0+ No No 5.0+ 3.0+

WebM No 4.0+ 10.6+ 6.0+ No

Ogg = 带有 Theora 视频编码和 Vorbis 音频编码的 Ogg 文件

MPEG4 = 带有 H.264 视频编码和 AAC 音频编码的 MPEG 4 文件

WebM = 带有 VP8 视频编码和 Vorbis 音频编码的 WebM 文件

注:格式必须符合上面三条详细要求,比如MPEG 4,必须是H.264视频和AAC音频。

3、IIS的MIME中未注册MP4、ogg、webm相关类型,导致IIS无法识别

解决方法:在IIS中注册MP4、ogg、webm类型,以下以MP4为例,ogg和webm以此类推:

1、在IIS中双击MIME类型的图标

1335.png

2、右键-》添加 IIS不认识的新类型

1336.png

3、添加新类型的扩展名和类型标识

1337.png

注意:以上图示以 .MP4 为例,如果想让视频标签兼容更多浏览器,需要将以下类型加入到MIME中

1338.png

二、兼容解决方法

1、在这种情况下,如果视频格式正确,大部分浏览器的兼容性结果我们还算满意,但是IE678不支持它,并且人家的用户至今在中国还是十分庞大的群体,我们就必须想到另外一个解决方案支持它们:

代码如下:

1

2

3

4

5

6

7

8

9

10

11

12

13

<object classid="clsid:D27CDB6E-AE6D-11cf-96B8-444553540000"

width="624" height="351" style="margin-top: -10px;margin-left: -8px;" id="FLVPlayer1">

<param name="movie" value="FLVPlayer_Progressive.swf" />

<param name="quality" value="high" />

<param name="wmode" value="opaque" />

<param name="scale" value="noscale" />

<param name="salign" value="lt" />

<param name="FlashVars" value="&amp;MM_ComponentVersion=1&amp;skinName=public/swf/Clear_Skin_3&amp;

streamName=public/video/test&amp;autoPlay=false&amp;autoRewind=false" />

<param name="swfversion" value="8,0,0,0" />

<!-- 此 param 标签提示使用 Flash Player 6.0 r65 和更高版本的用户下载最新版本的 Flash Player。如果您不想让用户看到该提示,请将其删除。 -->

<param name="expressinstall" value="expressInstall.swf" />

</object>

这里面引入了一些文件,除了flv格式的视频,还有几个swf或js文件,都是用DW软件生成的,不想研究<object></object>标签的朋友去DW软件生成就行,如果可以巧妙的融合
这两段代码就可以得到兼容所有主流浏览器的终极代码了。
于是我们可以这样:
用jquery判断浏览器是否为IE(不用判断具体IE版本,因为服务器的原因IE很可能高版本也不通过,暂且IE全部用<object></object>标签),根据版本加载不同的标签,代码如下:

代码如下:

阅读剩余部分

相关阅读 >>

HTML5 canvas中放入图片和保存为图片的方法

详细介绍HTML5 canvas基本绘图之绘制线段代码实例

HTML5音频与视频问题及解决方法

关于HTML5中自定义属性的介绍

h5设置或返回音频/视频所属的媒体组合的名称的属性mediagroup

HTML5特殊符号怎么显示

HTML5 input新增type属性color颜色拾取器的实例代码

HTML5中的常见错误用法

h5混合开发app如何升级

如何通过HTML5实现摇一摇的功能

更多相关阅读请进入《HTML5》频道 >>




打赏

取消

感谢您的支持,我会继续努力的!

扫码支持
扫码打赏,您说多少就多少

打开支付宝扫一扫,即可进行扫码打赏哦

分享从这里开始,精彩与您同在

评论

管理员已关闭评论功能...