前言:本文旨在帮助从未接触过wcf(.svc文件)的webservice开发人员,快速将传统的webService/asmx技术迁移到wcf。高手就不用浪费时间往下看了:)
以下所有操作均为vs2010 sp1环境
一、服务物理文件创建方式的变化
1.1 asmx的创建方式
新建项-->Web服务
1.2 wcf的创建方式
新建项-->Wcf服务
二、方法定义上的区别
2.1 asmx中的方法定义
2.2 wcf 中的方法定义
这里先啰嗦一下,默认情况下创建一个wcf服务(比如HelloWorld2.svc文件)后,vs.net会自动创建一个IHelloWorld2.cs的接口,然后HelloWorld2类会实现这个接口。
如果这让您感觉不安,可以大胆的把IHelloWorld2.cs接口删除!然后把HelloWorld2.svc.cs中的代码改成下面这样:
即:
a)在需要暴露的class前加上[ServcieContract]标签
b)在需要暴露的Method前加上[OperationContract]标签
三、客户端服务引用方式的变化
实际开发中,通常service层是一个单独项目,而调用service的是另一个项目,所以我们再创建一个Web Application(或WebSite),以充当调用服务器的客户端应用
3.1 asmx引用方式
右击"添加服务引用",会出来一个对话框
如果您用习惯了vs.net2008的"添加服务引用",对这个界面可能会感觉很陌生,没关系,vs2010允许您找回旧时熟悉的感觉,继续点击"高级"
继续点击"添加服务引用",下面这个界面应该再熟悉不过了吧
点击"此解决方案中的Web服务",选择HelloWorld.asmx,Web引用名填写成"YJM"(当然也可以自己随便写)
点击"添加引用"完事,完了以后,在vs2010中与vs2008有一些区别:
在vs2010中web.config中会变成
<applicationSettings> <WebClient.Properties.Settings> <setting name="WebClient_YJM_HelloWorld" serializeAs="String"> <value>http://localhost:3538/HelloWorld.asmx</value> </setting> </WebClient.Properties.Settings> </applicationSettings>
而vs2008添加服务引用后,是类似
<appSettings> <add key="YJM.HelloWorld" value="http://localhost:3538/HelloWorld.asmx"/> </appSettings>
注:部署到生产环境后,只要修改配置文件中的
http://localhost:3538/HelloWorld.asmx 即可实现webservice url的动态调整.(当然如果要在运行时动态指定url,就要代码处理了,后面的示例代码会给出方法)
3.2 wcf 引用方式
右击"添加服务引用",点击"发现"
选择HelloWorld2.svc,命名空间填写"YJM2"(当然也能是其它名字)
点击“确定”完成,web.config中会多出一节内容:
<system.serviceModel> <bindings> <basicHttpBinding> <binding name="BasicHttpBinding_HelloWorld2" closeTimeout="00:01:00" openTimeout="00:01:00" receiveTimeout="00:10:00" sendTimeout="00:01:00" allowCookies="false" bypassProxyOnLocal="false" hostNameComparisonMode="StrongWildcard" maxBufferSize="65536" maxBufferPoolSize="524288" maxReceivedMessageSize="65536" messageEncoding="Text" textEncoding="utf-8" transferMode="Buffered" useDefaultWebProxy="true"> <readerQuotas maxDepth="32" maxStringContentLength="8192" maxArrayLength="16384" maxBytesPerRead="4096" maxNameTableCharCount="16384" /> <security mode="None"> <transport clientCredentialType="None" proxyCredentialType="None" realm="" /> <message clientCredentialType="UserName" algorithmSuite="Default" /> </security> </binding> </basicHttpBinding> </bindings> <client> <endpoint address="http://localhost:3538/HelloWorld2.svc" binding="basicHttpBinding" bindingConfiguration="BasicHttpBinding_HelloWorld2" contract="YJM2.HelloWorld2" name="BasicHttpBinding_HelloWorld2" /> </client> </system.serviceModel>
注:部署到生产环境后,只要修改配置文件中的 http://localhost:3538/HelloWorld2.svc 即可实现wcf url的动态调整.
四、客户端调用代码的变化
这部分太简单了,直接上代码吧
using System; using WebClient.YJM; using WebClient.YJM2; namespace WebClient { public partial class Default : System.Web.UI.Page { protected void Page_Load(object sender, EventArgs e) { #region asmx/webservice调用示例 using (HelloWorld ws = new HelloWorld()) { //System.Diagnostics.Debug.WriteLine(ws.Url); //System.Diagnostics.Debug.WriteLine(Properties.Settings.Default.WebClient_YJM_HelloWorld); //ws.Url = "http://www.youWeb.com/xxx.asmx"; //如果需要动态切换asmx的地址,这一行代码就给出了方法 string result = ws.Hello("client_asmx"); Response.Write("asmx call:" + result + "
"); } #endregion #region svc/wcf 调用示例 using (HelloWorld2Client client = new HelloWorld2Client()) { //System.Diagnostics.Debug.Write(client.Endpoint.ListenUri.ToString()); //client.Endpoint.ListenUri = new Uri("http://www.youWeb.com/xxx.svc");//如果需要动态切换svc的地址,这一行代码就给出了方法 string result = client.Hello("client_wcf"); Response.Write("wcf call:" + result + "
"); } #endregion } } }
运行结果:
示例源码下载:https://files.cnblogs.com/yjmyzz/asmx_update_to_wcf.zip
相信有webservice经验的同学们,看完本篇,已经能顺利升级到wcf了。当然wcf深究下去,远不止本文所写的这么简单,这门技术水还是相当深的,强烈推荐多看看园子里http://www.cnblogs.com/artech/ 的文章,他是园子里(甚至可以说是国内) 我心目中的 wcf第一人,多去看看,必有收获。