前面一篇文章《WCF 学习总结1 -- 简单实例》 一股脑儿展示了几种WCF部署方式,其中配置文件(App.config/Web.config)都是IDE自动生成,省去了我们不少功夫。现在回过头来看看IDE提供的Wcf Service Library项目模板中的默认服务端配置文件--App.config里面究竟有什么秘密。

服务端的配置文件主要是对services、bindings、behaviors的配置。在默认的App.config中,使用的是WCF Framework定义好的wsHttpBinding默认配置,所以看不到binding配置节。

配置节展开如下图:

BTW: "元数据端点”通过WS-MetadataExchange帮我们实现了对服务的描述,提供了WSDL,启动Host之后我们可以通过<http://localhost:8732/Design_Time_Addresses/WcfServiceLib/Service1/?wsdl> 查看到公开的服务描述。

配置节展开如下图:

关于WCF中的地址和绑定,需要补充一下。

WCF中支持的传输协议包括HTTP、TCP、Peer network(对等网)、IPC(基于命名管道的内部进程通信)以及MSMQ(微软消息队列),每个协议对应一个地址类型:

  • HTTP地址:<http://localhost:8080/>
  • TCP地址: net.tcp://localhost:8080/
  • IPC地址: net.pipe://localhost/  (适用于跨进程,不能使用于不同机器间)
  • MSMQ地址: net.msmq://localhost/
  • 对等网地址: net.p2p://localhost/

WCF中提供的绑定有:

  • BasicHttpBinding: 最简单的绑定类型,通常用于 Web Services。使用 HTTP 协议,Text/XML 编码方式。
  • WSHttpBinding: 比 BasicHttpBinding 更加安全,通常用于 non-duplex 服务通讯。
  • WSDualHttpBinding: 和 WSHttpBinding 相比,它支持 duplex 类型的服务。
  • WSFederationHttpBinding: 支持 WS-Federation 安全通讯协议。
  • NetTcpBinding: 效率最高,安全的跨机器通讯方式。
  • NetNamedPipeBinding: 安全、可靠、高效的单机服务通讯方式。
  • NetMsmqBinding: 使用消息队列在不同机器间进行通讯。
  • NetPeerTcpBinding: 使用 P2P 协议在多机器间通讯。
  • MsmqIntegrationBinding: 使用现有的消息队列系统进行跨机器通讯。如 MSMQ。

------ 弱弱的分隔线 -----

OK,有了上面的基础,就让WCF风暴来的猛烈些吧。做一个多服务,多端点的示例。

1.WcfServiceLib 代码:

[ServiceContract] 

   publicinterfaceIService 

  

       [OperationContract] 

       stringGetMessage(); 

  

   publicclassService1 : IService 

  

       publicstringGetMessage() 

       { 

           var address = OperationContext.Current.Channel.LocalAddress.ToString(); 

           returnstring.Format("From Server1: Hello Client at [{0}]", address);  

       } 

  

   publicclassService2 : IService 

  

       publicstringGetMessage() 

       { 

           var address = OperationContext.Current.Channel.LocalAddress.ToString(); 

           returnstring.Format("来自Service2: Client at [{0}]", address); 

       } 

  

2.WcfConsoleHost 代码:

   staticvoidMain(string[] args) 

  

       ServiceHost host1 = newServiceHost(typeof(WcfServiceLib.Service1)); 

       host1.Open(); 

       Console.WriteLine("Server1 Opened!"); 

       ServiceHost host2 = newServiceHost(typeof(WcfServiceLib.Service2)); 

       host2.Open(); 

       Console.WriteLine("Server2 Opened!"); 

       Console.Read(); 

  

3.服务端配置文件:

  
<?xml
version="1.0"encoding="utf-8"?> 

  
<configuration>
 

  
 
<system.web> 

  
   
<compilationdebug="true"/> 

  
 
</system.web> 

  
 
<system.serviceModel> 

  
   
<services> 

  
     
<servicename="WcfServiceLib.Service1"> 

  
       
<host> 

  
         
<baseAddresses> 

  
           
<addbaseAddress=
"http://localhost:9999/WcfStudy3/Service1"/> 

  
           
<addbaseAddress=
"net.tcp://localhost:8888/WcfStudy3/Service1"/> 

  
         
</baseAddresses> 

  
       
</host> 

  
       
<endpointaddress="serviceEN_1"binding="wsHttpBinding"contract="WcfServiceLib.IService"/> 

  
       
