上次系统平台嵌套FlashGIS地图的时候,也出现过跨域访问不了的问题
http://can4you.iteye.com/blog/829419
不过那次问题是跨域访问不同服务器上的FlashGIS Framework文件资源(如js,swf等静态文件),因为资源文件时部署在TOMCAT下的,所以问题的解决方案是在TOMCAT目录:webapps/ROOT/下放置一个crossdomain.xml文件,其内容为:
<?xml version="1.0"?>
<cross-domain-policy>
<allow-access-from domain="*" />
</cross-domain-policy>
而这次客户端flash在actionscript脚本中通过调用系统提供的webservice服务来完成它们之间的交互,获取flash上的路径坐标,上传到后台处理,部分actionscript脚本如下:
function update(imageId:String, index:String) {
//构建WebService类,传入服务的自述地址
var ImagePathService:WebService = new WebService("http://localhost:8080/myproj/services/imagePathService?WSDL");
//接收服务的返回结果
ImagePathService.saveNewPoints(imageId, index);
ResultObj = ImagePathService.update(imageId, index);
//判断返回结果并执行操作,onResult监测返回成功事件
ResultObj.onResult = function(result:Boolean) {
//返回值(由web服务返回类型决定)
if (result == true) {
Alert.show("上传成功!");
} else {
Alert.show("上传失败!");
}
};
//判断返回结果并执行操作,onFault监测返回失败事件
ResultObj.onFault = function(result) {
Alert.show("上传失败");
};
}
虽然在Tomcat目录下的webapps/ROOT/下已经存在crossdomain.xml文件,但是还是出现跨域访问不了的问题,无法调用webservice,百思不得其解,在网上找了一下,发现在crossdomain.xml中修改内容可以很好的解决,最后修改如下:
<?xml version="1.0"?>
<cross-domain-policy>
<site-control permitted-cross-domain-policies="all" />
<allow-access-from domain="*" />
<allow-http-request-headers-from domain="*" headers="*"/>
</cross-domain-policy>
相比之前的文件,就增加了<site-control和<allow-http-request-headers-from这两个tag节点,其中前一个不是必须的,但是如果少了<allow-http-request-headers-from节点的话,调用webservice就不行,问题就出在这,参考一下文章找出的解决方案:
http://blog.csdn.net/lena_20081215/archive/2009/01/21/3849009.aspx
解析:
1. WEB服务器是TOMCAT,所以crossdomain.xml文件是放置在根目录即webapps/ROOT/下
2. crossdomain.xml的内容配置和FlashPlayer的版本有关,在9版本之前,通过第一种配置是可以的,但是在版本9和之后的版本对安全策略有着更严格的要求,尤其是对webservice的调用
3. 如果安全策略文件放在根目录,文件名字就必须为crossdomain.xml,这都有严格要求;如果不放置在根目录,需要通过System.security.loadPolicyFile(xml的路径)来加载这个文件
4. 这次主要问题是安全策略的问题,以后如果再涉及到跨越问题时,解决问题就省事多了
其他参考文章:
http://hi.baidu.com/wosinmaiken/blog/item/637a6e4b998a49fe82025c85.html
http://hi.baidu.com/lotusxyhf/blog/item/f1c08a58b5771e88810a1870.html/cmtid/1b4b1036c0ea62d3a3cc2bf2
分享到:
相关推荐
CORS是一种现代的跨域访问解决方案,服务器可以通过设置特定的HTTP响应头`Access-Control-Allow-Origin`来允许特定的源进行跨域访问。在Flex中,你可以通过HTTPService或WebService组件配置`crossDomainPolicy`来...
3. **Flex SDK和.NET的集成工具**:如BlazeDS和LCDS(LiveCycle Data Services),它们提供了与.NET集成的解决方案,支持AMF通信和Web服务。 4. **C#中的WCF(Windows Communication Foundation)**:WCF是.NET ...
对于更复杂的业务逻辑管理,Spring框架提供了集成BlazeDS的解决方案,可以轻松地将Flex与Spring服务和DAO层连接起来。 6. **Security and Cross-Domain Policy** 跨域访问是Flex与Java通信时必须考虑的安全问题。...
- 适用范围:适合寻求高性能解决方案的开发者。 #### II、ArcGIS Server 的 REST 接口 - **REST(Representational State Transfer)的概念**:REST是一种软件架构风格,用于设计和定义服务端和客户端之间如何...
- **特点**:基于Java的RIA解决方案,提供了简洁易用的API来创建桌面和Web应用。JavaFX允许开发者利用Java的强大功能来构建高性能的应用程序。 4. **Curl** - **特点**:一种轻量级的RIA开发平台,专注于提高Web...