Erstellen eines Diensts

Das Erstellen eines Webdiensts wird in WWSAPI durch die Dienstmodell-API und das WsUtil.exe-Tool erheblich vereinfacht. Das Dienstmodell stellt eine API bereit, die es dem Dienst und dem Client ermöglicht, Nachrichten über einen Kanal als C-Methodenaufrufe zu senden und zu empfangen. Das WsUtil-Tool generiert Stubs und Header für die Implementierung des Diensts.

Implementieren eines Rechnerdiensts mithilfe von WWSAPI

Implementieren Sie den Dienst mithilfe der aus dem Wsutil.exe-Tool generierten Quellen mit den folgenden Schritten.

Schließen Sie die Header in Ihre Anwendungsquelle ein.

#include "CalculatorProxyStub.h"

Implementieren Sie die Dienstvorgänge. In diesem Beispiel sind die Dienstvorgänge die Funktionen Hinzufügen und Subtrahieren des Rechnerdiensts.

HRESULT CALLBACK Add (const WS_OPERATION_CONTEXT* context, 
                  int a, int b, int* result, 
                  const WS_ASYNC_CONTEXT* asyncContext, 
                  WS_ERROR* error)
{
    *result = a + b;
    printf ("%d + %d = %d\n", a, b, *result);
    return NOERROR;
}

HRESULT CALLBACK Subtract (const WS_OPERATION_CONTEXT* context, 
                  int a, int b, int* result, 
                  const WS_ASYNC_CONTEXT* asyncContext, 
                  WS_ERROR* error)
{
    *result = a - b;
    printf ("%d - %d = %d\n", a, b, *result);
    return NOERROR;
}

Definieren Sie den Dienstvertrag, indem Sie die Felder einer WS_SERVICE_CONTRACT-Struktur festlegen.

static const DefaultBinding_ICalculatorFunctionTable calculatorFunctions = {Add, Subtract};
static const WS_SERVICE_CONTRACT calculatorContract = 
{
    &DefaultBinding_ICalculatorContractDesc, // comes from the generated header.
    NULL, // for not specifying the default contract
    &calculatorFunctions // specified by the user
};

Erstellen Sie nun einen Diensthost, und öffnen Sie ihn für die Kommunikation.

WS_SERVICE_ENDPOINT serviceEndpoint = {0};
serviceEndpoint.uri.chars = L"https://+:80/example"; // address given as uri
serviceEndpoint.binding.channelBinding =  WS_HTTP_CHANNEL_BINDING; // channel binding for the endpoint
serviceEndpoint.channelType = WS_CHANNEL_TYPE_REPLY; // the channel type
serviceEndpoint.uri.length = (ULONG)wcslen(serviceEndpoint.uri.chars);
serviceEndpoint.contract = (WS_SERVICE_CONTRACT*)&calculatorContract;  // the contract
serviceEndpoint.properties = serviceProperties;
serviceEndpoint.propertyCount = WsCountOf(serviceProperties);

if (FAILED (hr = WsCreateServiceHost (&serviceEndpoint, 1, NULL, 0, &host, error)))
    goto Error;

// WsOpenServiceHost  to start the listeners in the service host 
if (FAILED (hr = WsOpenServiceHost (host, NULL, error)))
    goto Error;

Eine vollständige Implementierung des Rechnerdiensts finden Sie im Codebeispiel unter HttpCalculatorServiceExample .