关于跨域策略文件crossdomain.xml文件

转载 2012年07月06日 11:38:55

下载flexpaper源码修改后做成swf阅读器,要加入待阅读的swf文件,可以在flex里调用js的方法来获取swf文件的路径的方法,在js只专注获取路径就行,等着flex来调用:但这里会遇到一个问题那就是出现安全问题,如下的提示: Error #2044: 未处理的 onDocumentLoadedError:。 text=Error #2048: 安全沙箱冲突:http://localhost:8080/UpLoadAndDownLoad/FlexPaper.swf 不能从 http://127.0.0.1:8080/MyFileConvert/ConvertFile/application1/2.swf 加载数据。这个是由flash的跨域传输数据的安全问题所引起的,当我在tomcat的webapps/ROOT目录里加入如下文件时就可以解决这个安全问题所引去的swf的文件的不能用的问题,不过这里是将swf文件公开给所有的IP访问,所以有安全问题:

Xml代码 复制代码 收藏代码
  1. <?xml version="1.0" encoding="UTF-8"?>
  2. <cross-domain-policy>
  3. <allow-access-from domain="*"/>
  4. </cross-domain-policy>

下面转载一下关于跨域问题的内容:

关于跨域策略文件crossdomain.xml文件

http://www.xiaonei.com/crossdomain.xml

<!– http://www.xiaonei.com/ –>
Xml代码 复制代码 收藏代码
  1. <?xml version="1.0" encoding="UTF-8"?>
  2. <cross-domain-policy>
  3. <allow-access-from domain="*.xiaonei.com" />
  4. <allow-access-from domain="xiaonei.com" />
  5. </cross-domain-policy>


这是很标准的做法,我就让我自己的域以及我的子域来获取数据。

淘宝的:

http://www.taobao.com/crossdomain.xml

Xml代码 复制代码 收藏代码
  1. <?xml version="1.0" encoding="UTF-8"?>
  2. <cross-domain-policy>
  3. <allow-access-from domain="*.taobao.com" />
  4. <allow-access-from domain="*.taobao.net" />
  5. <allow-access-from domain="*.taobaocdn.com" />
  6. <allow-access-from domain="*.allyes.com" />
  7. </cross-domain-policy>

红色的一行是淘宝的CDN所在的域,所谓内容分发网络。

绿色的一行是淘宝的广告商了,http://www.allyes.com/好耶广告网络,只是不清楚是不是仍然再卖淘宝的广告?

多看几个大网站的crossdomain.xml,也可以知道可能是什么网络广告商给它们在打广告。

比如彭博:http://www.bloomberg.com/crossdomain.xml

Xml代码 复制代码 收藏代码
  1. <?xml version="1.0" encoding="UTF-8"?>
  2. <cross-domain-policy>
  3. <allow-access-from domain="localhost" />
  4. <allow-access-from domain="10.16.136.107"/>
  5. <allow-access-from domain="*.bloomberg.com" />
  6. <allow-access-from domain="*.pointroll.com" />
  7. <allow-access-from domain="*.pointroll.net" />
  8. </cross-domain-policy>

红色的就太不专业了,把内部IP都给暴露了。。。。。。

绿色的是彭博的广告商:PointRoll

路透的:

http://www.reuters.com/crossdomain.xml

Xml代码 复制代码 收藏代码
  1. <?xml version="1.0" encoding="UTF-8"?>
  2. <cross-domain-policy>
  3. <allow-access-from domain="*.reuters.com" secure="false" />
  4. <allow-access-from domain="ad.doubleclick.net"
  5. secure="false" />
  6. <allow-access-from domain="ad.uk.doubleclick.net"
  7. secure="false" />
  8. <allow-access-from domain="m.2mdn.net" secure="false" />
  9. <allow-access-from domain="m2.2mdn.net" secure="false" />
  10. </cross-domain-policy>

广告给了doubleclick来做(绿色)

2mdn.net看不懂是干嘛的,大概是个cdn吧。

滥情的facebook:

http://www.facebook.com/crossdomain.xml

Xml代码 复制代码 收藏代码
  1. <?xml version="1.0" encoding="UTF-8"?>
  2. <!DOCTYPE cross-domain-policy SYSTEM "http://www.adobe.com/xml/dtds/cross-domain-policy.dtd">
  3. <cross-domain-policy>
  4. <site-control permitted-cross-domain-policies="master-only" />
  5. <allow-access-from domain="s-static.facebook.com" />
  6. <allow-access-from domain="static.facebook.com" />
  7. <allow-access-from domain="static.api.ak.facebook.com" />
  8. <allow-access-from domain="*.static.ak.facebook.com" />
  9. <allow-access-from domain="s-static.thefacebook.com" />
  10. <allow-access-from domain="static.thefacebook.com" />
  11. <allow-access-from domain="static.api.ak.thefacebook.com" />
  12. <allow-access-from domain="*.static.ak.thefacebook.com" />
  13. <allow-access-from domain="*.static.ak.fbcdn.com" />
  14. <allow-access-from domain="external.ak.fbcdn.com" />
  15. <allow-access-from domain="*.static.ak.fbcdn.net" />
  16. <allow-access-from domain="external.ak.fbcdn.net" />
  17. <allow-access-from domain="www.facebook.com" />
  18. <allow-access-from domain="www.new.facebook.com" />
  19. <allow-access-from domain="register.facebook.com" />
  20. <allow-access-from domain="login.facebook.com" />
  21. <allow-access-from domain="ssl.facebook.com" />
  22. <allow-access-from domain="secure.facebook.com" />
  23. </cross-domain-policy>

