| 导语 Web技术飞速发展的如今,我们在感受新技术带来的便捷和喜悦的同时,也时常在考虑着一个问题:老技术如何迁移。正如本文的主题一样,Flash技术在早年风靡在Web领域,曾经发挥着无尽力量的一个工具正逐渐失去了其重要性。由于性能,兼容性,版权问题,Flash的市场正在消退,曾经靠Flash实现的功能和特性如何完美得进行迁移呢,本文将简单谈一谈Flash的几个常见的特性的替代方案。
1.视频播放(Play Video)
我们知道Flash可以播放.swf文件的动画视频,而且具有很强的控制功能,以前很多Web视频播放器都是基于Flash去实现的。包括embed标签,都是如此。所有视频源为swf的文件的视频都需要借助Flash去播放。
解决方案:
在移动端设备上,使用HTML5的video标签基本没有问题。 在PC上,IE低版本(IE8-)浏览器上除了Flash目前没有其它办法 在PC上,IE9+和其它现在浏览器,采用HTML5标签。 综合来说,可以统一用以下一段代码实现兼容:
<video width="400" height="300" controld>
<!-- mp4格式适用于IE9+,Chrome,Safari -->
<source src="test.mp4" type="video/mp4"></source>
<!-- ogg格式适用于FireFox,Opera,Chrome -->
<source src="test.ogg" type="video/ogg"></source>
<!-- webm格式适用于FireFox,Opera,Chrome -->
<source src="test.webm" type="video/webm"></source>
<!-- object需要Flash支持,当IE8-时考虑 -->
<object data="test.mp4" width="400" height="300">
<!-- embed需要Flash支持,当IE8-时考虑 -->
<embed src="test.swf" width="400" height="300">
</object>
</video>
2.跨域请求(Corss Origin Request)
2.1使用Flash进行跨域请求的方案实现
目前在PC端a.qq.com的页面请求b.qq.com的一个接口是理论上跨域的一个请求,旧版本浏览器特别是只支持XMLHTTPRequest Level1的浏览器,需要访问跨域请求,要么使用jsonp,要么只能使用Flash。 使用Flash进行跨域需要做的事情是
1.a.qq.com的js与Flash交互 2.Flash校验安全性,检查b.qq.com下根目录的crossDomain.xml文件的控制访问属性 3.Flash作为中间代理请求b.qq.com 4.Flash将请求结果返回给a.qq.com的js 图1简明扼要的描述了这个过程。
图1 Flash跨域请求
2.2 去Flash跨域如何实现
情况一:CORS(Cross-Origin Resource Sharing)【后端需改造】
条件:要使用CORS,必须在支持XmlHttpRequest Level2的浏览器中(IE10+和其它现代浏览器) 做法:设置withCredentials头,然后结合后台设置的Access-Control-Allow-Origin头进行控制,进行跨域即可。相关代码如下: 前端JS:
$.ajax({
url:"http://b.qq.com/api/xxx.php",
type:"POST",
xhrFields:{
withCredentials:true
},
success:function(){
//...
},
fail:function(){
//...
}
})
后端PHP:
<?php
//b.qq.com的接口中添加Access-Control-Allow-Origin头
header("Access-Control-Allow-Origin:http://a.qq.com");
情况二:中转代理请求【建议】
我们回到同源策略,如果要请求b.qq.com下的一个接口,我们从b.qq.com下的页面发起请求,是遵循同源策略的。那么我们可以在接口域名下放一个统一的html文件,用于代理我们请求b.qq.com的接口,然后将结果告诉a.qq.com就可以了。 这种情况下要解决2个主要问题: 1.cookie如何发送 2.a.qq.com与b.qq.com的代理页面前端通信 其实两个问题是一个问题,a.qq.com下的cookie我们是可以获取到的,同样的cookie我们可以种在b.qq.com下的。问题归结到第二个问题,如何在前端实现a.qq.com和b.qq.com两个页面之间的通信。 有两个方法:
1.使用HTML5规范的PostMessage特性
主要核心逻辑代码可以参考: 【a.qq.com页面代码】
<!DOCTYPE html>
<html>
<head>
<meta charset="utf-8">
</head>
<body>
<script>
//a.qq.com中逻辑:
var $proxyFrame=$("<iframe style='display:none' src='http://b.qq.com/proxy.html'></iframe>").appendTo(document.body);
//等待iframe中转页面load完毕
$proxyFrame.on("load",function(){
//调中转页面
$proxyFrame.get(0).contentWindow.postMessage({
api:"/xx/y",
data:{
a:1,
b:2
},
cookie:document.cookie//带过去的cookie
});
//回调
$(window).on("message",function(e){
var event=e.originalEvent;
if(event.origin=="http://b.qq.com"){
console.log("response data:",event.data);
}
})
})
</script>
</body>
</html>
【b.qq.com页面代码】
<!DOCTYPE html>
<html>
<head>
<meta charset="utf-8">
</head>
<body>
<script>
//b.qq.com中逻辑:
$(window).on("message",function(e){
var event=e.originalEvent;
if(event.origin=="http://a.qq.com"){
var api=event.data.api;
var data=event.data.data;
var cookie=event.data.cookie;
//种植cookie
//.........种植cookie的操作
//代理请求接口
$.ajax({
url:api,
data:data,
//.......
success:function(result){
//将response返回给a.qq.com
window.parent.postMessage(result,"*")
},
fail:function(){
}
})
}
})
</script>
</body>
</html>
以上demo简单解决了前端跨域通信,跨域带cookie等问题,在逻辑上完全可以实现跨域通信。但是对于不支持PostMessage特性的老版浏览器是行不通的。比如IE8-浏览器就不能很好的支持PostMessage特性。这种情况下我们采用另外一种中转跨域的方案:降子域通信。 下面介绍第二种方法:降子域通信:
2.不支持PostMessage时,降子域通信
由于a.qq.com和b.qq.com都是属于qq.com下的子域,同源策略在前端页面中判定依据是document.domain而不是location.host。而document.domain可写,可以人为更改到其父域名。这样a.qq.com和b.qq.com的两个页面都可以自行降到qq.com。这样就可以直接进行通信。 主要核心逻辑代码可以参考: 【a.qq.com页面代码】
<!DOCTYPE html>
<html>
<head>
<meta charset="utf-8">
</head>
<body>
<script>
//a.qq.com中逻辑:
document.domain="qq.com";
var $crossFrame=$("<iframe style='display:none' src='http://b.qq.com/proxy.html'></iframe>").appendTo(document.body);
//等待iframe中转页面load完毕
$crossFrame.on("load",function(){
//回调
window['callback']=function(result){
//收到响应
console.log("receive response:",result);
}
//调中转页面中的方法直接请求
$crossFrame.get(0).contentWindow.request({
api:"/xx/y",
data:{
a:1,
b:2
}
});
})
</script>
</body>
</html>
【b.qq.com页面代码】
<!DOCTYPE html>
<html>
<head>
<meta charset="utf-8">
</head>
<body>
<script>
//b.qq.com中逻辑:
document.domain="qq.com";
window.request=function(api,data){
$.ajax({
url:api,
data:data,
//.......
success:function(result){
//将response返回给a.qq.com
window.parent.callback(result,"*")
},
fail:function(){
}
})
}
</script>
</body>
</html>
在实际改造过程中,如果后端结果过多,或者改造不方便,可以直接采用第二种方式——中转代理的方式进行改造。其原理示意图总结如下:
图2 去Flash跨域请求改造指导图
3.文件上传
3.1 背景
其实文件上传是HTML规范内的,理论上不需要使用Flash去做。但是随着ajax技术的兴起,Web 2.0时代的到来,input表单的提交改成ajax提交,页面无刷新的形式。但是这种形式下对于文件这类二进制文件无法提交,IE下本来有ActiveX 的FSO可以操作,但是插件的执行需要IE安全机制允许,很多情况下用户体验不好,而且兼容性也不是很好。于是这种背景下,FLash又担当起了一个新的功能:文件上传。 著名的jquery插件,ajaxupload.js就是用的Flash进行文件提交。
3.2去Flash上传
如何不使用Flash,上传文件,而且保证页面不刷新,是我们在去Flash上传工作中需要做的核心。下面针对不同的浏览器提供两套方案:
3.2.1 【第一套方案】HTML5获取文件信息用FormData提交
条件:支持HTML5 FileReader 和FormData 特性 做法:
1.获取input表单的files对象 2.实例化FileReader对象,并解析files对象 3.解析之后输出base64编码的文件数据 4.base64的数据传入FormData 5.ajax提交FormData
参考demo如下:
<!DOCTYPE html>
<html>
<head>
<meta charset="utf-8">
</head>
<body>
<input type="file" name="test" id="test" />
<script>
$("#test").change(function(e){
var files=e.target.files;
va fr=new FileReader();
fr.onload=function(e){
var fm=new FormData();
fm.append("file_test",e.target.result);
//额外参数
fm.append("sExtend","test");
//提交ajax
$.ajax({
url:'http://b.qq.com/cgi/',
type:"POST",
dataType:json,
data:fm,
processData: false, // 不会将 data 参数序列化字符串
contentType: false, // 根据表单 input 提交的数据使用其默认的 contentType
success:function(result){
console.log(result);
},
fail:function(){
console.log("failed");
}
});
}
fr.readAsDataURL(files[0]);
});
</script>
</body>
</html>
3.2.2 【第二套方案】低版本浏览器中用模拟表单提交
条件:无任何条件,支持任何浏览器 做法:
1.在页面上构建一个隐藏的iframe 2.在页面上构建一个form表单,表单中包含文件表单和其它附加字段表单,target设为上述iframe的id 3.上传文件动作触发时,调用form的submit方法 4.iframe中加载上传cgi,返回结果与父窗口通信,如果iframe与cgi跨域,则参考【第二部分:跨域请求】进行处理
参考demo如下:
<!DOCTYPE html>
<html>
<head>
<meta charset="utf-8">
<title>DEMO-上传文件</title>
</head>
<body>
<!-- 以a.qq.com上传到b.qq.com/upload/为例 -->
<form action="http://b.qq.com/upload/" enctype="multipart/form-data" method="post" target="postframe" name="fileform">
<!-- 文件上传按钮 -->
<input type="file" name="file_1" />
<!-- 隐藏的附加字段 -->
<input type="hidden" name="sExtend1" value="test1" />
<input type="hidden" name="sExtend2" value="test2" />
</form>
<iframe src="" frameborder="0" style="display:none;" id="postframe"></iframe>
<script>
//监听文件基本信息
$("[name=file_1]").change(function(e){
var files=e.target.files;
if("undefined" == typeof files && e.target.value){
//IE9-
files=[];
try{
files=[new ActiveXObject("Scripting.FileSystemObject").GetFile(e.target.value)];
}catch(err){
files=[{
name:e.target.value,
type:"unkown"
}];
}
if(!files.length){
files=[{
name:e.target.value,
type:"unkown"
}];
}
}
//获取文件信息
console.log(files);
})
//上传
$("[name=fileform]").submit();
//回调
window.fileCallback=function(result){
//处理result
console.log("文件上传成功");
}
</script>
</body>
</html>
总结
本文给出了笔者在实际工作中遇到的最常见的去Flash改造的三种场景,现以表格的形式简单概括如下:
视频播放 | 使用H5的video标签 | 没办法只能使用FLash,如果不用Flash,建议提醒用户升级浏览器 |
跨域提交请求 | 使用CORS,前后端结合 | 中转代理(PostMessage或者降域) |
Ajax文件上传 | 使用FileReader+FormData封装 | 模拟表单提交到iframe |
结语
去Flash不仅是对实现方案的一种兼容改造,更是对早已成熟的新技术新思路的运用。目前而言,不管是因为政策原因,还是因为性能或者其它兼容性原因,去Flash改造都是重要和紧迫的,本文是笔者在实际工作过程中总结出的最常见的三种去Flash场景和改造方案,供参考,不足之处还请不吝指正。
相关推荐
7. **安全与兼容性**:需要注意的是,由于Flash的安全问题和即将被淘汰的命运,用户在使用Flash时钟时要考虑其对浏览器兼容性和数据安全的影响。 8. **学习与资源**:对于想学习如何制作Flash时钟的开发者,可以...
- **更新和替代方案:**鉴于Flash即将全面退役的趋势,建议用户寻求更安全、更现代的技术替代方案,如HTML5、CSS3和JavaScript等。 - **跨平台支持:**上述方法适用于Chrome和Safari浏览器,但对于其他浏览器(如...
QQ空间是中国最受欢迎的社交平台之一,用户们常常在这里分享照片、日志、音乐以及各种个人资料。...尽管Flash Player即将被淘汰,但它仍可能在某些场合派上用场。用户应谨慎对待,并尽快转向更安全、更现代的替代方案。
标题 "Google浏览器所有网站允许flash运行" 涉及到的是在Google Chrome浏览器上启用Adobe Flash Player的设置问题。...然而,由于Flash即将被逐步淘汰,对于长期解决方案,最好还是转向HTML5等现代技术。
7. **现代替代方案**:虽然Flash曾是批量上传的主流解决方案,但由于其不支持移动设备和即将被浏览器淘汰,现代Web开发中更多地使用HTML5的File API。HTML5的`multiple`属性允许用户在输入文件字段中选择多个文件,`...
【360急速浏览器】是360公司...尽管Flash即将退出历史舞台,但考虑到其在某些领域的遗留影响,360浏览器的这一特性仍有其存在的价值。同时,用户应关注Flash的安全风险,并在可能的情况下逐步转向更安全的替代技术。
10. **替代方案**:鉴于Flash的逐渐淘汰,现代Web开发更倾向于使用HTML5、JavaScript(如jQuery File Upload库)和Web Workers来实现批量上传,这些技术更符合现代浏览器标准,具有更好的跨平台兼容性和安全性。...
8. 播放器替代方案:随着Flash的逐渐淡出,各种开源的HTML5视频播放器(如Video.js、JW Player等)成为新的选择,它们同样支持流媒体播放,并提供了丰富的定制选项和API,方便开发者实现各种功能。 9. 结论:FLV ...
然而,由于对移动设备支持不佳和安全性问题,Flash逐渐被淘汰,被HTML5等现代标准所取代。 结合JS和Flash实现图片轮换,通常步骤如下: 1. **HTML布局**:首先在HTML中设置一个容器,用于放置图片轮换的区域,可能...
Flash上传插件在过去广泛使用,但由于安全漏洞和即将被淘汰的技术,许多开发者转向了其他替代方案。百度上传插件则是一个流行的JavaScript解决方案,它提供了多文件选择、断点续传、进度显示等功能,适用于各种现代...
本主题聚焦于"随机效果js+flash幻灯片",这是一种结合JavaScript(js)和Flash技术实现的动态图片展示方案。在网页中,这种幻灯片通常用于创建吸引人的轮播效果,使用户能够方便地浏览一系列图片或内容,而无需手动...
**Haddu - Activador flash-crx 插件详解** Haddu - Activador flash-crx 是一款专门针对西班牙语...然而,考虑到Flash的安全性和即将被淘汰的事实,用户也需要关注网站的现代化进程,适时更新自己的在线体验方式。
包含了一套利用HTML5和CSS3技术构建的个人简历模板,它旨在模仿过去Flash技术提供的互动体验,但又避免了Flash不支持移动设备和即将被淘汰的问题。 HTML5是超文本标记语言的第五个版本,它的主要改进包括:更好的...
【GamePoint Flash Enabler-crx插件】是一款专为GamePoint游戏设计的浏览器扩展程序,其主要功能是自动为用户...然而,由于Flash即将被彻底淘汰,未来可能需要寻找替代方案,例如使用模拟器来运行这些基于Flash的游戏。
5. **替代方案**:由于Flash即将被淘汰,一个更现代的替代方案是使用HTML5和JavaScript技术,如PDF.js(用于PDF)、Epub.js(用于电子书)或PPTX.js(用于PPT),这些工具可以直接在浏览器中呈现文档,无需依赖任何...
值得注意的是,由于Flash的安全问题和即将被淘汰的命运,现代浏览器已经默认禁用了Flash内容。因此,使用这类插件可能存在一定的风险,如安全漏洞的暴露,以及与浏览器更新的兼容性问题。用户在享受便利的同时,也...
此外,由于Flash即将被完全淘汰,用户也需要考虑逐渐过渡到HTML5等现代网页技术,以适应未来的网络环境。 总的来说,Bibbop Automatic Flash Enable-crx插件是针对特定需求的解决方案,它帮助用户在Flash逐渐退出...
涂鸦是一种创意表达和艺术创作的形式,而"ty.rar_bg888.ty_涂鸦"这个文件似乎是一...不过,由于Flash即将被淘汰,用户可能需要使用特定的软件或环境(如Adobe Flash Player或Ruffle等Flash模拟器)来运行这个涂鸦应用。
然而,随着HTML5的崛起,Flash逐渐被淘汰,因为HTML5提供了更现代、更高效且更利于搜索引擎优化(SEO)的解决方案。尽管如此,对于一些老项目或者特定需求,Flash模板仍有其价值。 在这个灰色音乐摇滚Flash网站模板...
总的来说,FlashImageUpload是一个结合了Flash技术的图片上传解决方案,它通过预览功能和前端处理优化了上传体验,为Web开发者提供了一种高效且用户友好的图片上传工具。然而,考虑到Flash的逐步淘汰,开发者在使用...