<endpointaddress="serviceEN_2"binding="mexTcpBinding"contract="WcfServiceLib.IService"/> 

  
       
<endpointaddress="mex"binding="mexHttpBinding"contract="IMetadataExchange"/> 

  
     
</service> 

  
     
<servicename="WcfServiceLib.Service2"> 

  
       
<host> 

  
         
<baseAddresses> 

  
           
<addbaseAddress=
"http://localhost:9999/WcfStudy3/Service2"/> 

  
           
<addbaseAddress=
"net.tcp://localhost:8888/WcfStudy3/Service2"/> 

  
         
</baseAddresses> 

  
       
</host> 

  
       
<endpointaddress="serviceCH_1"binding="wsHttpBinding"contract="WcfServiceLib.IService"/> 

  
       
<endpointaddress="serviceCH_2"binding="mexTcpBinding"contract="WcfServiceLib.IService"/> 

  
       
<endpointaddress="mex"binding="mexHttpBinding"contract="IMetadataExchange"/> 

  
     
</service> 

  
   
</services> 

  
   
<behaviors> 

  
     
<serviceBehaviors> 

  
       
<behavior> 

  
         
<serviceMetadatahttpGetEnabled="True"/> 

  
         
<serviceDebugincludeExceptionDetailInFaults="true"/> 

  
       
</behavior> 

  
     
</serviceBehaviors> 

  
   
</behaviors> 

  
 
</system.serviceModel> 

  
</configuration>
 

4. 启动Host,在Client工程中添加Service Reference

