环境:arcgis 10 server,map,catalog,flex2.5,xp系统上的IIS6.0
问题症状:catalog建立发布好服务后,用flex viewer调用服务显示提示提示错误,错误信息为
faultCode="Channel.Security.Error"
??????????????? Security error accessing url
还有其他一些提示信息,忘了保存了。
解决办法:
在server根目录建立一个文件crossdomain.xml,内容为
<?xml version="1.0"?>
<cross-domain-policy>
????<allow-access-from domain="*" />
</cross-domain-policy>
这样既可解决!
?
参考信息如下:??
?最近在用Flex做一个项目,在本机调试一切正常,传到服务器上之后出现如下错误:
????????[RPC Fault faultString="Security error accessing url"
????????faultCode="Channel.Security.Error"
????????faultDetail="Unable to load WSDL.
????查明是swf文件跨域访问安全机制的问题,最简单的解决办法就是在所调用的webservice服务器的根目录上加上一个策略文件,默认名为crossdomain.xml内容如下:
????
<?xml version="1.0"?>
<cross-domain-policy>
????<allow-access-from domain="*" />
</cross-domain-policy>
???? 同样也可以在代码中调用
??flash.system.Security.loadPolicyFile(http://mydomain/crossdomain.xml);方法来加载策略文件。加上策略文件之后,以为这下应该没有可以了,但不幸的是又出现新的错误,这次错误信息有所不同,但同样和跨域访问有关系,错误如下:
????????[RPC Fault faultString="Security error accessing url"
????????faultCode="Channel.Security.Error"
????????faultDetail="Destination: DefaultHTTP"]
????最后发现是flash播放器版本更新成9.0.124之后,对安全方面有很多的改变,所以造成了这种错误的出现,解决办法也很简单,在原来的crossdomain.xml文件中加入以下代码即可
???? <allow-http-request-headers-from domain="*" headers="*"/>
????关于flash player 9.0.124版本的安全方面的改变可以以下参考adobe的文档
????http://www.adobe.com/devnet/flashplayer/articles/flash_player9_security_update.html
????http://kb.adobe.com/selfservice/viewContent.do?externalId=kb403185&sliceId=2
完整代码:
<?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> 位置: C:inetpubwwwroot