次の方法で共有


ASMX Web サービスとの相互運用

ASMX サンプルでは、Windows Communication Foundation (WCF) クライアント アプリケーションを既存の ASMX Web サービスと統合する方法を示します。

このサンプルのセットアップ手順とビルド手順は、このトピックの最後にあります。

このサンプルは、インターネット インフォメーション サービス (IIS) によってホストされるクライアント コンソール プログラム (.exe) とサービス ライブラリ (.dll) で構成されています。 このサービスは、要求/応答通信パターンを定義するコントラクトを実装する ASMX Web サービスです。 このサービスでは、算術演算 (AddSubtractMultiplyDivide) が公開されます。 クライアントは算術演算に対して同期要求を行い、サービスは結果と共に応答します。 クライアント アクティビティはコンソール ウィンドウに表示されます。

次のサンプル コードに示す ASMX Web サービスの実装は、適切な結果を計算して返します。

[WebService(Namespace="http://Microsoft.ServiceModel.Samples")]
public class CalculatorService : System.Web.Services.WebService
    {
        [WebMethod]
        public double Add(double n1, double n2)
        {
            return n1 + n2;
        }
        [WebMethod]
        public double Subtract(double n1, double n2)
        {
            return n1 - n2;
        }
        [WebMethod]
        public double Multiply(double n1, double n2)
        {
            return n1 * n2;
        }
        [WebMethod]
        public double Divide(double n1, double n2)
        {
            return n1 / n2;
        }
    }

構成されている場合、同じコンピューター上のクライアントが http://localhost/servicemodelsamples/service.asmx でサービスにアクセスできます。 リモート マシン上のクライアントがサービスにアクセスするには、localhost の代わりに修飾ドメイン名を指定する必要があります。

通信は、 ServiceModel メタデータ ユーティリティ ツール (Svcutil.exe) によって生成されたクライアントを介して行われます。 クライアントはファイル generatedClient.csに含まれています。 ASMX サービスは、更新されたメタデータを取得するために使用されるため、プロキシ コードを生成するために使用できる必要があります。 クライアント ディレクトリのコマンド プロンプトから次のコマンドを実行して、型指定されたプロキシを生成します。

svcutil.exe /n:http://Microsoft.ServiceModel.Samples,Microsoft.ServiceModel.Samples http://localhost/servicemodelsamples/service.svc?wsdl /out:generatedClient.cs

生成されたクライアントを使用すると、適切なアドレスとバインドを構成することで、サービス エンドポイントにアクセスできます。 サービスと同様に、クライアントは構成ファイル (App.config) を使用して通信するエンドポイントを指定します。 クライアント エンドポイントの構成は、次のサンプル構成に示すように、サービス エンドポイント、バインディング、コントラクトの絶対アドレスで構成されます。

<client>
   <endpoint
      address="http://localhost/ServiceModelSamples/service.asmx"
      binding="basicHttpBinding"
      contract="Microsoft.ServiceModel.Samples.CalculatorServiceSoap" />
</client>

クライアント実装は、生成されたクライアントのインスタンスを構築します。 生成されたクライアントは、サービスとの通信に使用できます。

// Create a client.
CalculatorServiceSoapClient client = new CalculatorServiceSoapClient();

// 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);

//Closing the client gracefully closes the connection and cleans up resources.
client.Close();

Console.WriteLine();
Console.WriteLine("Press <ENTER> to terminate client.");
Console.ReadLine();

サンプルを実行すると、操作要求と応答がクライアント コンソール ウィンドウに表示されます。 クライアント ウィンドウで Enter キーを押して、クライアントをシャットダウンします。

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.

サンプルを設定、ビルド、実行するには

  1. Windows Communication Foundation サンプル One-Time セットアップ手順を実行していることを確認します。

  2. ソリューションの C# または Visual Basic .NET エディションをビルドするには、「Windows Communication Foundation サンプルのビルド」の手順に従います。

  3. 単一または複数のコンピューター間の構成でサンプルを実行するには、「Windows Communication Foundation Samplesの実行」の手順に従います。