HTML5上傳視頻沒法播放以及兼容的解決方法

1、視頻沒法播放緣由分析javascript

一、路徑不對html

<video width="100%" height="100%" controls="controls">
   <source src="p_w_picpaths/apply.mp4" type="video/mp4"></source>
  </video>
html5

在p_w_picpaths前面不加斜槓,使用相對路徑,不要使用絕對路徑java

二、視頻格式不對jquery

解決方法:當前,video 元素支持三種視頻格式:
格式 IE Firefox Opera Chrome Safari
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音頻。
angularjs

三、IIS的MIME中未註冊MP四、ogg、webm相關類型,致使IIS沒法識別web

解決方法:在IIS中註冊MP四、ogg、webm類型,如下以MP4爲例,ogg和webm以此類推:express

一、在IIS中雙擊MIME類型的圖標api

2011062922434432.png

二、右鍵-》添加 IIS不認識的新類型瀏覽器

2011062922460374.png

三、添加新類型的擴展名和類型標識

2011062922473089.png

注意:以上圖示以 .MP4 爲例,若是想讓視頻標籤兼容更多瀏覽器,須要將如下類型加入到MIME中

擴展名 類型
.mp4 video/mp4
.ogv video/ogg
.webm video/webm

2、兼容解決方法

一、在這種狀況下,若是視頻格式正確,大部分瀏覽器的兼容性結果咱們還算滿意,可是IE678不支持它,而且人家的用戶至今在中國仍是十分龐大的羣體,咱們就必須想到另一個解決方案支持它們:


代碼以下:


<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>標籤),根據版本加載不一樣的標籤,代碼以下:


代碼以下:


<script>
if($.browser.msie){
document.write('<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>');
}else{
document.write('<video width="602px" height="345px" controls="controls">'+
'<source src="public/video/test.mp4" type="video/mp4"></source>'+
'<source src="public/video/test.ogg" type="video/ogg"></source>'+
'your browser does not support the video tag'+
'</video>');
}
</script>


不要忘記在寫這段代碼以前引入jquery文件

到此爲止,就能夠編寫兼容全部瀏覽器的HTML視頻代碼了。

二、JS庫

html5media就是一個能讓這兩個標籤在舊版IE瀏覽器中全面兼容的JavaScript類庫。

html5media是一個很給力的JavaScript類庫,它不依賴於任何JavaScript框架。使用了html5media以後,當瀏覽器不支持Html5時,它將會自動切換成Flash模式Flowplayer播放器。雖然,目前web播放器不少,但處理代碼上並不簡潔。

使用html5media讓IE6/7/8瀏覽器支持HTML5的audio和video標籤

一、首先在頁面的head部分加入以下腳本

<script src="http://api.html5media.info/1.1.6/html5media.min.js"></script>

你能夠經過使用IE條件註釋的方法,只在舊版IE瀏覽器中加載這條JS腳本。

二、而後再使用audio或video添加音頻視頻就好了

相關文章
相關標籤/搜索