WCF学习日记

图书馆借阅了《WCF高级编程》,从6.11开始学习wcf,希望尽快熟悉原理和编程模型以及常用编程方法。

WCF是一个平台,也是一个框架,从Net.3.0 就在Net framework(无需安装)
。WCF将服务以SOA架构对外使用。SOA的宗旨就是让应用程序成为一个接口可以供其余程序使用。比如图书订单管理系统,订单履约系统,ship系统,会计系统,以及其它系统,每个都是一个独立的系统,但是彼此系统应该作为接口供别人使用,这样即使扩展了服务或者改善了服务也不会影响原先的体系架构和业务规则。

WCF类似之前的ASP.NET 服务(*.asmx)和remoting,还有ws(web服务增强,MSMQ微软消息队列等)。
remoting都是在远端建立对象,而不是在本地建立对象。

下面是WCF中的一些概念以及原理

  1. 1.契约

  2. 数据契约

消息契约       soap信封,soap头,soap体

服务契约

行为契约

契约就相当于现实生活中的合同。假如买方和卖方之间的合同,需要对产品的质地和零件有限制(数据契约),消息契约(产品完成后,怎样将所有产品交到我手里,物流公司还是卖家自有的车送上门还是买家上门取),服务契约约定卖家要提供什么服务。

2.编程模型

面向服务编程 (松耦合编程,但是同样要面向对象)。而面向对象编程很多类耦合比较小(紧耦合),所有类更同组成一个系统。

服务要自治   自己管理自己,要注意版本控制

编程用到   System.ServiceModel;  注意net2.0
以下无法引用到此类库,引用窗口找不到。只要net 3.0以上的才可以引用,一定要注意项目的生成版本是什么版本必须3.0以上。

3种编程。声明式编程(接口或类上添加属性特性来编程),显示编程(diy
code),配置文件(好处不用重新编译,但是如果是在IIS中应该会断掉服务把)

3.宿主

windows active  service ---windows激活服务,装有此服务上的计算机上可以自动启动wcf 服务

可以做为exe可执行程序启动

windows 服务

msmq???

4. net 3.0 推出system.transaction事务,可以向数据库一样将代码集合作为一个整体提交或者回滚。

事务的4要素:原子,一致,永久,

---------------------------------------------------------------------------------------------

开始编程-

下面是根据书中的代码做的例子

新建网站2.0下的空web服务(删除*.asmx),(新建窗口指向文本文件,修改文件名后缀*.svc)新建空的Service.svc(appcode自动添加一个Service.cs),最后修改web.config,再建立个windows
客户端调用此服务

Service.cs是具体的代码,Service.svc(里面添加一段代码用来指定路径)

Service.svc空文件中新加入的代码  ,定义此服务的名字为MyWCFService

<%@ ServiceHost Language="C#" Debug="true" Service="MyWCFService"
CodeBehind="~/App_Code/Service.cs"%>

Service.cs文件

[ServiceContract]                 
--服务契约,定义在一个接口上
public interface IMyWCFService
{

   
[OperationContract]          
--行为契约
    string Operation1(string myvalue);

}

public class MyWCFService : IMyWCFService
{

public string Operation1(string myvalue)

    {

        return "hello: " + myvalue;

    }
}

web.config中的代码

<?xml version="1.0"?>
<configuration xmlns="http://schemas.microsoft.com/.NetConfiguration/v2.0">

  <system.serviceModel>
   
<services>
      <service
name="MyWCFService" behaviorConfiguration="returnFaults">

        <endpoint
contract="IMyWCFService" binding="wsHttpBinding" address="http://127.0.0.1/service.svc"/>

      </service>

    </services>
   
<behaviors>
     
<!--<behavior name="returnFaults">

        <serviceMetadata
httpGetEnabled="true"/>
     
</behavior>-->
     
<serviceBehaviors>

        <behavior
name="returnFaults">

         
<serviceMetadata httpGetEnabled="true"/>

         
<!--开启元数据发布-->
       
</behavior>
     
</serviceBehaviors>
     
<!--<endpointBehaviors>
     
</endpointBehaviors>-->
   
</behaviors>
  </system.serviceModel>

  <system.web>
    <compilation
debug="true" targetFramework="4.0"/>
   
<pages controlRenderingCompatibilityVersion="3.5"
clientIDMode="AutoID"/>
  </system.web>

</configuration>

至此服务的宿主在IIS中布置完毕了,打开http://127.0.0.1/service.svc,
看到下图服务已经建立好

打开 
http://127.0.0.1/Service.svc?wsdl
,可以看到服务描述语言(和asp.net服务很像)

winform中引用服务

客户端将服务名ServiceReference1,编程的时候就代码服务名,然后通过服务名找到具体的类和操作。(客户端的app.config也可以查看到一些服务信息)

windows客户端有个按钮和文本框,实现点击按钮从服务获取内容后在文本框中显示

private void button1_Click(object sender, EventArgs e)

       {

          
ServiceReference1.MyWCFServiceClient wcfService1 = new
ServiceReference1.MyWCFServiceClient();

          
//wcfService1.Open();

          
textBox1.Text = wcfService1.Operation1("哈哈");

          
//wcfService1.Close();
       }

代码是客户端调用宿主为IIS的服务。

至此第一个wcf代码已经完成

WCF学习日记,布布扣,bubuko.com

时间: 2024-10-03 01:32:19

WCF学习日记的相关文章

学习日记之状态模式和Effective C++

