Silverlight2 跨域调用Web服务的方法

Silverlight2 跨域调用Web服务的方法,第1张

概述调用Web服务是一种常见的功能,在Silverlight2中也是可以调用别的网站的Web服务的。由于跨域访问存在安全漏洞,所以,默认情况下,Silverlight2不允许跨域进行服务的调用。要实现跨域调用Web服务,需要在被调用的Web服务的网站跟目录下放置一个策略配置文件:clientaccesspolicy.xml。该文件的内容如下: <?xml version="1.0" encoding=

调用Web服务是一种常见的功能,在Silverlight2中也是可以调用别的网站的Web服务的。由于跨域访问存在安全漏洞,所以,默认情况下,Silverlight2不允许跨域进行服务的调用。要实现跨域调用Web服务,需要在被调用的Web服务的网站跟目录下放置一个策略配置文件:clIEntaccesspolicy.xml。该文件的内容如下: <?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> 
<?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>
 

此文件的意思是允许来自任何域的任何方法的访问。有关Sliverlight2的安全策略,请参考“使服务跨域边界可用”的文章,地址是:http://msdn.microsoft.com/zh-cn/library/cc197955(VS.95).aspx
下面,就做一个调用的例子。

1,建立Silverlight2应用程序的工程,注意此处的工程名字是SilverlightCrossDomainCallWebService,工程名字会影响到代码里面一些对象的名称写法

 

2,添加一个按钮和一个显示信息的文本框,内容如下:<UserControl x:Class="SilverlightCrossDomainCallWebService.Page" 
    xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"   
    xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"   
    WIDth="400" Height="300"> 
 <GrID x:name="LayoutRoot" Background="White"> 
  <StackPanel x:name="buttonPanel" HorizontalAlignment="left"> 
   <button Content="调用" WIDth="200" margin="10" Click="button_Click"></button> 
   <TextBox x:name="Result" WIDth="360" margin="10"></TextBox> 
  </StackPanel> 
 </GrID> 
</UserControl> 
<UserControl x:Class="SilverlightCrossDomainCallWebService.Page"
    xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"
    xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"
    WIDth="400" Height="300">
 <GrID x:name="LayoutRoot" Background="White">
  <StackPanel x:name="buttonPanel" HorizontalAlignment="left">
   <button Content="调用" WIDth="200" margin="10" Click="button_Click"></button>
   <TextBox x:name="Result" WIDth="360" margin="10"></TextBox>
  </StackPanel>
 </GrID>
</UserControl>
 

3,切换到代码视图,在工程上点右键,选择“添加服务引用…”,输入Web服务地址:http://dotnet.aspx.cc/HelloWebService.asmx,名称空间的名字也影响代码的写法,此处需要注意,如图:


4,编写调用代码。

private voID button_Click(object sender,RoutedEventArgs e)  
{  
  MengXianhuiCallWebService.HelloWebServiceSoapClIEnt service = new SilverlightCrossDomainCallWebService.MengXianhuiCallWebService.HelloWebServiceSoapClIEnt();  
  service.HelloWorldCompleted += new EventHandler<SilverlightCrossDomainCallWebService.MengXianhuiCallWebService.HelloWorldCompletedEventArgs>(service_HelloWorldCompleted);  
  service.HelloWorldAsync();  
}  
 
voID service_HelloWorldCompleted(object sender,SilverlightCrossDomainCallWebService.MengXianhuiCallWebService.HelloWorldCompletedEventArgs e)  
{  
  Result.Text = e.Result.ToString();  

private voID button_Click(object sender,RoutedEventArgs e)
{
  MengXianhuiCallWebService.HelloWebServiceSoapClIEnt service = new SilverlightCrossDomainCallWebService.MengXianhuiCallWebService.HelloWebServiceSoapClIEnt();
  service.HelloWorldCompleted += new EventHandler<SilverlightCrossDomainCallWebService.MengXianhuiCallWebService.HelloWorldCompletedEventArgs>(service_HelloWorldCompleted);
  service.HelloWorldAsync();
}

voID service_HelloWorldCompleted(object sender,SilverlightCrossDomainCallWebService.MengXianhuiCallWebService.HelloWorldCompletedEventArgs e)
{
  Result.Text = e.Result.ToString();
}
 
5,输入浏览器 地址进行测试即可,注意:需要使用http方式进行测试,结果如图:

 

 

转载出处:http://blog.csdn.net/net_lover/archive/2009/02/10/3875484.aspx

总结

以上是内存溢出为你收集整理的Silverlight2 跨域调用Web服务的方法全部内容,希望文章能够帮你解决Silverlight2 跨域调用Web服务的方法所遇到的程序开发问题。

如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。

欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/web/1050565.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2022-05-25
下一篇 2022-05-25

发表评论

登录后才能评论

评论列表(0条)

保存