zoukankan      html  css  js  c++  java
  • WCF 第二章 契约 实现一个双向契约的客户端部分

    为了参与到一个双工消息交换模式中,客户端必须实现WCF的ABCs-必须在客户端定义服务要把消息发送到的地址,指导服务端如何把消息发送给客户端的绑定,定义消息内容和格式的契约。幸运的是,当你生成一个客户端代理而且在运行时使用信道结构时,WCF很大程度上考虑到了这些。
    生成一个客户端代理类,你可以使用svcutil.exe或者添加服务引用。代理定义一个与服务同名的接口,并在后面加上Callback.如果服务契约接口是IStockService,客户端接口就是IStockServiceCallback。客户端必须实现一个从接口继承的类。
    在运行时,与服务类似,客户端通过终结点定义和发送消息给客户端来严格限制访问。服务端终结点和客户端终结点的主要不同在于服务端终结点由WCF动态创建。没有配置文件或者客户端代码中有显式的对ServiceHost的调用。WCF又处理了这些,所以客户端仅需要实现从生成的接口继承的类。
    列表2.9显示了一个调用服务端RegisterForUpdates方法来实现周期性更新的客户端。它也实现了一个服务端要求的PriceUpdate的回调接口来更新stock price.注意一个InstaceContext对象被实例化来创建代理。InstanceContext对象存储一个服务的上下文信息,比如在对客户端创建的进入信道和输出信道的引用。
    列表2.9 在客户端实现双向服务契约
    using System;
    using System.ServiceModel;

    namespace Client
    {
    public class CallbackHandler : IServerStockCallback
    {
    static InstanceContext site =
    new InstanceContext(new CallbackHandler());
    static ServerStockClient proxy = new ServerStockClient(site);
    public void PriceUpdate(string ticker, double price)
    {
    Console.WriteLine(
    "Received alert at : {0}. {1}:{2}",
    System.DateTime.Now, ticker, price);
    }

    class Program
    {
    static void Main(string[] args)
    {
    proxy.RegisterForUpdates(
    "MSFT");
    Console.WriteLine(
    "Press Enter or any key to exit");
    Console.ReadLine();
    }
    }
    }
    }
  • 相关阅读:
    Python_Crawler_Foundation1-2_MYSQL_Regular Expression
    Linux_Best Practice_01_Ubuntu_set prox_set Repositories
    python_Note_Preview_01
    Python_Note_Day 10_Coroutine
    Python_Note_Day 9_threading.Thread_multiprocessing.Process_Queue
    Linux_学习_Day4_user/group/permission
    Linux_学习_Day3_bash
    Linux_学习_Day2~3
    Python_Note_Day 8_socket
    Python_Note_Day 7_Advanced Class
  • 原文地址:https://www.cnblogs.com/danielWise/p/2088442.html
Copyright © 2011-2022 走看看