Flex跨域访问沙箱问题解决方案

开发 后端
本文向大家简单介绍一下Flex跨域访问的沙箱问题解决方案,当Flex访问WebService服务时,在本地能够正常访问,当部署到web容器中发布为web服务后,就需要Flex跨域访问。

本文和大家重点讨论一下Flex跨域访问的沙箱问题,当Flex访问WebService服务时,在本地能够正常访问,当部署到web容器中发布为web服务后,再调用WebServicIE,此时就会被拒绝访问,这就是Flex跨域访问的沙箱问题,下面介绍一下解决方案。

Flex跨域访问的沙箱问题

当Flex访问WebService服务时,在本地能够正常访问,当部署到web容器中发布为web服务后,再调用WebServicIE,此时就会被拒绝访问,这就是Flex跨域访问的沙箱问题,为了解决Flex跨域访问WebService的问题,可采用如下方案:

首先,Flex跨域访问被拒绝是因为提供服务方没有配置安全策略文件,即crossdomain.xml,如果你不想用crossdomain.xml就要用到代理,即自己写一个后台读取webservice,然后提供给自己的flex应用,因为在flashplayer中,要Flex跨域必须要有策略文件。考虑到flashplayer升级到9.124之后,加强了安全性,之前的crossdomain.xml的写法发生了变化,以下就是该文件的完整写法:

  1. <?xmlversionxmlversion="1.0"?> 
  2. <!DOCTYPEcross-domain-policySYSTEM"http://www.macromedia.com/xml/dtds/cross-domain-policy.dtd"> 
  3. <cross-domain-policy> 
  4. <allow-access-fromdomainallow-access-fromdomain="*"/> 
  5. <allow-http-request-headers-fromdomainallow-http-request-headers-fromdomain="*"headers="*"/> 
  6. </cross-domain-policy> 
  7.  

 表示该服务允许任何外域来访问。

关于crossdomain.xml的放置目录问题,有如下解决方案,可放置在:

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

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

2)如果crossdomain.xml不是放在根目录下,而是在某个webapp下面,在flex中就需要在初始化的时候应用

Security.loadPolicyFile("http://localhost:8080/xx/crossdomain.xml");

其中xx为webapp的名称

这样,外部Flex跨域访问该服务发布的WebService时,flashplayer首先找的就是crossdomain.xml文件,若安全机制设置为允许访问,则访问成功。

【编辑推荐】

  1. Flex样式的添加和卸载
  2. Flex安全沙箱问题解决方法
  3. 技术前沿 看Flex客户端缓存技术如何使用
  4. 解析Flex全屏模式设置方法
  5. Flex内存泄露解决方法和内存释放优化原则
责任编辑:佚名 来源: rommayer
相关推荐

2010-02-24 10:55:01

WCF跨域访问

2012-05-09 10:08:41

跨机房

2010-07-29 15:28:47

Flex安全沙箱

2010-08-03 09:12:52

Flex安全沙箱

2010-08-04 10:20:30

Flex组件开发

2010-05-31 12:53:56

Nagios apac

2009-12-22 11:21:43

WCF跨域访问

2019-11-11 17:34:16

前端开发技术

2010-03-30 16:04:34

Linux Nginx

2010-09-27 13:14:42

JVM内存限制

2009-03-18 09:26:23

Winform多线程C#

2010-05-20 11:06:01

IIS服务器

2024-12-02 14:30:20

2010-02-06 14:54:11

C++指针漂移

2010-10-08 13:09:38

JavaScript数

2010-04-28 19:24:17

Hp unix

2011-03-23 16:38:28

LAMP

2021-01-13 10:18:29

SocketNetty粘包

2010-10-09 12:58:59

JS脚本兼容

2010-09-07 09:08:03

DIV弹出层
点赞
收藏

51CTO技术栈公众号