Megosztás a következőn keresztül:


Útmutató: Szolgáltatások elérése kétoldalas szerződéssel

A Windows Communication Foundation (WCF) egyik funkciója, hogy kétoldalas üzenetkezelési mintát használó szolgáltatást hozhat létre. Ez a minta lehetővé teszi, hogy a szolgáltatás visszahíváson keresztül kommunikáljon az ügyféllel. Ez a témakör bemutatja a WCF-ügyfél létrehozásának lépéseit egy ügyfélosztályban, amely implementálja a visszahívási felületet.

A kettős kötés az ügyfél IP-címét teszi elérhetővé a szolgáltatás számára. Az ügyfélnek a biztonság használatával kell biztosítania, hogy csak a megbízható szolgáltatásokhoz csatlakozzon.

Az alapszintű WCF-szolgáltatás és -ügyfél létrehozásáról szóló oktatóanyagért tekintse meg az Első lépések oktatóanyagot.

Kétoldalas szolgáltatás elérése

  1. Hozzon létre egy szolgáltatást, amely két felületet tartalmaz. Az első felület a szolgáltatáshoz tartozik, a második a visszahíváshoz. A kétoldalas szolgáltatás létrehozásával kapcsolatos további információkért lásd : Kétoldalas szerződés létrehozása.

  2. Futtassa a szolgáltatást.

  3. A ServiceModel Metadata Segédprogram (Svcutil.exe) használatával szerződéseket (interfészeket) hozhat létre az ügyfél számára. Ennek módjáról további információt az Ügyfél létrehozása című témakörben talál.

  4. Implementálja a visszahívási felületet az ügyfélosztályban az alábbi példában látható módon.

    public class CallbackHandler : ICalculatorDuplexCallback
    {
        public void Result(double result)
        {
            Console.WriteLine("Result ({0})", result);
        }
        public void Equation(string equation)
        {
            Console.WriteLine("Equation({0})", equation);
        }
    }
    
    Public Class CallbackHandler
    Implements ICalculatorDuplexCallback
       Public Sub Result (ByVal result As Double)
          Console.WriteLine("Result ({0})", result)
       End Sub
        Public Sub Equation(ByVal equation As String)
            Console.WriteLine("Equation({0})", equation)
        End Sub
    End Class
    
  5. Hozza létre az osztály egy példányát InstanceContext . A konstruktorhoz az ügyfélosztály egy példánya szükséges.

    InstanceContext site = new InstanceContext(new CallbackHandler());
    
    Dim site As InstanceContext = New InstanceContext(new CallbackHandler())
    
  6. Hozzon létre egy WCF-ügyfélpéldányt az objektumot InstanceContext igénylő konstruktor használatával. A konstruktor második paramétere a konfigurációs fájlban található végpont neve.

    CalculatorDuplexClient wcfClient = new CalculatorDuplexClient(site, "default");
    
    Dim wcfClient As New CalculatorDuplexClient(site, "default")
    
  7. Szükség szerint hívja meg a WCF-ügyfél metódusait.

Példa

Az alábbi példakód bemutatja, hogyan hozható létre kétoldalas szerződéshez hozzáférő ügyfélosztály.

using System;
using System.ServiceModel;
using System.ServiceModel.Channels;

// Define class that implements the callback interface of duplex
// contract.
public class CallbackHandler : ICalculatorDuplexCallback
{
  public void Result(double result)
  {
    Console.WriteLine($"Result({result})");
  }
  public void Equation(string equation)
  {
    Console.WriteLine($"Equation({equation})");
  }
}

public class Client
{
  public static void Main()
  {
    // Picks up configuration from the config file.

    CalculatorDuplexClient wcfClient
      = new CalculatorDuplexClient(new InstanceContext(new CallbackHandler()));
    try
    {
      // Call the AddTo service operation.
      double value = 100.00D;
      wcfClient.AddTo(value);

      // Call the SubtractFrom service operation.
      value = 50.00D;
      wcfClient.SubtractFrom(value);

      // Call the MultiplyBy service operation.
      value = 17.65D;
      wcfClient.MultiplyBy(value);

      // Call the DivideBy service operation.
      value = 2.00D;
      wcfClient.DivideBy(value);

      // Complete equation.
      wcfClient.Clear();

      // Wait for callback messages to complete before
      // closing.
      System.Threading.Thread.Sleep(5000);

      // Close the WCF client.
      wcfClient.Close();
      Console.WriteLine("Done!");
    }
    catch (TimeoutException timeProblem)
    {
      Console.WriteLine("The service operation timed out. " + timeProblem.Message);
      wcfClient.Abort();
      Console.Read();
    }
    catch (CommunicationException commProblem)
    {
      Console.WriteLine("There was a communication problem. " + commProblem.Message);
      wcfClient.Abort();
      Console.Read();
    }
  }
}
Imports System.ServiceModel

Namespace Microsoft.ServiceModel.Samples

    ' The service contract is defined in generatedClient.vb, generated from the service by the svcutil tool.

    ' Define class which implements callback interface of duplex contract
    Public Class CallbackHandler
        Implements ICalculatorDuplexCallback

        Public Sub Result(ByVal result As Double) Implements ICalculatorDuplexCallback.Result
            Console.WriteLine("Result({0})", result)
        End Sub

        Public Sub Equation(ByVal eqn As String) Implements ICalculatorDuplexCallback.Equation
            Console.WriteLine("Equation({0})", eqn)
        End Sub
    End Class

    Class Client
        Public Shared Sub Main()

            ' Construct InstanceContext to handle messages on callback interface
            Dim instanceContext As New InstanceContext(New CallbackHandler())

            ' Create a client
            Dim wcfClient As New CalculatorDuplexClient(instanceContext)
            Console.WriteLine("Press <ENTER> to terminate client once the output is displayed.")
            Console.WriteLine()

            Try
                ' Call the AddTo service operation.
                Dim value As Double = 100
                wcfClient.AddTo(value)

                ' Call the SubtractFrom service operation.
                value = 50
                wcfClient.SubtractFrom(value)

                ' Call the MultiplyBy service operation.
                value = 17.65
                wcfClient.MultiplyBy(value)

                ' Call the DivideBy service operation.
                value = 2
                wcfClient.DivideBy(value)

                ' Complete equation
                wcfClient.Clear()

                Console.ReadLine()

                'Closing the client gracefully closes the connection and cleans up resources
                wcfClient.Close()

            Catch timeout As TimeoutException
                Console.WriteLine(timeout.Message)
                wcfClient.Abort()
            Catch commException As CommunicationException
                Console.WriteLine(commException.Message)
                wcfClient.Abort()
            End Try
        End Sub

    End Class

End Namespace

Lásd még