关于flex的安全沙箱问题
发布时间:2020-12-15 01:01:05 所属栏目:百科 来源:网络整理
导读:关于flex跨域读取一个图片 比如? 假设你的服务器事??www.myserver.com??? 而你的一个flex文件位于???www.myserver.com?/flex/myfalsh.swf 当一个客户来访问你的这个myfalsh.swf 文件? 而你的这个文件又要去?www.otherserver.com/img/1.jpg? 这里把这个图片加
关于flex跨域读取一个图片
比如? 假设你的服务器事??www.myserver.com??? 而你的一个flex文件位于???www.myserver.com?/flex/myfalsh.swf 当一个客户来访问你的这个myfalsh.swf 文件? 而你的这个文件又要去?www.otherserver.com/img/1.jpg? 这里把这个图片加载到flash中 怎么办? 最简单的方法就是 var l:loader = new loader; l.load(new urlrequest(""));??? 这个方式如果你的flash是直接放在本地目录上运行那还可以 放在服务器上? 加载 立马 报错?安全沙箱冲突 看了看loader 的 load的方法load(request:URLRequest,context:LoaderContext?= null):void? context:LoaderContext? 这个干吗用的? 再看看帮助 原来是用来设置运行域 和 设置是否加载安全策略文件的 当然使用方法是? var lc:LoaderContext?= new?LoaderContext(true); ?var l:loader = new loader; l.load(new urlrequest(""),lc);????这样行吗? 一样不行 还要放一个 安全策略文件 放在对方服务器的根目录下面? 名称为:crossdomain.xml 最好是这个名字 省得多写代码 内容为
<?xml?version="1.0"?>
<cross-domain-policy> ??<allow-access-from?domain="? www.myserver.com"?/> </cross-domain-policy> 所以这种方式有个很大弊病 就是要在对方服务器上放这么一个文件,别人还肯给你放啊 ? 要不就是傻了 第2种方式 很自然的就是想到用代理方法? 就是 用asp,php 等类似的程序去把这种图片读回来 然后传给flex?? 具体: 放一个如 getpic.asp 在服务器上 和myfalsh.swf 同一个目录 getpic.asp的代码为 < % function ?reReader(url)? dim ?http set ?http? = ?server.CreateObject( " Microsoft.XMLHTTP )? with ?http? .Open? get ,?url,? false "" ? .Send? reReader? ?.ResponseBody end ? ? nothing ? end?function ?url url? Request.QueryString( url ) response.Clear Response.ContentType? image/gif Response.BinaryWrite?reReader(url) response.End? % > myfalsh.swf 种的代码这样写 调用方法 ? FileLoader(http://www.myserver.com?/flex/myfalsh.swf?url=http://www.otherserver.com/img/1.jpg); 原文地址:http://www.cnblogs.com/qkaibo/archive/2007/07/28/834238.html 搞定 ? ??(编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |