博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
使用WC“.NET研究”F实现SOA面向服务编程——简单的WCF开发实例
阅读量:6210 次
发布时间:2019-06-21

本文共 3141 字,大约阅读时间需要 10 分钟。

  前面为大家介绍过WCF的特点,现在再讲解一下。

  在WCF里,各个Application之间的通信是由EndPoint来实现的,EndPoint是WCF实现通信的核心要素。一个WCF Service可由多个EndPoint集合组成,每个EndPoint只能有一种绑定,就是说EndPoint就是通信的入口,客户端和服务端通过 EndPoint交换信息。

 
<
service
name
= " "
>
<
endpoint
address
= ""
binding
= " wsHttpBinding "
contract = " myNamespace.IService "
>
</
endpoint
>
</
service
>

  Endpoint由三部分组成:(A) Address 地址,(B)Binding 绑定,(C)Contract 契约。

  • A(Address): 通过一个URI唯一地标识一个Endpoint,并告诉WCF service的调用者如何找到这个Endpoint。
  • B(Binding): 定义了与数据传输相关的传输协议,消息编码,通信模式,可靠性,安全性,事务,互操作性等信息。Framewrok3.5里已经包括以下几种绑定:

  • C(Contract):它是有关服务响应的操作及进出消息的格式的语法描述,系统就是通过Contract实现操作的。

  下面为大家讲解一下Hello World的开发例子。

  服务器端:

 
using
System;
using
System.ServiceModel;
namespace
myNamespace
{
//
在服务器端定义在一个服务契约
[ServiceContract(Namespace
=
"
myNamespace
"
)]
public
interface
IService
{
[OperationContract]
String HelloWorld();
}
//
实现契约
public
class
MyService:IService
{
public
String HelloWorld(
string
name)
{
return
"
Hello World
"
+
Name;
}
}
}

  最后,服务既可以在代码中实现,也可以在配置文件中实现:

 
<
services
>
<
service
behaviorConfiguration
="ServiceBehavior"
name
="Service"
>
//行为可以影响运行是操作的WCF类,它不公在客户端和服务器启动WCF运行时被执行,还可以在二者之间流动消息时被执行。
<
endpoint
address
=""
binding
="wsHttpBinding"
contract
="IService"
>
<
identity
>
<
dns
value
="localhost"
/>
</
identity
>
</
endpoint
>
<
endpoint
address
="mex"
binding
="mexHttpBinding"
contract
="IMetadataExchange"
/>
//mexHttpBinding定义了WCF的元数据。当没有定义元数据时,服务依然能够执行,但不能在HTTP中被发现。
</
service
>
</
services
>
<
behaviors
>
<
serviceBehaviors
>
<
behavior 上海企业网站制作pan>name="ServiceBehavior">
<serviceMetadata httpGetEnabled="true" />
<serviceDebug includeExceptionDetailInFaults="true" />
</behavior>
</serviceBehaviors>
</behaviors>

  客户端:

  通过Add Service Reference引用服务地址:

  添加配置文件:

 
<
system.serviceModel
>
<
bindings
>

上海闵行企业网站设计与制作 />
<
basicHttpBinding
>
<
binding
name
="wsHttpBinding_IService"
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/myNamespace.IService.svc"
binding
="wsHttpBinding"
bindingConfiguration
="wsHttpBinding_IService"
contract
="myNamespace.IService"
name
="wsHttpBinding_IService"
/>
</
client
>
</
system.serviceModel
>

    最后通过代理直接调用:

 
static
void
Main(
string
[] args)
{
ServiceClient client
=
new
ServiceClient();
string
data
=
client.HelloWorld(
"
Leslie
"
);
Console.Writeline(data);
Console.Read();
}

  朋友,恭喜你,一个最简单Hello World的WCF已经实现。

  然而,如果你要开发一个SOA系统,你不可能将每一个类都编写成一个*.svc文件,那应该怎么做才能真正实现SOA?

  下一章将为你详细介绍如何使用WCF实现真正的SOA。

转载地址:http://ukdja.baihongyu.com/

你可能感兴趣的文章
Apache服务器SSL双向认证配置
查看>>
hdu 1671 Phone List(字典树)
查看>>
论数据库访问组件的选择--火地晋大作读后感
查看>>
php socket服务端和OC客户端(简单的测试)
查看>>
Dialog with HTML skin using CDHtmlDialog and SetWindowRgn
查看>>
看开源代码利器—用Graphviz + CodeViz生成C/C++函数调用图(call graph)
查看>>
回车替换Tab 并不会 提交表单 IE Chrome 通过
查看>>
算法:基于 RingBuffer 的 Deque 实现
查看>>
SharePoint 2013技巧分享系列 - Active Directory同步显示用户照片
查看>>
Xcode :Missing file warnings
查看>>
Four Ways to Create a Thread
查看>>
Unity 物理引擎动力学关节
查看>>
黄聪:360浏览器、chrome开发扩展插件教程(1)开发Chrome Extenstion其实很简单
查看>>
新年是否应该跳槽去外包公司呢?
查看>>
【重温经典算法之二】快速排序
查看>>
浏览器是如何展示网页的
查看>>
架构:Hexagonal Architecture Guidelines for Rails(转载)
查看>>
同源策略
查看>>
各种C#数组的定义和初始化
查看>>
Fragment之间的通信
查看>>