silverlight调用webservice跨域导致问题的解决方法

1 篇文章 0 订阅
1 篇文章 0 订阅

前提说明:

1、Silverlight和Webserive是单独发布在IIS6上的,例silverlight网站为http://192.168.0.189/index.aspx   . webservice的服务地址为http://192.168.0.189/fuwu/fuwu.asmx.意思是先将Webservice服务单独发布,发布后再在Silverlight中引用该Web服务

2、网站的目录,Silverlight目录为IIS的默认目录即(C:\Inetpub\wwwroot)

WebSerivce的服务目录则放在Silverlight的子文件夹fuwu中,

3、虚拟目录,在iis中新增虚拟目录,目录的地址便是webservice的地址

虚拟目录建好后,要保证可以正常浏览,例下图

4.关于Silverlight的服务引用,在建立Silverlight项目时,会自动将Webserive架构在asp.net下

但在发布时,引用的Webserive服务则不能是本机的http://localhost:5774/fuwu.asmx,否则将出现跨域的问题,所以要先将Webserive先前发布,然后在Silverlight中引用该服务,例下图

 

然后生成部署包放在IIS中即可

5.以上4步操作后,还是会出现跨域的问题,根据网上的搜索结果,要放两个xml文件

/*****************clientaccesspolicy.xml*******************/

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

 

/*********************crossdomain.xml***********************************/

<?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>

两个文件具体存放哪个目录下,我没有找到最终结果;但是我索性在wwwroot下的主要目录都放了这两上文件

放会后就OK了,但是我不知道是哪个目录下的xml起的作用

6.网上还有说要将wwwroot的文件夹属性加一个network的权限,于是我也加了

 

最后还有一点,在测试时,每次测试最好清除一下IE缓存,

 

 

如果你的 WebService 与前端代码不在同一个域名下,就会涉及到跨域问题解决跨域问题方法有很多,以下是一些常用的方法: 1. JSONP JSONP 是一种利用 script 标签跨域获取数据的方法。它的原理是在页面中动态创建一个 script 标签,src 属性指向 WebService 的地址,并通过回调函数来接收数据。具体实现可以通过以下步骤: - 在前端页面中定义一个回调函数; - 在 WebService 中定义一个方法方法返回参数为回调函数名称和数据; - 在前端页面中创建一个 script 标签,src 属性指向 WebService 地址,并将回调函数名称作为参数传入; - 当 WebService 返回数据时,会将数据封装成一个 JavaScript 代码块,并通过 script 标签返回给前端页面,并执行回调函数。 2. CORS CORS(Cross-Origin Resource Sharing)是一种浏览器机制,它允许 Web 应用服务器进行跨域访问控制。在 WebService 中添加 CORS 支持,可以使前端页面直接通过 XMLHttpRequest 对 WebService 进行访问。 CORS 的实现需要在 WebService 的响应头中添加 Access-Control-Allow-Origin 字段。该字段的值可以为 *,表示允许任意域名访问,也可以指定特定的域名。 3. 代理 代理是一种常用的跨域解决方案,它的原理是在同一域名下创建一个代理服务器,前端页面通过代理服务器来访问 WebService。代理服务器可以是后端代码,也可以是第三方服务。 在前端页面中,需要将 WebService 的请求发送给代理服务器,代理服务器再将请求转发给 WebService,并将 WebService 的响应返回给前端页面。由于代理服务器和前端页面在同一域名下,因此不存在跨域问题。 以上是几种常用的解决跨域问题方法,具体应该根据实际情况选择。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值