XML Web サービス プロキシの作成

Web サービスは定義上、SOAP などの業界標準プロトコルを使用してネットワーク経由で通信できます。つまり、クライアントと Web サービス間では、IN パラメータおよび OUT パラメータを XML としてカプセル化する SOAP メッセージを使用して通信します。Web サービス クライアントについては、パラメータを XML 要素に割り当て、SOAP メッセージをネットワーク経由で送信する処理をプロキシ クラスが行います。

サービスの説明が存在し、そのサービスの説明が Web サービス記述言語 (WSDL: Web Services Description Language) に準拠していれば、プロキシ クラスを生成できます。サービスの説明には、Web サービスと通信する方法が定義されています。サービスの説明があれば、Wsdl.exe ツールを使用してプロキシ クラスを作成できます。その後、Web サービス クライアントがプロキシ クラスのメソッドを呼び出します。プロキシ クラスでは Web サービスとの間でやり取りされる SOAP メッセージが処理され、ネットワーク経由で Web サービスと通信します。プロキシ クラスはインターネット経由で Web サービスと通信するため、プロキシ クラスの Url プロパティが、信頼できる通信先を参照していることを確認することをお勧めします。

既定では、プロキシ クラスは SOAP over HTTP を使用して Web サービスと通信します。ただし、Wsdl.exe では、HTTP-GET プロトコルまたは HTTP-POST プロトコルを使用して Web サービスと通信するプロキシ クラスも生成できます。プロキシ クラスでの HTTP-GET または HTTP-POST の使用を指定するには、下の表に示すように、Wsdl.exe ツールに /protocol スイッチを指定します。

Wsdl.exe ツールを使用した XML Web サービス プロキシ クラスの生成

コマンド プロンプトで Web サービス記述言語ツール (Wsdl.exe) を使用し、少なくとも Web サービスまたはサービスの説明への URL を指定するか、保存されているサービスの説明へのパスを指定してプロキシ クラスを作成します。

Wsdl /language:language  /protocol:protocol /namespace:myNameSpace /out:filename /username:username /password:password /domain:domain <url or path>
Noteメモ :

一般的に Wsdl.exe に使用される引数の一覧を次に示します。Wsdl.exe の完全な構文については、「Web サービス記述言語ツール (Wsdl.exe)」を参照してください。

パラメータ

<url or path>

サービスの説明 (Web サービス記述言語で Web サービスを説明するファイル) の URL またはパス。

ファイルを指定する場合、サービスの説明が含まれるファイルを指定します。次に例を示します。

mywebservice.wsdl

URL を指定する場合、.asmx ページを参照する URL、またはサービスの説明を返す URL を指定する必要があります。ASP.NET を使用して作成した Web サービスでは、Web サービスの URL に ?WSDL を追加すると、サービスの説明を返すことができます。次に例を示します。

https://www.contoso.com/MyWebService.asmx?WSDL

/language:language

