在Silverlight2中跨域调用Web服务

转帖|其它|编辑:郝浩|2009-02-12 11:30:58.000|阅读 730 次

概述:在Silverlight2中跨域调用Web服务

# 界面/图表报表/文档/IDE等千款热门软控件火热销售中 >>

  调用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方式进行测试,结果如图:


标签:

本站文章除注明转载外,均为本站原创或翻译。欢迎任何形式的转载,但请务必注明出处、不得修改原文相关链接,如果存在内容上的异议请邮件反馈至chenjj@evget.com

文章转载自:个人博客

为你推荐

  • 推荐视频
  • 推荐活动
  • 推荐产品
  • 推荐文章
  • 慧都慧问
扫码咨询


添加微信 立即咨询

电话咨询

客服热线
023-68661681

TOP