2012-11-27 34 views
1

我对Silverlight有点新,我想知道如何处理WCF服务的Faulted/Disposing。Silverlight配置WCF模式(异步)

我习惯了这样的事情(wcf abort/close pattern),你在try/catch中调用服务(确保关闭或放弃)。 (这在无状态应用中效果很好)

看着Silverlight,我们在哪里应用中止/关闭模式?因为服务调用是异步的并且应用程序状态已满。

目前我唯一能想到的就是某种动态代理(使用类似Castle DP的动态代理),以及来自n-tier app, about 1/2 way down the page示例的ChannelFactoryManager。代理将确保始终存在开放通道,并且ChannelFactoryManager将处理故障

回答

1

由于Silverlight网络环境的异步特性,我建议您构建更多可测试的ServiceAgent - 围绕Silverlight客户端代理生存的长期单身包装回调服务方法。在调用服务方法或使用通道Faulted事件之前,您可以检查实际代理状态(如果需要,可重新创建&)。对于前:

public void GetOptionsAsync(Action<GetOptionsCompletedEventArgs> callback) 
{ 
    try 
    { 
     CheckProxy(); 

     EventHandler<GetOptionsCompletedEventArgs> handler = null; 

     handler = (sender, args) => 
     { 
      Proxy.GetOptionsCompleted -= handler; 
      if (args.Error != null) 
      { 
       //... 
      } 
      if (callback != null) 
      { 
       callback(args); 
      } 
     }; 

     Proxy.GetOptionsCompleted += handler; 

     Proxy.GetOptionsAsync(); 
    } 
    catch (Exception unknownException) 
    { 
     //... 
     throw; 
    } 
} 

public override void ResetProxy() //AbortProxy/CloseProxy 
{ 
    if (Proxy != null) 
    { 
     try 
     { 
      Proxy.CloseProxy(); //extension method to handle exception while closing 
     } 
     catch (Exception unknownException) //CommunicationObjectFaultedException 
     { 
      //... 
      Proxy.Abort(); 
     }    
    } 

    CreateProxy();   
} 

public override void CheckProxy() 
{ 
    if (Proxy == null || (Proxy.State != CommunicationState.Opened && Proxy.State != CommunicationState.Created)) 
    {    
     ResetProxy(); 
    } 
} 

public override void CreateProxy() //RecreateProxy 
{   
    Proxy = new WcfClient(); 

    Proxy.InnerChannel.Faulted += OnChannelFaulted; 
} 
+0

谢谢你的输入 - 听起来很接近的问题代理的建议。你的解决方案如何工作,它继承了什么,消费者可以直接使用服务接口,开发人员是否需要为每个服务开发一个包装? – dbones