因为有两个Service,所以要添加两次。
(1) WcfSvc1(Url:http://localhost:9999/WcfStudy3/Service1

(2) WcfSvc2(Url:<http://localhost:9999/WcfStudy3/Service2>) 图略

5. 客户端配置文件: 配置节中,生成了4个Endpoint,分别对应服务端的4个Endpoint。通过
name属性区别。

  
<client>

<endpoint
address="http://localhost:9999/WcfStudy3/Service1/serviceEN_1"

binding="wsHttpBinding"
bindingConfiguration="WSHttpBinding_IService"

contract="WcfSvc1.IService"
name="WSHttpBinding_IService">

</endpoint>

<endpoint
address="net.tcp://localhost:8888/WcfStudy3/Service1/serviceEN_2"

binding="netTcpBinding"
bindingConfiguration="MetadataExchangeTcpBinding_IService"

contract="WcfSvc1.IService"
name="MetadataExchangeTcpBinding_IService"
/>

<endpoint
address="http://localhost:9999/WcfStudy3/Service2/serviceCH_1"

binding="wsHttpBinding"
bindingConfiguration="WSHttpBinding_IService1"

contract="WcfSvc2.IService"
name="WSHttpBinding_IService1">

</endpoint>

<endpoint
address="net.tcp://localhost:8888/WcfStudy3/Service2/serviceCH_2"

binding="netTcpBinding"
bindingConfiguration="MetadataExchangeTcpBinding_IService1"

contract="WcfSvc2.IService"
name="MetadataExchangeTcpBinding_IService1"
/>

  
</client>

6.
客户端代码:

  
static
voidMain(string[] args) 

  

  
   
Console.WriteLine("------------"); 

  
   
WcfSvc1.ServiceClient
client1_1 =
newWcfSvc1.ServiceClient("WSHttpBinding_IService"); 

  
   
Console.WriteLine(client1_1.GetMessage()); 

  
   
Console.WriteLine("------------"); 

  
   
WcfSvc1.ServiceClient
client1_2 =
newWcfSvc1.ServiceClient("MetadataExchangeTcpBinding_IService"); 

  
   
Console.WriteLine(client1_2.GetMessage()); 

  
   
Console.WriteLine("------------"); 

  
   
WcfSvc2.ServiceClient
client2_1 =
newWcfSvc2.ServiceClient("WSHttpBinding_IService1"); 

  
   
Console.WriteLine(client2_1.GetMessage()); 

  
   
Console.WriteLine("------------"); 

  
   
WcfSvc2.ServiceClient
client2_2 =
newWcfSvc2.ServiceClient("MetadataExchangeTcpBinding_IService1"); 

  
   
Console.WriteLine(client2_2.GetMessage()); 

  
   
Console.Read(); 

  

7.运行结果:

有人会问,那么生成完的配置文件都要一个个手动修改吗?答案当然不是,VS已经为我们准备了WCF配置工具:IDE > Tools > WCF
Service Configuration Editor 。 关于工具的使用,大家可以看这里: <http://www.rainsts.net/article.asp?id=441>

WCF配置详解的更多相关文章

  1. Log4j配置详解(转)

    一.Log4j简介 Log4j有三个主要的组件:Loggers(记录器),Appenders (输出源)和Layouts(布局).这里可简单理解为日志类别,日志要输出的地方和日志以何种形式输出.综合使 ...

  2. logback 常用配置详解<appender>

    logback 常用配置详解 <appender> <appender>: <appender>是<configuration>的子节点,是负责写日志的 ...

  3. [转]阿里巴巴数据库连接池 druid配置详解

    一.背景 java程序很大一部分要操作数据库,为了提高性能操作数据库的时候,又不得不使用数据库连接池.数据库连接池有很多选择,c3p.dhcp.proxool等,druid作为一名后起之秀,凭借其出色 ...

  4. libCURL开源库在VS2010环境下编译安装,配置详解

    libCURL开源库在VS2010环境下编译安装,配置详解 转自:http://my.oschina.net/u/1420791/blog/198247 http://blog.csdn.net/su ...

  5. logback配置详解3<filter>

    logback 常用配置详解(三) <filter> <filter>: 过滤器,执行一个过滤器会有返回个枚举值,即DENY,NEUTRAL,ACCEPT其中之一.返回DENY ...

  6. logback配置详解2<appender>

    logback 常用配置详解(二) <appender> <appender>: <appender>是<configuration>的子节点,是负责写 ...

  7. log4j.properties配置详解

    1.Loggers Loggers组件在此系统中被分为五个级别:DEBUG.INFO.WARN.ERROR和FATAL.这五个级别是有顺序的,DEBUG < INFO < WARN < ...

  8. Log4J日志配置详解

    一.Log4j简介 Log4j有三个主要的组件:Loggers(记录器),Appenders (输出源)和Layouts(布局).这里可简单理解为日志类别,日志要输出的地方和日志以何种形式输出.综合使 ...

  9. Windows下Nginx Virtual Host多站点配置详解

    Windows下Nginx Virtual Host多站点配置详解 此教程适用于Windows系统已经配置好Nginx+Php+Mysql环境的同学. 如果您还未搭建WNMP环境,请查看 window ...

随机推荐

  1. LA 3704 Cellular Automaton

    题意概述: 等价地,本题可以转化为下面的问题: 考虑$n \times n$的$0-1$矩阵$A$,在第$i$行上第$[-d+i, d+i]$(模$n$意义下)列对应的元素为$1$,其余为$0$.求$ ...

  2. R2D2 and Droid Army(多棵线段树)

    R2D2 and Droid Army time limit per test 2 seconds memory limit per test 256 megabytes input standard ...

  3. JAVA基础知识之网络编程——-使用Proxy创建连接

    在前面的HTTP网络通信的例子中,使用了URLConnection conn = url.openConnection();连接网络, 如果改用URLConnection conn = url.ope ...

  4. xcodeheader search 配置

    一般我们在xcode里面配置包含工程目录下头文件的时候,都要关联着相对路径和绝对路径,如果只是自己用这个项目,用绝对路径的问题不大,但是如果你把工程发给别人,别人就要在改这个绝对路径,这时候绝对路径的 ...

  5. ContentProvider官方教程(8)自定义MIME

    MIME Type Reference Content providers can return standard MIME media types, or custom MIME type stri ...

  6. django 的auth.authenticate返回为None

    使用auth.authenticate(username= username,passowrd=passowrd),这个用户认证时候,明明数据库中有记录,但是返回就None 我的错误点比较多: 1.我 ...

  7. jquery加载页面的方法

    jquery加载页面的方法(页面加载完成就执行),建议大家看下windows.onload与$(document).ready之间的区别.   1.$(function(){ $("#a&q ...

  8. [Effective Java]第十一章 序列化

    声明:原创作品,转载时请注明文章来自SAP师太技术博客( 博/客/园www.cnblogs.com):www.cnblogs.com/jiangzhengjun,并以超链接形式标明文章原始出处,否则将 ...

  9. NSKeyedArchive(存储自定义对象)

    在viewController.m中: - (void)viewDidLoad { [super viewDidLoad]; ZWPerson *p = [[ZWPerson alloc] init] ...

  10. FJNU 1153 Fat Brother And XOR(胖哥与异或)

    FJNU 1153 Fat Brother And XOR(胖哥与异或) Time Limit: 1000MS   Memory Limit: 257792K [Description] [题目描述] ...