我相信你基本上有两种选择:
选项 1 - “bin”部署(首选选项)
- 将您的 WCF 服务编译成 DLL(类库)
- 在 IIS 中创建网站
- 将 WCF DLL 复制到网站的
.\bin 文件夹中
- 在该网站中创建一个
*.svc 文件
- 在网站文件夹中添加适当的
web.config 以定义您的端点和服务配置等。
您的 WCF 服务现在可以通过网站的基本地址以及*.svc 文件的名称访问,例如
http://myserver/someweb/Myservice.svc
您的*.svc 看起来像这样:
<%@ ServiceHost Language="C#" Debug="true"
Service="WCF_Simple_Service.HelloIndigoService" %>
Service= 属性表示实现服务的类 - 完全符合其命名空间。
选项 2 - 将内容放入 App_Code
- 在 IIS 中创建网站
- 将所有与 WCF 相关的
*.cs 文件直接放入 .\App_Code 文件夹中
- 在该网站中创建一个
*.svc 文件
- 在网站文件夹中添加适当的
web.config 以定义您的端点和服务配置等。
您的 WCF 服务现在可以通过网站的基本地址以及*.svc 文件的名称访问,例如
http://myserver/someweb/Myservice.svc
您的*.svc 看起来像这样:
<%@ ServiceHost Language="C#" Debug="true"
Service="Service"
CodeBehind="~/App_Code/Service.cs" %>
一个简单的示例web.config 可能看起来像这样:
<system.serviceModel>
<behaviors>
<serviceBehaviors>
<behavior name="WithDebug">
<serviceMetadata httpGetEnabled="true" />
<serviceDebug includeExceptionDetailInFaults="true" />
</behavior>
</serviceBehaviors>
</behaviors>
<serviceHostingEnvironment multipleSiteBindingsEnabled="true" />
<services>
<service name="SimpleWCF.HelloIndigoService" behaviorConfiguration="WithDebug">
<endpoint
address=""
binding="basicHttpBinding"
contract="SimpleWCF.IHelloIndigoService" />
<endpoint
address="mex"
binding="mexHttpBinding"
contract="IMetadataExchange" />
</service>
</services>
</system.serviceModel>
您基本上定义了您的<service> 标记-再次:name= 表示实现服务的类-完全限定其名称空间。它必须至少包含一个端点——“mex”端点是可选的——但非常有用,尤其是对于开发和测试。它允许客户端“发现”服务并获取其服务描述,以便与它进行交互。
在 IIS 中部署您的服务后,您可以使用 WCF 附带的免费工具 WCF Test Client 或通用 SOAP 测试实用程序 SoapUI(免费版)等工具查看它的运行情况供您使用)。