silverlight cross domain 访问策略配置文件

<?xml version="1.0" encoding="utf-8"?>
<access-policy>
    <cross-domain-access>
        <policy>
            <allow-from http-request-headers="*">
                <domain uri="*"/>
            </allow-from>
            <grant-to>
                <resource path="/" include-subpaths="true"/>
            </grant-to>
        </policy>
    </cross-domain-access>
</access-policy>

 

跨域访问限制主要为了解决以下安全性问题。

 

假设 用户A访问了 站点B,并在自己的机器上保存了用户凭证(放在cookie里)。  当用户A访问站点C(这是一个恶意站点), 站点C的页面中的脚本在用户不知晓的情况下,偷偷访问了站点B, 由于这是在用户A机器上的一个模拟请求, 所以用户A的凭证被传输到站点B中, B站点认为该用户为有效用户, 这样站点C可以利用自己页面中的脚本肆意的利用用户A的账户做任何站点B运行做的事情。 这显然会对用户A和站点B造成危害, 所以,浏览器设置了跨域访问限制。 脚本对Http的请求只能限制在同一个域中, 同一个域指的是相同的主机名和端口号。 对于Silverlight和flash来说, 跨域访问时必须的, 因为Silverlight的部署站点和Silverlight需要访问的服务站点大多数情况下都不在同一个域下。 所以Silverlight运行时在Silverlight需要访问web服务的时候, 先要在web服务的根目录下获取一个clientaccesspolicy的文件, 如果找到这个文件, 则认为改服务站点可以被Silverlight程序访问。否则禁止访问。(flash也采用这个策略,不过文件名称不同)。

 

对于Silverlight来说,还有一个限制, 如果在本地运行Silverlight程序,则任何访问远程数据的代码都将失败。 本地Silverlight程序只能用来显示一些界面效果。 没有多大用处。

评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值