这么多!有子域,有CDN,有thefacebook(facebook的旧域名吧?)

还是google的专业:

Xml代码 复制代码 收藏代码
  1. <?xml version="1.0"?>
  2. <!DOCTYPE cross-domain-policy SYSTEM "http://www.macromedia.com/xml/dtds/cross-domain-policy.dtd">
  3. <cross-domain-policy>
  4. <site-control permitted-cross-domain-policies="by-content-type" />
  5. </cross-domain-policy>

蓝色行的意思是,要符合要求的文件你才能取,不管你是哪来的flash数据请求。符合要求的文档必须满足:Content-Type: text/x-cross-domain-policy

另:

当Flex访问WebService服务时,在本地能够正常访问,当部署到web容器中发布为web服务后,再调用WebServicIE,此时就会被拒绝访问,这就是Flex跨域访问的沙箱问题,
为了解决Flex跨域访问WebService的问题,可采用如下方案:
首先,跨域访问被拒绝是因为提供服务方没有配置安全策略文件,即crossdomain.xml,如果你不想用crossdomain.xml就要用到代理,即自己写一个后台读取webservice,然后提供给自己的flex应用,因为在flashplayer中,要跨域必须要有策略文件。考虑到 flashplayer升级到9.124之后,加强了安全性,之前的crossdomain.xml的写法发生了变化,以下就是该文件的完整写法:

Xml代码 复制代码 收藏代码
  1. <?xml version="1.0"?>
  2. <!DOCTYPE cross-domain-policy SYSTEM "http://www.macromedia.com/xml/dtds/cross-domain-policy.dtd">
  3. <cross-domain-policy>
  4. <allow-access-from domain="*" />
  5. <allow-http-request-headers-from domain="*" headers="*" />
  6. </cross-domain-policy>

表示该服务允许任何外域来访问。
关于crossdomain.xml的放置目录问题,有如下解决方案,可放置在:

1) 如果这个目录是容器的根目录,可以通过以下的url访问crossdomain.xml:

http://localhost:8080/crossdomain.xml 。

2) 如果crossdomain.xml不是放在根目录下,而是在某个webapp下面,在flex中就需要在初始化的时候应用
Security.loadPolicyFile("http:// localhost:8080/aaa /crossdomain.xml");

其中aaa为webapp的名称
这样,外部Flex访问该服务发布的WebService时,flashplayer首先找的就是crossdomain.xml文件,若安全机

跨域策略文件crossdomain.xml的配置方法

一、crossdomain.xml文件的作用    跨域,顾名思义就是需要的资源不在自己的域服务器上,需要访问其他域服务器。跨域策略文件是一个xml文档文件,主要是为web客户端(如Adobe Fla...
  • gnail_oug
  • gnail_oug
  • 2016年12月06日 16:41
  • 9892

Flash/ActionScript 解决跨域问题的策略文件crossdomain.xml的写法

在做视频截图的时候遇到了 Flash 安全沙箱 错误,到网上找了很多方法,弄了半天,搞得心烦意乱,最后才解决。在这里记下来。 使用 BitmapData.draw Flash弹出这个错误 Secu...
  • RoadToTheExpert
  • RoadToTheExpert
  • 2015年06月10日 09:42
  • 1389

跨域策略文件--crossdomain.xml

1、为什么需要采用 crossdomain.xml 文件? 跨域策略文件 跨域策略文件是一种 XML 文档,旨在为 Web 客户端,比如 Adobe Flash Player 或 Adobe Acr...
  • charleslei
  • charleslei
  • 2016年03月28日 21:55
  • 3176

CrossDomain.xml的作用及其简单用法

使用crossdomain.xml让Flash可以跨域传输数据 本文来自http://www.mzwu.com/article.asp?id=975 一、概述 位于www.mzwu.com域中的...
  • zws1987211
  • zws1987211
  • 2012年01月03日 18:16
  • 43632

crossdomain.xml

  • 2013年09月03日 11:48
  • 164B
  • 下载

nginx配置好后,访问时出现crossdomain.xml

近期配置nginx做反向代理,访问某些页面出现会自动下载crossdomain.xml文件,且访问地址如下: http://backend/crossdomain.xml    查名原因为flex...
  • gobravery
  • gobravery
  • 2017年11月29日 14:31
  • 151

crossdomain.xml文件

当使用WWW访问Web服务时,安全策略会阻止跨域的请求访问,会返回类似“Rejected because no crossdomain.xml policy file was found”等错误信息。...
  • dlnuchunge
  • dlnuchunge
  • 2012年05月18日 08:40
  • 5461

Rejected because no crossdomain.xml policy file was found

Rejected because no crossdomain.xml policy file was found Unity加载Web资源需求crossdomain.xml文件格式...
  • six_sex
  • six_sex
  • 2016年03月19日 17:51
  • 883

跨域策略文件crossdomain.xml配置

参考链接 1,http://blog.csdn.net/gnail_oug/article/details/53488918 2,http://blog.csdn.net/summerhust/a...
  • jason_czm
  • jason_czm
  • 2017年05月03日 15:22
  • 463

crossdomain.xml怎么用

crossdomain.xml是adobe搞的,为了让flash跨域访问文件。 该配置文件放于服务器端的根目录下面。来设置让哪些域名下面的swf文件能够访问我服务器上的内容。 比如:我的服务器...
  • ruanjian11110
  • ruanjian11110
  • 2015年10月10日 15:31
  • 1710
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:关于跨域策略文件crossdomain.xml文件
举报原因:
原因补充:

(最多只允许输入30个字)