跨域中的crossdomain文件
2016-03-27 13:23
585 查看
使用crossdomain.xml让Flash可以跨域传输数据
本文来自crossdomain.xml作用
一、概述
位于http://hr64.xyz域中的SWF文件要访问http://www.163.com的文件时,SWF首先会检查163服务器目录下是否有crossdomain.xml文件,如果没有,
则访问不成功;若crossdomain.xml文件存在,且里边设置了允许http://hr64.xyz域访问,那么通信正常。所以要使Flash可以跨域传输数据,其关键就是crossdomain.xml。
二、crossdomain.xml文件格式
crossdomain.xml的格式非常简单,其根节点为<cross-domain-policy>
,其下包含一个或多个<allow-access-from>节点,<allow-access-from>有一个属性domain,其值为允许访问的域,
可以是确切的 IP 地址、一个确切的域或一个通配符域(任何域)。下边是两个例子:
程序代码1:
程序代码2:
程序2表示允许所有的域行访问.对于crossdomain.xml文件存放位置,建议将其存放于站点根目录中!
当Flex访问WebService服务时,在本地能够正常访问,当部署到web容器中发布为web服务后,再调用WebServicIE,此时就会被拒绝访问,这就是Flex跨域访问的沙箱问题,
为了解决Flex跨域访问WebService的问题,可采用如下方案:
首先,跨域访问被拒绝是因为提供服务方没有配置安全策略文件,即crossdomain.xml,如果你不想用crossdomain.xml就要用到代理,即自己写一个后台读取webservice,
然后提供给自己的flex应用,因为在flashplayer中,要跨域必须要有策略文件。考虑到flashplayer升级到9.124之后,加强了安全性,
之前的crossdomain.xml的写法发生了变化,以下就是该文件的完整写法:
表示该服务允许任何外域来访问。
关于crossdomain.xml的放置目录问题,有如下解决方案,可放置在:
1) 如果这个目录是容器的根目录,可以通过以下的url访问crossdomain.xml:
http://localhost:8080/crossdomain.xml 。
2) 如果crossdomain.xml不是放在根目录下,而是在某个webapp下面,在flex中就需要在初始化的时候应用
Security.loadPolicyFile("http:// hr64.xyz:8080/aaa/crossdomain.xml");
其中aaa为webapp的名称
这样,外部Flex访问该服务发布的WebService时,flashplayer首先找的就是crossdomain.xml文件,若安全机制设置为允许访问,则访问成功。
本文来自crossdomain.xml作用
一、概述
位于http://hr64.xyz域中的SWF文件要访问http://www.163.com的文件时,SWF首先会检查163服务器目录下是否有crossdomain.xml文件,如果没有,
则访问不成功;若crossdomain.xml文件存在,且里边设置了允许http://hr64.xyz域访问,那么通信正常。所以要使Flash可以跨域传输数据,其关键就是crossdomain.xml。
二、crossdomain.xml文件格式
crossdomain.xml的格式非常简单,其根节点为<cross-domain-policy>
,其下包含一个或多个<allow-access-from>节点,<allow-access-from>有一个属性domain,其值为允许访问的域,
可以是确切的 IP 地址、一个确切的域或一个通配符域(任何域)。下边是两个例子:
程序代码1:
<?xml version="1.0"?> <cross-domain-policy> <allow-access-from domain="hr64.xyz" /> <allow-access-from domain="*.xyz" /> <allow-access-from domain="139.129.5.54" /> </cross-domain-policy>
程序代码2:
<?xml version="1.0"?> <cross-domain-policy> <allow-access-from domain="*" /> </cross-domain-policy>
程序2表示允许所有的域行访问.对于crossdomain.xml文件存放位置,建议将其存放于站点根目录中!
<?xml version=”1.0″?> <!DOCTYPE cross-domain-policy SYSTEM “http://www.macromedia.com/xml/dtds/cross-domain-policy.dtd”> <cross-domain-policy> <!--要符合要求的文件你才能取,不管你是哪来的flash数据请求。符合要求的文档必须满足:Content-Type: text/x-cross-domain-policy--> <site-control permitted-cross-domain-policies=”by-content-type” /> </cross-domain-policy>
当Flex访问WebService服务时,在本地能够正常访问,当部署到web容器中发布为web服务后,再调用WebServicIE,此时就会被拒绝访问,这就是Flex跨域访问的沙箱问题,
为了解决Flex跨域访问WebService的问题,可采用如下方案:
首先,跨域访问被拒绝是因为提供服务方没有配置安全策略文件,即crossdomain.xml,如果你不想用crossdomain.xml就要用到代理,即自己写一个后台读取webservice,
然后提供给自己的flex应用,因为在flashplayer中,要跨域必须要有策略文件。考虑到flashplayer升级到9.124之后,加强了安全性,
之前的crossdomain.xml的写法发生了变化,以下就是该文件的完整写法:
<?xml version="1.0"?> <!DOCTYPE cross-domain-policy SYSTEM "http://www.macromedia.com/xml/dtds/cross-domain-policy.dtd"> <cross-domain-policy> <allow-access-from domain="*" /> <allow-http-request-headers-from domain="*" headers="*"/> </cross-domain-policy>
表示该服务允许任何外域来访问。
关于crossdomain.xml的放置目录问题,有如下解决方案,可放置在:
1) 如果这个目录是容器的根目录,可以通过以下的url访问crossdomain.xml:
http://localhost:8080/crossdomain.xml 。
2) 如果crossdomain.xml不是放在根目录下,而是在某个webapp下面,在flex中就需要在初始化的时候应用
Security.loadPolicyFile("http:// hr64.xyz:8080/aaa/crossdomain.xml");
其中aaa为webapp的名称
这样,外部Flex访问该服务发布的WebService时,flashplayer首先找的就是crossdomain.xml文件,若安全机制设置为允许访问,则访问成功。
相关文章推荐
- 我的思考,我的科技漫谈——Tay Tweets
- hdoj-1982-Kaitou Kid - The Phantom Thief (1)
- 03-树3 Tree Traversals Again (25分)
- 检查C语言的内存问题 参考网址:http://blog.csdn.net/sduliulun/article/details/7732906
- 对raid几个技术的简单理解
- arithmetic daily
- main函数中两个参数的用法总结
- 【Educational Codeforces Round 10C】【脑洞 SET】Foe Pairs 不含有敌对pair的区间数
- 我的第一个 Rails 站点:极简优雅的笔记工具-Raysnote
- raid详解
- hangdain 2013
- 使用wait、notify简单实现并行计算
- 浙江科技学院第十三届程序设计竞赛 1008:A Heavy Rainy Day【贪心】
- hdoj--A Heavy Rainy Day(贪心好题)
- LeetCode172. Factorial Trailing Zeroes
- 增加samba用户提示Failed to add entry for user
- Educational Codeforces Round 5 E. Sum of Remainders
- AIDL调用指南
- 加入百度地图遇到 framework not found BaiduMapAPI***
- 在main方法中调用service