プロキシ クラスの生成に使用する言語。有効なオプションは、CS (C#)、VB (Visual Basic .NET)、および JS (JScript .NET) です。既定の言語は C# です。この値は省略できます。

/protocol:protocol

Web サービス メソッドとの通信に使用するプロトコル。有効なオプションは、SOAP、HTTP-GET、および HTTP-POSTです。既定のプロトコルは SOAP です。この値は省略できます。

/namespace:myNameSpace

生成するプロキシの名前空間。既定値はグローバル名前空間です。この値は省略できます。

/out:filename

作成するプロキシ クラスを含むファイルの名前。既定の名前は、Web サービスを実装するクラスの名前に基づく名前です。この値は省略できます。

/username:username

認証を要求する Web サーバーへの接続時に使用するユーザー名。この値は省略できます。

/password:password

認証を要求する Web サーバーへの接続時に使用するパスワード。この値は省略できます。

/domain:domain

認証を要求する Web サーバーへの接続時に使用するドメイン。この値は省略できます。

生成されるプロキシ クラスの詳細

Wsdl.exe を使用してプロキシ クラスを生成すると、指定した言語でソース ファイルが 1 つ作成されます。このファイルには、Web サービスの各 Web サービス メソッドに対応する同期メソッドおよび非同期メソッドの両方を公開するプロキシ クラスが含まれています。たとえば、Web サービスに Add という名前の Web サービス メソッドが含まれる場合、プロキシ クラスには、Add Web サービス メソッドを呼び出すための AddBeginAdd、および EndAdd という名前のメソッドが含まれます。**ADD Web サービス メソッドと同期的に通信する場合はプロキシ クラスの Add メソッドを使用し、Web サービス メソッドと非同期的に通信する場合は BeginAdd および EndAdd メソッドを使用します。Web サービス メソッドとの非同期通信の詳細については、「XML Web サービスとの非同期通信」を参照してください。

生成されるプロキシ クラスの各メソッドには、各 Web サービス メソッドと通信するために必要なコードが含まれています。Web サービスとプロキシ クラスの通信中にエラーが発生した場合は、例外がスローされます。例外の処理の詳細については、「XML Web サービスでの例外の処理およびスロー」を参照してください。

Web サービスのメソッドと、関連するプロキシ クラスのメソッドでは、パラメータの定義順序が異なることがあります。ほとんどの場合、パラメータの順序は一致しています。ただし、Web サービスが Document 形式 の SOAP メッセージを要求する場合は、パラメータの順序が一致しません。Web サービス メソッドで、in パラメータの前に out パラメータが定義されている場合、プロキシ クラスでは、すべての in パラメータの後に out パラメータが配置されます。たとえば、次のコード例の MyWebMethod Web サービス メソッドでは、in パラメータの inStr の前に out パラメータの outStr が宣言されています。一方、プロキシ クラスでは、outStr パラメータの前に inStr パラメータが宣言されています。

' Declare MyWebMethod in the Web service.
MyWebMethod(ByRef outStr As String, inStr As String)

' This is the corresponding MyWebMethod in the proxy class.
MyWebMethod(inStr As String, ByRef outStr As String)
// Declare MyWebMethod in the Web service.
MyWebMethod(out string outStr, string inStr)

// This is the corresponding MyWebMethod in the proxy class.
MyWebMethod(string inStr, out string outStr).

場合によって、WSDL.exe を使用して生成されたプロキシ クラスは、オブジェクトをサービスの説明に指定された型にキャストするときに、共通項的な方法を使用することがあります。結果として、そのプロキシ クラスの生成された型が開発者の意図するものと異なることがあります。たとえば、WSDL.exe がサービスの説明で ArrayList 型を検出した場合は、生成するプロキシ クラス内に Object 配列を作成します。オブジェクト型が正しくキャストされるようにするには、生成されたプロキシ クラスが含まれているファイルを開き、不正なオブジェクト型を正しいオブジェクト型に変更します。

Wsdl.exe によりスローされる警告

Wsdl.exe に複数のサービスの説明が指定された場合は、次の 2 つのエラー メッセージが生成されることがあります。

  • 警告 : 場所 <schema URI> からの TargetNamespace=<schema namespace> を持つ重複するサービスの説明を無視します。

    指定された複数のサービスの説明に対する TargetNamespace が同一であることを示しています。TargetNamespace は、特定の XML ドキュメント (この場合はサービスの説明) に対する一意の識別子であると見なされるため、Wsdl.exe は、これらのサービスの説明が同一であると見なします。その場合、Wsdl.exe は いずれか 1 つのサービスの説明に対するプロキシ クラスを 1 つ作成します。この動作が要件と合わない場合は変更できます。ASP.NET を使用して作成した Web サービスを表すサービスの説明については、一意の Namespace プロパティを指定する WebService 属性を、Web サービスを実装するクラスに適用できます。次に、Namespace プロパティをサービスの説明の TargetNamespace として使用し、Web サービスを一意に識別できます。

  • 警告 : 場所 <schema URI> からの TargetNamespace=<schema Namespace> を持つ重複するスキーマを無視します。

    指定されたサービスの説明で、複数の XML スキーマに対する TargetNamespace が同一であることを示しています。TargetNamespace は、特定の XML ドキュメント (この場合は XML スキーマ) に対する一意の識別子であると見なされるため、Wsdl.exe は、これらの XML スキーマが同一であると見なします。その場合、Wsdl.exe は いずれか 1 つのスキーマに対してのみクラスを作成します。この動作が要件に合わない場合は、それぞれの XML スキーマに対する TargetNamespace を一意の URI に変更する必要があります。TargetNamespace の変更方法は、特定の XML スキーマのソースによって異なります。

関連項目

タスク

方法 : ASP.NET を使用して作成した既存の XML Web サービスを調査する
方法 : ブラウザから XML Web サービスにアクセスする

概念

XML Web サービス クライアントの作成
Web サービス探索
XML Web サービスとの非同期通信

その他の技術情報

XML Web サービスのクライアントの作成

Footer image

Copyright © 2007 by Microsoft Corporation.All rights reserved.