大家好,在这里分享一下flash里边处理redirect的方法。
一般而言,大家不会遇到这个问题,毕竟图片地址一般杠杠的,不会redirect。但昨天在拉取空间的照片就会出现redirect。神啊!!!
而且这个不是必现的,空间某些照片会突然redirect,例如从aXX.photo.qq.com域名转到sXX.photo.qq.com。
这个redirect,对于页面来说,当然是没问题的,反正浏览器解决了。但是在Flash里边,如果需要对下载回来的图片进行处理(放缩、平滑等),你就肯定会遇到 “需要一个策略文件,但在加载此媒体时未设置 checkPolicyFile 标志 ”之类的报错。
但是,即使你在Loader的load之前设置了这个标志,也是没用的,因为abode没有这么完善,自动对redirect后的url再请求一次crossdomain.xml文件。
这个时候只能靠自己了~~~
解决方案:
1、乐观情况下,你知道redirect后的几个地址,如果无非就几个。那么你可以在整个程序开始,就直接手工loadPolicyFile。嘿嘿,先下手为强。
Security.loadPolicyFile(http://show.qq.com/crossdomain.xml);
2、悲剧情况下,redirect的地址无数个,随机的。那么就只能出绝招了。在Complete事件处理中,判断一下这次的请求是不是redirect过。
如果是,那么就手工请求这次新的策略文件crossdomain.xml。同时根据adobe官方说明,我们还需要轮询contentLoaderInfo 的 childAllowsParent ,如果是true,才表示新的策略文件已经拉取回来。
那么,可以参考以下代码:
代码语言:javascript复制private function loadImage(imageURL:String):void
{
_originURL = imageURL;
var imageLoader:Loader = new Loader();
var lc:LoaderContext = new LoaderContext(true);
imageLoader.load(new URLRequest(imageURL), lc);
imageLoader.contentLoaderInfo.addEventListener(Event.COMPLETE, loadImageCompleteHandler);
imageLoader.contentLoaderInfo.addEventListener(IOErrorEvent.IO_ERROR, loadImageFailHandler);
}
private function loadImageCompleteHandler(event:Event):void
{
event.target.removeEventListener(Event.COMPLETE, loadImageCompleteHandler);
event.target.removeEventListener(IOErrorEvent.IO_ERROR, loadImageFailHandler);
//实际url跟原来url不一致,被redirect了,要重新拉取策略文件
if(event.target.url != _originURL)
Security.loadPolicyFile(event.target.url.split("/").slice(0, 3).join("/") "/crossdomain.xml");
_waitPolicyFileTimer = setInterval(function():void
{
if(event.target.childAllowsParent)
{
clearInterval(_waitPolicyFileTimer);
_waitPolicyFileTimer = 0;
_image = Bitmap(event.target.content);
_image.smoothing = true;
addChildAt(_image, 0);
if (_loadImageCompleteHandler != null)
_loadImageCompleteHandler();
}
}, 50);
}
附上官方说明:http://help.adobe.com/en_US/FlashPlatform/reference/actionscript/3/flash/system/LoaderContext.html#checkPolicyFile
如果大家以后拉取照片,发现偶尔打不开,或者很奇怪的情况,也许是因为跨域问题,flash内部出错了!这个时候,请想起来,这里有这样的一个分享~~~