在从网络加载内容时,很多时候会发生这种情况,但对于我们来说,最常见的是通过Facebook的图表快捷方式调用来加载图片。
简单的事情:
package
{
import flash.display.Loader;
import flash.display.LoaderInfo;
import flash.display.Sprite;
import flash.events.Event;
import flash.net.URLRequest;
import flash.system.LoaderContext;
public class RedirectTestFail extends Sprite
{
private const url:String = 'https://graph.facebook.com/4/picture';
private const context:LoaderContext = new LoaderContext(true);
public function RedirectTestFail()
{
var loader:Loader = new Loader();
loader.contentLoaderInfo.addEventListener(Event.COMPLETE, onComplete);
loader.load(new URLRequest(this.url), this.context);
}
protected function onComplete(event:Event):void
{
this.addChild((event.target as LoaderInfo).content);
}
}
}
给出了一个可怕的“SecurityError:错误#2122”错误。
答案 0 :(得分:1)
尽管其他答案暗示了一些简单的事情:
Security.loadPolicyFile("https://fbcdn-profile-a.akamaihd.net/crossdomain.xml");
这不清楚,也不够全面。 Facebook拥有不同的图像服务器,我以前就已经被它所接受。这可能被视为Flash Player Bug,我会接受,但出于安全考虑,我可以理解它们默认情况下不允许重定向,因为您应该自己处理它。
我现在在下面使用。您尝试执行正常行为,但将其包装在SecurityError的try / catch中。如果抛出一个,请捕获它,如果loaderInfo的域与您请求的域不同,则在其上运行“Security.allowDomain”和“Security.loadPolicyFile”,并尝试再次加载它。这在实践中非常有效,只需要很少的开销。
package
{
import flash.display.Loader;
import flash.display.LoaderInfo;
import flash.display.Sprite;
import flash.events.Event;
import flash.net.URLRequest;
import flash.system.LoaderContext;
import flash.system.Security;
public class RedirectTest extends Sprite
{
private const url:String = 'https://graph.facebook.com/4/picture';
private const context:LoaderContext = new LoaderContext(true);
public function RedirectTest()
{
var loader:Loader = new Loader();
loader.contentLoaderInfo.addEventListener(Event.COMPLETE, onComplete);
loader.load(new URLRequest(this.url), this.context);
}
protected function onComplete(event:Event):void
{
try
{
this.addChild((event.target as LoaderInfo).content);
}
catch(error:SecurityError)
{
trace(error);
var loaderInfo:LoaderInfo = (event.target as LoaderInfo);
var loaderDomain:String = loaderInfo.loader.contentLoaderInfo.url;
if(-1 == this.url.indexOf(loaderDomain))
{
Security.loadPolicyFile(loaderDomain + 'crossdomain.xml');
if( 0 == loaderDomain.indexOf('https') )
{
Security.allowDomain(loaderDomain);
}
else
{
Security.allowInsecureDomain(loaderDomain)
}
loaderInfo.loader.load(new URLRequest(this.url), this.context);
return;
}
throw error;
}
}
}
}
答案 1 :(得分:0)
如果您不需要使用加载的图片BitmapData
对象操纵像素,那么您只需从context
loader.load
但如果没有context.checkPolicyFile = true
,您将无法将smoothing
添加到图片