Comment : utiliser un client Windows Communication Foundation
C'est la dernière des six tâches requises pour créer un service Windows Communication Foundation (WCF) de base et un client pouvant appeler le service. Pour une vue d'ensemble des six tâches, consultez la rubrique Didacticiel de mise en route.
Une fois qu'un proxy Windows Communication Foundation (WCF) a été créé et configuré, une instance client peut être créée, et l'application cliente peut être compilée et utilisée pour communiquer avec le service WCF. Cette rubrique décrit les procédures pour la création et l'utilisation d'un client WCF. Cette procédure accomplit trois tâches :
Crée un client WCF.
Appelle les opérations de service à partir du proxy généré.
Ferme le client une fois que l'appel de l'opération est terminé.
Le code évoqué dans la procédure est aussi fourni dans l'exemple qui suit la procédure. Le code dans cette tâche doit être placé dans la méthode Main()
de la classe Program
générée dans le projet client.
Pour utiliser un client Windows Communication Foundation
Créez une instance EndpointAddress pour l'adresse de base du service que vous allez appeler, puis créez un objet WCF
Client
.' Step 1: Create an endpoint address and an instance of the WCF Client. Dim epAddress As New EndpointAddress("https://localhost:8000/ServiceModelSamples/Service/CalculatorService") Dim Client As New CalculatorClient(New WSHttpBinding(), epAddress)
//Step 1: Create an endpoint address and an instance of the WCF Client. CalculatorClient client = new CalculatorClient();
Appelez les opérations clientes à partir du
Client
.'Step 2: Call the service operations. 'Call the Add service operation. Dim value1 As Double = 100D Dim value2 As Double = 15.99D Dim result As Double = Client.Add(value1, value2) Console.WriteLine("Add({0},{1}) = {2}", value1, value2, result) 'Call the Subtract service operation. value1 = 145D value2 = 76.54D result = Client.Subtract(value1, value2) Console.WriteLine("Subtract({0},{1}) = {2}", value1, value2, result) 'Call the Multiply service operation. value1 = 9D value2 = 81.25D result = Client.Multiply(value1, value2) Console.WriteLine("Multiply({0},{1}) = {2}", value1, value2, result) 'Call the Divide service operation. value1 = 22D value2 = 7D result = Client.Divide(value1, value2) Console.WriteLine("Divide({0},{1}) = {2}", value1, value2, result)
// Step 2: Call the service operations. // Call the Add service operation. double value1 = 100.00D; double value2 = 15.99D; double result = client.Add(value1, value2); Console.WriteLine("Add({0},{1}) = {2}", value1, value2, result); // Call the Subtract service operation. value1 = 145.00D; value2 = 76.54D; result = client.Subtract(value1, value2); Console.WriteLine("Subtract({0},{1}) = {2}", value1, value2, result); // Call the Multiply service operation. value1 = 9.00D; value2 = 81.25D; result = client.Multiply(value1, value2); Console.WriteLine("Multiply({0},{1}) = {2}", value1, value2, result); // Call the Divide service operation. value1 = 22.00D; value2 = 7.00D; result = client.Divide(value1, value2); Console.WriteLine("Divide({0},{1}) = {2}", value1, value2, result);
Appelez
Close
sur le client WCF et attendez que l'utilisateur appuie sur la touche Entrée pour mettre fin à l'application.' Step 3: Closing the client gracefully closes the connection and cleans up resources. Client.Close() Console.WriteLine() Console.WriteLine("Press <ENTER> to terminate client.") Console.ReadLine()
//Step 3: Closing the client gracefully closes the connection and cleans up resources. client.Close(); Console.WriteLine(); Console.WriteLine("Press <ENTER> to terminate client."); Console.ReadLine();
Exemple
L'exemple suivant vous montre comment créer un client WCF, comment appeler les opérations du client, et comment fermer le client au terme de l'appel d'opération.
Compilez le client WCF généré et l'exemple de code suivant dans un fichier exécutable nommé Client.exe. Veillez à référencer System.ServiceModel lors de la compilation du code.
Imports System
Imports System.Collections.Generic
Imports System.Text
Imports System.ServiceModel
Module Client
Sub Main()
' Step 1: Create an endpoint address and an instance of the WCF Client.
Dim epAddress As New EndpointAddress("https://localhost:8000/ServiceModelSamples/Service/CalculatorService")
Dim Client As New CalculatorClient(New WSHttpBinding(), epAddress)
'Step 2: Call the service operations.
'Call the Add service operation.
Dim value1 As Double = 100D
Dim value2 As Double = 15.99D
Dim result As Double = Client.Add(value1, value2)
Console.WriteLine("Add({0},{1}) = {2}", value1, value2, result)
'Call the Subtract service operation.
value1 = 145D
value2 = 76.54D
result = Client.Subtract(value1, value2)
Console.WriteLine("Subtract({0},{1}) = {2}", value1, value2, result)
'Call the Multiply service operation.
value1 = 9D
value2 = 81.25D
result = Client.Multiply(value1, value2)
Console.WriteLine("Multiply({0},{1}) = {2}", value1, value2, result)
'Call the Divide service operation.
value1 = 22D
value2 = 7D
result = Client.Divide(value1, value2)
Console.WriteLine("Divide({0},{1}) = {2}", value1, value2, result)
' Step 3: Closing the client gracefully closes the connection and cleans up resources.
Client.Close()
Console.WriteLine()
Console.WriteLine("Press <ENTER> to terminate client.")
Console.ReadLine()
End Sub
End Module
using System;
using System.Collections.Generic;
using System.Text;
using System.ServiceModel;
namespace ServiceModelSamples
{
class Client
{
static void Main()
{
//Step 1: Create an endpoint address and an instance of the WCF Client.
CalculatorClient client = new CalculatorClient();
// Step 2: Call the service operations.
// Call the Add service operation.
double value1 = 100.00D;
double value2 = 15.99D;
double result = client.Add(value1, value2);
Console.WriteLine("Add({0},{1}) = {2}", value1, value2, result);
// Call the Subtract service operation.
value1 = 145.00D;
value2 = 76.54D;
result = client.Subtract(value1, value2);
Console.WriteLine("Subtract({0},{1}) = {2}", value1, value2, result);
// Call the Multiply service operation.
value1 = 9.00D;
value2 = 81.25D;
result = client.Multiply(value1, value2);
Console.WriteLine("Multiply({0},{1}) = {2}", value1, value2, result);
// Call the Divide service operation.
value1 = 22.00D;
value2 = 7.00D;
result = client.Divide(value1, value2);
Console.WriteLine("Divide({0},{1}) = {2}", value1, value2, result);
//Step 3: Closing the client gracefully closes the connection and cleans up resources.
client.Close();
Console.WriteLine();
Console.WriteLine("Press <ENTER> to terminate client.");
Console.ReadLine();
}
}
}
Vérifiez que le service s'exécute avant d'essayer d'utiliser le client. Pour plus d'informations, consultez Comment : héberger et exécuter un service Windows Communication Foundation de base.
Pour lancer le client, cliquez avec le bouton droit sur Client dans l'Explorateur de solutions, puis sélectionnez Débogage, Démarrer une nouvelle instance.
Add(100,15.99) = 115.99
Subtract(145,76.54) = 68.46
Multiply(9,81.25) = 731.25
Divide(22,7) = 3.14285714285714
Press <ENTER> to terminate client.
Si vous voyez cette sortie, cela signifie que vous avez complété le didacticiel avec succès. Cet exemple illustre comment configurer le client WCF dans le code. Pour obtenir des informations de dépannage, consultez Dépannage du didacticiel de mise en route.
Voir aussi
Tâches
Comment : créer un client Windows Communication Foundation
Comment : créer un contrat duplex
Comment : accéder aux services ayant un contrat duplex
Getting Started, exemple
Self-Host
Autres ressources
Génération de clients
Didacticiel de mise en route
Programmation WCF de base