在本文中,咱们将会在local development fabric上建立一个WCF服务角色,而后在一个控制台应用程序中使用它。浏览器
WCF服务角色可让咱们建立一个WCF服务,而且把它托管在Windows Azure中。在本文中,咱们将会建立一个WCF服务角色,把它托管在local development fabric上,而后在一个控制台应用程序中使用它。在下一篇文章中,咱们将会把这个WCF服务迁移到Azure门户中。测试
首先spa
1,建立一个新项目code
2,导航到“Cloud”标签orm
3,建立Windows Azure项目资源
4,在给出的选项中选择WCF服务角色rpc
若是你看一下解决方案资源管理器,你会发现这个WCF服务角色项目的结构和文件与正常建立的WCF服务应用程序彻底相同。它包含:get
1,IService1.cs(服务契约)string
2,Service1.svc.cs(服务定义)it
3,Web.config(EndPoint的配置)
咱们能够按照咱们的需求来修改这些文件,这和咱们平时在一个WCF服务应用程序中作的事情没有什么两样。
让咱们来修改服务契约:
IService1.svc
using System.ServiceModel;
namespace WCFServiceWebRole1
{
[ServiceContract]
public interface IService1
{
[OperationContract]
string GetData(int value);
}
}
而后,修改服务定义:
Service1.svc.cs
namespace WCFServiceWebRole1
{
public class Service1 : IService1
{
public string GetData(int value)
{
return string.Format("You entered: {0}", value);
}
}
}
在Web.Config中保留默认的配置。
确保你已经把Windows Azure项目设置成启动项目了,而后运行这个应用程序。在浏览器中,你会获得以下错误信息:
忽略这个错误信息,而后把一个URL添加到“Service1.svc”中,这个URL应该是http://127.0.0.1:81/Service1.svc。“Service1.svc”是服务定义的名字。添加之后,你会在浏览器中获得一般的WCF服务消息
要在一个控制台客户端中测试这个WCF服务角色,须要:
1,建立一个控制台应用程序项目
2,使用指定的URL(http://127.0.0.1:81/Service1.svc)来添加服务引用
如今,咱们编写一个正常的服务调用:
Program.cs
using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using ConsoleApplication14.ServiceReference1;
namespace ConsoleApplication14
{
class Program
{
static void Main(string[] args)
{
Service1Client proxy = new Service1Client();
var result = proxy.GetData(99);
Console.WriteLine(result);
Console.ReadKey(true);
}
}
}
如今,当你运行这个应用程序的时候,你也许会获得下面这个异常:
要解决上面这个异常,咱们必需要编辑“App.Config”文件。咱们须要修改这个配置文件:
“127.0.0.1”表明“localhost”。也许这个控制台应用程序不能解析“127.0.0.1”,因此,咱们把它改为“localhost”:
如今,运行这个应用程序,咱们会获得以下输出:
这里,咱们须要注意的一个行为是,有时,在把“127.0.0.1”改为“localhost”之后,你可能仍是会获得那个超时异常。在我之后的文章中,我会深刻研究一下这个意料以外的行为。
原文名:Windows Azure for Developers Task 8: Working with WCF Service Web Role 做者: Dhananjay Kumar