Loader拉取图片,由于redirect重定向,导致策略文件无效 设置checkPolicyFile后还是无效:需要一个策略文件,但在加载此媒体时未设置 checkPolicyFile 标志

大家好,在这里分享一下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,才表示新的策略文件已经拉取回来。

那么,可以参考以下代码:

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内部出错了!这个时候,请想起来,这里有这样的一个分享~~~

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

发表于

我来说两句

0 条评论
登录 后参与评论

相关文章

来自专栏逸鹏说道

NET跨平台:在Ubuntu下搭建ASP.NET 5开发环境

0x00 写在前面的废话 年底这段时间实在太忙了,各种事情都凑在这个时候,没时间去学习自己感兴趣的东西,所以博客也好就没写了。最近工作上有个小功能要做成Web应...

2803
来自专栏Android源码框架分析

Android模拟器识别技术

Android模拟器常常被用来刷单,如何准确的识别模拟器成为App开发中的一个重要模块,目前也有专门的公司提供相应的SDK供开发者识别模拟器。 目前流行的And...

3734
来自专栏徐耀的专栏

CIA泄露资料分析(黑客工具&技术)—Windows篇

近期,维基解密曝光了一系列据称来自美国中央情报局(CIA)网络攻击活动的秘密文件,代号为“Vault 7”,被泄露文件的第一部分名为“Year Zero”,共有...

1.1K0
来自专栏NetCore

Catalog Service - 解析微软微服务架构eShopOnContainers(三)

上一篇我们说了Identity Service,因为其基于IdentityServer4开发的,所以知识点不是很多,今天我们来看下Catalog Service...

2788
来自专栏李蔚蓬的专栏

VMware Workstation14.1.3 & Ubuntu18.04从安装到实用的填坑之路

本机VMware Workstation环境是上学期安装的,拿的老师给的安装包,版本10.0.1。顺便装了个Ubuntu15.10。

1241
来自专栏大魏分享(微信公众号:david-share)

Openshift 3.11的14大新功能详解

聂健是大魏的红帽同事,本文已获得授权转载,欢迎读者阅读他的技术blog:https://www.cnblogs.com/ericnie/

7523
来自专栏信安之路

RedTeam 技巧集合

1、利用目标用户使用的 user agent 来隐藏自身的恶意流量,比如像 Outlook 软件的 UA。

1282
来自专栏FreeBuf

Aws_Public_Ips:获取AWS账户关联的所有IP地址(IPv4IPv6)的工具

Aws_Public_Ips是一个可帮助你获取与AWS账户关联的,所有IP地址(IPv4/IPv6) 的工具。它可以被作为库和CLI使用,并支持以下AWS服务(...

1182
来自专栏比原链

剥开比原看代码05:如何从比原节点拿到区块数据?

Gitee地址:https://gitee.com/BytomBlockchain/bytom

651
来自专栏知识分享

八,ESP8266 文件保存数据(基于Lua脚本语言)

应该是LUA介绍8266的最后一篇,,,,,,下回是直接用SDK,,然后再列个12345.......不过要等一两个星期,先忙完朋友的事情 前面几篇 用AT指令...

3777

扫码关注云+社区