状态模式(State):当一个对象内在状态改变时,允许改变其行为,这个对象看起来像是改变了其类. (1),状态模式主要负责解决的是当控制一个对象转换的条件表达式过于复杂时的情况.把状态的判断逻辑转移到表示不同状态的一系列类中,可以把复杂的判断逻辑简化. (2),状态模式的好处是将与特定状态相关的行为局部化,并且将不同状态的行为分割开来. (3),将特定的状态相关的行为都放入一个对象中,由于所有与状态相关的代码都存在于某个ConcreteState中,所以通过定义新的子类可以很容易地增加新的状态和

学习日记

五一耍了三天,自己的计划有泡汤,那种制止力哪里去了,不过我认真起来还有有废寝忘食的时候,不过希望这种时候多一点,回家妈妈告诉我,她给老师打电话了的,老师说了我的一些情况,不过我没有老师说的那么好,学习在班上算中等.我觉得还算不上吧!任重而道远吧. Java中有个比较重要的类Properties(Java.util.Properties),主要用于读取Java的配置文件,各种语言都有自己所支持的配置文件,配置文件中很多变量是经常改变的,这样做也是为了方便用户,让用户能够脱离程序本身去修改相关的变量

学习日记之解释器模式和Effective C++

解释器模式(interpreter):给定一个语言,定义它的文法的一种表示,并定义一个解释器,这个解释器使用该表示来解释语言中的句子. (1),如果一种特定类型的问题发生的频率足够高,那么可能就值得将该问题的各个实例表述为一个简单语言的句子.这样可以构建一个解释器,该解释器通过解释这些句子来解决该问题. (2),当一个语言需要解释执行,并且你可将该语言中的句子表示为一个抽象的语法树时,可使用解释器模式. (3),容易改变和扩展文法,因为该模式使用类来表示文法规则,你可以使用继承来改变和扩展该文法

学习日记之中介者模式和Effective C++

中介者模式(Mediator):用一个中介对象来封装一系列的对象交互.中介者使各对象不需要显示地相互引用,从而使其耦合松散,而且可以独立地改变他们之间的交互. (1),中介者模式很容易在系统中应用,也很容易在系统中误用.当系统出现多对多交互复杂的对象群时,不要急于使用中介者模式,而要反思你在系统的设计上是不是合理. (2),中介者的出现减少了各个对象的耦合,使得可以独立地改变和复用各个对象和中介者. (3),由于把对象如何协作进行了抽象,将中介者作为一个独立的概念并将其封装在一个对象中,这样关注

学习日记之职责链模式和Effective C++

职责链模式(Chain of Responsibility):使多个对象都有机会处理请求,从而避免请求的发送者和接收者之间的耦合关系.将这个对象连成一条链,并沿着该条链传递该请求,直到有一个对象处理它为止. (1),当客户提交一个请求时,请求时沿着链传递直到有一个 ConcreteHandler 对象负责处理它. (2),接收者和发送者都没有对方的明确信息,切链中的对象自己也不知道链的结构.结果是职责链可简化为对象之间的连接,它们仅需保留一个指向其后继者的引用.而不惜保留它所有的候选接收者的引用

学习日记之单例模式和Effective C++

单例模式(Singleton):保证一个类仅有一个实例,并提供一个访问它的全局访问点. (1),通常我们可以让一个全局变量使得一个对象被访问,但它不能防止你实例化多个对象.一个最好的办法就是,让类自身负责保存它的唯一实例.这个类可以保证没有其他实例被创建,并且它可以提供一个访问该实例的方法. (2),lock 是确保当一个线程位于代码的临界区时,另一个线程不进入临界区.如果其他线程试图进入锁定的代码,则它将一直等待,知道该对象被释放. (3),双重锁定解决效率问题. (4),C#与公共语言运行库

学习日记之迭代器模式和Effective C++

迭代器模式(Iterator):提供一种方法顺序访问一个聚合对象的各个元素,而又不暴露该对象的内部表示. (1),当需要访问一个聚合对象,而且不管这些对象是什么都需要遍历的时候,你就应该考虑迭代器模式. (2),你需要对聚集有多种方式遍历时,可以考虑用迭代器模式. (3),当遍历不同的聚集结构,应提供如开始.下一个.当前项等统一的接口. (4),迭代器模式就是分离了集合对象的遍历行为,抽象出一个迭代器来负责,这样即可以做到不暴露集合的内部结构,又可让外部代码透明地访问集合内部的数据. Effec

学习日记之适配器模式和Effective C++

适配器模式(Adapter):将一个类的接口转换为客户希望的另一个接口.Adapter 模式使得原本由于接口不兼容而不能一起工作的那些类可以一起工作. (1),系统的数据和行为都正确,但接口不符时,我们应该考虑适配器模式,目的是使控制范围之外的一个原有对象与某个接口匹配.适配器模式主要应用于希望复用一些现存的类,但是接口又与复用环境要求不一致的情况. (2),使用一个已经存在的类,但如果他的接口,也就是他的方法和你的要求不相同时,经营该考虑适配器模式. (3),两个类所做的事情相同或相似,但是具

工厂方法模式和Effective C++学习日记

简单工厂模式VS工厂方法模式: 简单工厂模式:最大优点在于工厂类中必须包含必要的逻辑判断,根据客户端选择条件动态实例化相关类,对于客户端来说,去除了与具体产品的依赖. 工厂方法模式(Factory Method),定义一个用于创建对象的接口,让子类决定实例化哪一个类.工厂方法模式使一个类的实例化延迟到其子类. 工厂方法模式实现时,客户端需要决定实例化哪一个工厂来实现相应的类,选择判断的问题还是存在的,也就是说,工厂方法模式把简单工厂的内部逻辑判断移动了客户端代码来进行.想要加功能,在简单工厂模式