原文:在 VS 类库项目中 Add Service References 和 Add Web References 的区别
出身问题:
1.在vs2005时代,Add Web Reference(添加Web服务引用)的功能主要是添加Web Service引用。基于.NET Framework 2.0。
2.自VS2008以后,为了对.NET Framework 3.0 或 3.5版本上WCF Service Library的支持。增加了Add Service Reference(添加服务引用)功能。但为了版本向前兼容而保留了Add Web Reference(添加Web服务引用)。
生成引用文件的区别(本段来自于网上评论,仅供参考):
用两种方式添加同一个WebService,生成 Reference.cs的区别:
1.主要添加引用都有一个获取服务元数据,反序列话本地类文件的过程。这个结构也基本类似。都包含wsdl\discovery等文件。
这个也和WCF Service支持Web Service的核心行业标准有关系。毕竟WCF的特性之一就是兼容Web Service的特性。
2.不同的地方时Add Web Reference 生成的 Reference.cs文件里,包含一个服务代理类,他负责与Web服务通信,它继承一个Soap类,使用SOAP协议,SOAP简单对象访问协议,基于XML语言。此外还包含一些Web服务类里定义的方法,和与之相关的异步调用方法和事件。遵守.NET Web Service 的主要规则。
3.Add Service Reference生成的客户端文件 Reference.cs。我看了一下,这个也会反序列化一个本地代理类,很相似和前者。不过除了服务类和其相关的一些别的类和契约接口。其中比较重要就是一个契约和一个通信管道。这个主要和WCF框架的编程模型和反序列话机制有关系。因为WCF 强调的是 契约的概念,还有就是绑定协议,这个就直接决定了客户端和服务端通信的通道类型。你在这个文件里也能看到。此外还有服务请求和相应对应的信息。遵循WCF服务框架的规则。
使用区别:
1.Add Web Reference:
构造实例 WebReference1.Service1 webs1 = new WebReference1.Service1()的构造方法不可重载。使用实例webs1时,可以通过webs1.Url来改变引用的地址。如:webs1.Url = "http://localhost:7280/Service1.asmx"。
2.Add Service Reference:
构造实例WebReference1.Service1 webs1 = new WebReference1.Service1()提供重载构造方法,默认构造方法引用的地址为<client>节点下<endpoint>中的配置地址,也可用ServiceReference1.Service1SoapClient webs2 = new ServiceReference1.Service1SoapClient("Service1Soap", "http://localhost:7280/Service1.asmx")来指定服务地址。不可以再用webs2.Url = "http://localhost:7280/Service1.asmx"来改变服务地址。
使用区表小结:
Add Service Reference只能在构造实例实例时指定服务地址,不可动态改变。这样可以再编译时检查出错误,以减少运行时错误。