加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 百科 > 正文

Flex跨域调用Webservice 问题 解决 Channel.Security.Error

发布时间:2020-12-15 05:10:46 所属栏目:百科 来源:网络整理
导读:环境: arcgis 10 server,map,catalog,flex2.5,xp系统上的IIS6.0 问题症状: catalog建立发布好服务后,用flex viewer调用服务显示提示提示错误,错误信息为 faultCode="Channel.Security.Error" ??????????????? Security error accessing url 还有其他

环境: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

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读