Silverlight+WCF 新手实例 象棋 WCF通讯跨域(十五)

简介:

这节我们把WCF独立一个服务出来,不寄放在Web应用程序中。

我们再开一个项目来讲解,上节名称叫Hellow,这节名称起World:

文件—》新建->项目-》Silverlight应用程序-》起名叫:World

确定后还是:World和World.web应用程序,两个项目

 

我们对着解决方案右键,添加新建项目:建立WCF 服务应用程序->输入名称为:WorldService:

接着我们把默认的Service1.cs和Service1.svc删除:

删除后,我们新建一个新的服务,叫Service.svc

我们提前修改下服务的端口,这样添加服务引用后,不用再改配置文件的端口。

好了,现在我们为接口弄多一个方法叫GetWrold:

同时新建一个实体类MyWorld,用于返回,关于实体类的头顶的上标识,上节说过了就不说了。

复制代码
[ServiceContract]
    
public   interface  IService
    {
        [OperationContract]
        MyWorld GetWorld(
int  id);
    }
    [DataContract]
    
public   class  MyWorld
    {
        [DataMember]
        
public   int  ID
        {
            
get ;
            
set ;
        }
         [DataMember]
        
public   string  Name
        {
            
get ;
            
set ;
        }
    }
复制代码

 

好,接下来简单实现接口方法:

复制代码
public   class  Service : IService
    {
        
#region  IService 成员
        
public  MyWorld GetWorld( int  id)
        {
            MyWorld world 
=   new  MyWorld();
            world.ID 
=  id;
            world.Name 
=   " Name is: "   +  id;
            
return  world;
        }
        
#endregion
    }
复制代码

 

OK,WCF服务方法就写完了啦,看,多简单。

现在客户端要调用了,还是像上节一样,添加服务引用:

修改服务名称为WorldService.确认后同样的新增加一个文件夹和一个配置文件。

这里的配置文件我们不用改端口号了,因为我们提前设置项目属性的端口号了。

OK,接着我们还是要弄一个和上次一样的界面,来调用,从上节那里Copy来xaml的代码:

 

复制代码
  < Grid  x:Name ="LayoutRoot"  Background ="White" >
        
< Button  Content ="WCF 调用"  Height ="23"  HorizontalAlignment ="Left"  Margin ="84,111,0,0"  Name ="btnCallWCF"  VerticalAlignment ="Top"  Width ="75"  Click ="btnCallWCF_Click"   />
        
< TextBox  Height ="23"  HorizontalAlignment ="Left"  Margin ="84,71,0,0"  Name ="txtName"  VerticalAlignment ="Top"  Width ="120"   />
        
< TextBlock  Height ="23"  HorizontalAlignment ="Left"  Margin ="228,71,0,0"  Name ="tbMsg"  Text ="显示的内容"  VerticalAlignment ="Top"   />
    
</ Grid >
复制代码

 

后台代码调用也差不多一个样了:

复制代码
private   void  btnCallWCF_Click( object  sender, RoutedEventArgs e)
        {
            Binding binding 
=   new  BasicHttpBinding();
            EndpointAddress endPoint 
=   new  EndpointAddress( " http://localhost:54321/Service.svc " );
            WorldService.ServiceClient client 
=   new  WorldService.ServiceClient(binding, endPoint);
            client.GetWorldCompleted 
+=   new  EventHandler < WorldService.GetWorldCompletedEventArgs > (client_GetWorldCompleted);
            client.GetWorldAsync(
int .Parse(txtName.Text));
        }

        
void  client_GetWorldCompleted( object  sender, WorldService.GetWorldCompletedEventArgs e)
        {
            WorldService.MyWorld world 
=  e.Result;
            
if  (world  !=   null )
            {
                tbMsg.Text 
=  world.Name;
            }
            
else
            {
                tbMsg.Text 
=   " 返回为NULL " ;
            }

        }
复制代码

 

上一节说明了每行代码的意思,这节就不重复了。

但有一个e.Result参数,会根据你方法的返回值不同,而返回的类型是不同的。所以这里的e.Result就是MyWorld类型,不是上节的string类型了。

一切按正规代码写完,按F5,运行

输入数字1:[服务端直接让传数字的,你别乱写其它]

回车调用,啊,出现异常:

看一下,跨域的错误终于出来了。

我们用Firefox跟踪一下调用,看截图大伙看看:

看到没有,有两个404找不到文件的,按官方的说法简单就是:

如果遇到跨域情况,会先找第一个配置文件:clientaccesspolicy.xml

如果找不到,就去找第二个配置文件:crossdomain.xml

