WCF编码器正确创建方式解读

开发 开发工具
WCF编码器的创建,实现起来看似麻烦,但是实际操作起来还是比较简单的。在这篇文章中,我们可以通过介绍来详细掌握这一应用技巧。

在应用WCF之前,我们需要创建一个编码器来帮组我们的程序开发。那么如何才能正确的实现WCF编码器的创建呢?首先,我们需要创建一个定制的MessageEncoderFactory,它能创建我们的定制的编码器对象,它需要:#t#

一个被覆盖的编码器对象

一个被覆盖的消息版本

包含一个从CustomMessageEncoder工厂创建的名为CustomEncoderFactory的样本类。我们需要将该编码器标记为一个单独的CustomMessageEncoder工厂对象。

为了创建一个CustomEncoderFactory实例,需要传入两个新的东西:一个EncodeMode枚举值以及一个EnableCompression变量:

EncodeMode是一个可根据配置值动态改变编码格式,并且无需知道任何特殊的WCF编码器的深入知识就可以编写压缩/解压缩逻辑的枚举值。它支持各种压缩类型,包括None、Deflate、Gzip,同时,我们还可以添加更多定制的压缩编码器格式:

  1. /// <  summary> 
  2. /// Compression Encoder formats. Add custom encoders such as   
  3. /// ICSharpLib, 7z, rar   
  4. /// <  /summary> 
  5. public enum CompressionEncoder  
  6. {  
  7. None,  
  8. Deflate,  
  9. GZip  

EnableCompression是一个布尔开关值,通过它可以启用或者禁用压缩处理。

接下来,我们需要创建一个CustomEncoder,以实现抽象类MessageEncoder,具体代码如清单2所示。清单2的示例代码实现了IsDataCompressed方法,用以确定数据是否已经压缩。对于Gzip,可以使用“幻码”值来确定数据是否经过压缩处理。

就像前面提到的那样,这个定制的WCF编码器的编码过程是在ReadMessage和WriteMessage方法中进行的。所以,我们还需要覆盖ContentType属性来交付不同的内容类型。枚举类型的CompressionEncoder变量值决定了运行时的内容类型。

然后,我们需要创建一个CustomMessageEncodingBinding元素,以便规定可配置的定制属性,在本例中它包含EnableCompression、CompressionEncoder 和捆绑元素。

***,我们需要创建一个CustomMessageEncodingElement元素,它派生自BindingElementExtensionElement类。
 

从配置文件读取这些值之后,CreateBindingElement方法充当一个入口点,并将这些值转换成定制的捆绑元素的适当的属性。

我们需要注意的事项如下所示:CreateBindingElement方法,它充当一个入口点。

注意,我们可以通过配置修改捆绑元素的messageversion属性,但是为简单起见,我们在此不对此加以讨论。

ApplyConfiguration方法,它使我们可以显式指定属性。

ReaderQuotas,它用来给CustomMesssageEncodingBindingElement指定属性。

值ReaderQuotas.MaxArrayLength可以控制请求大小。因为这个例子使用定制的捆绑,所以需要将其设为捆绑元素。

***,需要实现CustomBindingElement的配置部分。对于客户端,配置看上去是这样的:

  1. < system.serviceModel> 
  2. < extensions> 
  3. < bindingElementExtensions> 
  4. < add name="customMessageEncoding" type="   
  5. Infrastructure.CustomEncoder.CustomMessageEncodingElement, assemblyname" /> 
  6. < /bindingElementExtensions> 
  7. < /extensions> 
  8. < bindings> 
  9. < customBinding> 
  10. < binding name="myBinding"> 
  11. < customMessageEncoding innerMessageEncoding=  
  12. "textMessageEncoding" enableCompression="false" 
  13. compressionEncode="gzip"> 
  14. < readerQuotas maxArrayLength="62914560" >< /readerQuotas> 
  15. < /customMessageEncoding > 
  16. < httpTransport maxBufferSize="62914560"   
  17. maxReceivedMessageSize="62914560" 
  18. authenticationScheme="Anonymous"   
  19. proxyAuthenticationScheme="Anonymous" 
  20. useDefaultWebProxy="true" 
  21. /> 
  22. < /binding> 
  23. < /customBinding>   
  24. < /bindings> 
  25. < client> 
  26. < endpoint address="http://127.0.0.1/mywcf.services/service1.svc" 
  27. binding="customBinding" bindingConfiguration="myBinding" 
  28. contract="IService" name="Service1"> 
  29. < /endpoint> 
  30. < /client> 
  31. < /system.serviceModel> 

上面创建的定制的捆绑使用新的CustomMessageEncoding。请求通常不需要压缩,因为它们通常很小;事实上,压缩它们反而会增加请求的尺寸。因此,以上显示的客户端配置文件了enableCompression ="false"的设置。服务器配置看起来象这样:

  1. < system.serviceModel> 
  2. < extensions> 
  3. < bindingElementExtensions> 
  4. < add name="customMessageEncoding" type="   
  5. Infrastructure.CustomEncoder.CustomMessageEncodingElement, assemblyname" /> 
  6. < /bindingElementExtensions> 
  7. < /extensions> 
  8. < bindings> 
  9. < customBinding> 
  10. < binding name="myBinding"> 
  11. < customMessageEncoding   
  12. innerMessageEncoding="textMessageEncoding"   
  13. enableCompression="true" 
  14. compressionEncode="gzip"> 
  15. < readerQuotas   
  16. maxArrayLength="62914560" > 
  17. < /readerQuotas> 
  18. < /customMessageEncoding > 
  19. < httpTransport maxBufferSize="62914560"   
  20. maxReceivedMessageSize="62914560" 
  21. authenticationScheme="Anonymous"   
  22. proxyAuthenticationScheme="Anonymous" 
  23. useDefaultWebProxy="true" /> 
  24. < /binding> 
  25. < /customBinding>   
  26. < bindings> 
  27. < services> 
  28. < service behaviorConfiguration="Host.Behavior" 
  29. name="Host.Service"> 
  30. endpoint address=""   
  31. binding="customBinding"   
  32. bindingConfiguration="myBinding" 
  33. contract="ServiceContracts.IService" /> 
  34. < endpoint address="mex" binding="mexHttpBinding"   
  35. contract="IMetadataExchange" /> 
  36. < /service> 
  37. < /services> 
  38. < /system.serviceModel> 

通过阅读本文,您会发现向我们的WCF编码器中添加定制的编码不仅简单,而且还是透明的。我们的示例代码不仅包含了文中描述的class属性的详尽的源代码,而且还提供了所需的配置章节。

责任编辑:曹凯 来源: IT168
相关推荐

2010-02-26 13:26:55

WCF消息编码器

2010-03-02 16:05:48

WCF端点配置

2010-02-26 17:44:51

WCF安全参数

2010-03-01 10:26:40

WCF异步服务

2010-02-26 14:05:57

WCF通信方式

2021-03-22 10:52:13

人工智能深度学习自编码器

2021-11-02 20:44:47

数字化

2021-03-29 11:37:50

人工智能深度学习

2009-12-08 14:10:55

Silverlight

2012-04-01 16:40:45

编码器

2012-04-10 16:55:22

PowerSmart编码器

2010-02-24 10:07:48

WCF跨越边界

2010-03-02 09:32:54

WCF服务消息

2023-04-25 21:36:07

火山引擎

2010-02-22 14:09:08

WCF Dispose

2010-03-01 16:59:31

WCF异常调试

2010-02-26 09:33:18

WCF创建WebSer

2010-02-26 15:24:27

WCF释放服务对象

2010-02-26 13:34:50

WCF编码机制
点赞
收藏

51CTO技术栈公众号