所以,新增加一个clientaccesspolicy.xml文件就可以了,第二个配置文件是可以不用的,因为找到后它就不找第二个了。

我们对着WorldService的WCF服务应用程序右键,添加文件->xml文件:

确定后,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 >
复制代码

 

 

保存后,我们再运行F5,还是输入1:

回车调用:

一切正常了。跨域的问题就一个配置文件解决了。

OK,这节到此了,下节我们简单讲讲双工通讯

提供源码下载:点击下载

版权声明:本文原创发表于博客园,作者为路过秋天,原文链接:

http://www.cnblogs.com/cyq1162/archive/2010/07/12/1775939.html

相关文章
|
监控 NoSQL
Wcf通讯基础框架方案(一)——基本结构
由于希望使用Wcf作为公司内的通讯框架,因此基于Wcf进行了一些扩展,主要的目的有以下几个方面: 1) 希望减少客户端调用的复杂度,调用方式简化为WcfServiceLocator.Create().Add(1,2)。
810 0
|
XML 监控 数据格式
Wcf通讯基础框架方案(二)——集中配置
从这次开始在几个方面简单阐述一下实现,集中配置是这个框架很大的一个目的,首先在数据库中会有这么一些表: 其实可以看到这些表的结构,应该是和配置节点中的层次有对应的 1) Service表描述的是服务,主要保存服务行为以及服务的配置。
601 0
|
监控
Wcf通讯基础框架方案(三)——客户端
假设定义了一个服务契约: [ServiceContract(Namespace = "WcfExtension.Services.Interface")] public interface ITestService { [OperationContract] ...
725 0
|
监控 负载均衡 缓存
Wcf通讯基础框架方案(四)——横切日志
在第一篇文章中已经列出了几种日志的概览: 所有的日志都有一个最终基类,来看看这个类: [DataContract(Namespace = "WcfExtension")] [KnownType(typeof(WcfExceptionInfo))] [KnownType(t...
648 0
|
缓存 NoSQL Redis
Wcf通讯基础框架方案(五)——更新通知
对于负载均衡环境,多服务器内存中缓存数据的话,需要解决的一个很重要的问题就是一旦数据库中数据有更新,怎么让缓存的数据立即更新? 如果可以容忍延迟或是差异性的话,可以考虑缓存的数据有一个过期时间。但是,最好的方式还是采用通知方式,或者说发布订阅方式。
827 0
|
SQL 监控 NoSQL
Wcf通讯基础框架方案(六)解决方案说明以及源代码
源代码见 http://wcfextension.codeplex.com/ 注意: 1) 本来没打算这么早开源,这只是一个比较原始的实现,请勿直接在商业环境使用 2) 请注意本框架的授权条款Apache License 2.
705 0
wcf双工通讯
首先说一个服务引用不成功的解决办法: 需要把服务端配置文件中的Binding换成: 或: 下面是一个wcf的简单示例: 服务契约代码: using System.Collections.Generic; using System.Linq; using System.Runtime.Serialization; using System.ServiceModel; using System.Text; namespace WcfService { // 注意: 使用“重构”菜单上的“重命名”命令,可以同时更改代码和配置文件中的接口名“IUser”。
1010 0
WCF入门(四)——会话与实例
会话是两个终结点之间消息交换的一种相互关系;实例化是服务对象的生存期控制。 (一)会话 会话由服务契约的SessionMode属性指定,SessionMode属性用于是否允许,禁止和要求会话状态,它有三种设定: Allowed 如果绑定支持会话,则契约支持会话 Required 要求绑定支持会话,否则引发异常 NotAllowed 指定契约不支持启动会话的绑定 如果服务支持会话,则可以通过实例创建模式属性指定服务契约实例与会话之间的关系。
688 0
|
Web App开发 .NET 测试技术
.net WCF简单实例
  最近看到网上招聘有许多都需要WCF技术的人员,我之前一直没接触过这个东西,以后工作中难免会遇到,所谓笨鸟先飞,于是我就一探究竟,便有了这边文章。由于是初学WCF没有深入研究其原理,只是写了一个demo留着以后,如果哪里写的不对希望大佬们能指出批评。
1078 0
|
数据库 测试技术 安全
使用Entity Framework和WCF Ria Services开发SilverLight之2:POCO
在上一篇中《使用Entity Framework和WCF Ria Services开发SilverLight之1:简单模型》我们提出这类简单模型的几个问题: 1:实体模型被紧耦合在EDM中,同时它不能项目(模块)使用。
1254 0

热门文章

最新文章