方法: WCF サービスおよび ASP.NET Web サービス クライアントを相互運用するために構成する
ASP.NET Web サービス クライアントと相互運用できるように Windows Communication Foundation (WCF) サービス エンドポイントを構成するには、サービス エンドポイントのバインド型として System.ServiceModel.BasicHttpBinding 型を使用します。
必要に応じて、HTTPS およびトランスポート レベルのクライアント認証のサポートをバインディングで有効にできます。 ASP.NET Web サービス クライアントでは MTOM メッセージのエンコードがサポートされていないため、BasicHttpBinding.MessageEncoding プロパティは、既定値である WSMessageEncoding.Text のままにしておきます。 また、ASP.NET Web サービス クライアントでは WS-Security がサポートされていないため、BasicHttpBinding.Security を Transport に設定する必要があります。
WCF サービスのメタデータを ASP.NET Web サービス プロキシ生成ツール (つまり Web サービス記述言語ツール (Wsdl.exe)、Web サービス検出ツール (Disco.exe)、および Visual Studio の Web 参照の追加機能) で利用できるようにするには、HTTP/GET メタデータ エンドポイントを公開する必要があります。
コードにエンドポイントを追加する
新しい BasicHttpBinding インスタンスを作成します。
必要に応じて、バインディングのセキュリティ モードを Transport に設定して、このサービス エンドポイント バインディングのトランスポート セキュリティを有効にします。 詳細については、「トランスポート セキュリティ」を参照してください。
上で作成したバインディング インスタンスを使用して、サービス ホストに新しいアプリケーション エンドポイントを追加します。 コードでサービス エンドポイントを追加する方法の詳細については、「方法 : コード内にサービス エンドポイントを作成する」を参照してください。
サービス用に HTTP/GET メタデータのエンドポイントを有効にします。 詳細については、「方法: コードを使用してサービスのメタデータを公開する」を参照してください。
構成ファイルにエンドポイントを追加する
新しい BasicHttpBinding バインディング構成を作成します。 詳細については、「方法: 構成でサービス バインディングを指定する」を参照してください。
必要に応じて、バインディングのセキュリティ モードを Transport に設定して、このサービス エンドポイント バインド構成のトランスポート セキュリティを有効にします。 詳細については、「トランスポート セキュリティ」を参照してください。
上で作成したバインド構成を使用して、サービスに新しいアプリケーション エンドポイントを構成します。 構成ファイルにサービス エンドポイントを追加する方法の詳細については、「方法 : 構成にサービス エンドポイントを作成する」を参照してください。
サービス用に HTTP/GET メタデータのエンドポイントを有効にします。 詳細については、「方法: 構成ファイルを使用してサービスのメタデータを公開する」を参照してください。
例
ASP.NET Web サービス クライアントと互換性のある WCF エンドポイントをコードおよび構成ファイルで追加する方法を次のコード例に示します。
using System;
using System.Collections.Generic;
using System.Text;
using System.ServiceModel;
using System.ServiceModel.Description;
[ServiceContract]
public interface IEcho
{
[OperationContract]
string Echo(string s);
}
public class MyService : IEcho
{
public string Echo(string s)
{
return s;
}
}
class Program
{
static void Main(string[] args)
{
string baseAddress = "http://localhost:8080/wcfselfhost/";
ServiceHost host = new ServiceHost(typeof(MyService), new Uri(baseAddress));
// Create a BasicHttpBinding instance
BasicHttpBinding binding = new BasicHttpBinding();
// Add a service endpoint using the created binding
host.AddServiceEndpoint(typeof(IEcho), binding, "echo1");
host.Open();
Console.WriteLine("Service listening on {0} . . .", baseAddress);
Console.ReadLine();
host.Close();
}
}
Imports System.Collections.Generic
Imports System.Text
Imports System.ServiceModel
Imports System.ServiceModel.Description
<ServiceContract()> _
Public Interface IEcho
<OperationContract()> _
Function Echo(ByVal s As String) As String
End Interface
Public Class MyService
Implements IEcho
Public Function Echo(ByVal s As String) As String Implements IEcho.Echo
Return s
End Function
End Class
Friend Class Program
Shared Sub Main(ByVal args() As String)
Dim baseAddress = "http://localhost:8080/wcfselfhost/"
Dim host As New ServiceHost(GetType(MyService), _
New Uri(baseAddress))
' Add a service endpoint using the created binding
With host
.AddServiceEndpoint(GetType(IEcho), _
New BasicHttpBinding(), _
"echo1")
.Open()
Console.WriteLine("Service listening on {0} . . .", _
baseAddress)
Console.ReadLine()
.Close()
End With
End Sub
End Class
<configuration>
<system.serviceModel>
<services>
<service name="MyService" behaviorConfiguration="HttpGetMetadata">
<endpoint address="echo2" contract="IEcho" binding="basicHttpBinding" />
</service>
</services>
<behaviors>
<serviceBehaviors>
<behavior name="HttpGetMetadata">
<serviceMetadata httpGetEnabled="true" />
</behavior>
</serviceBehaviors>
</behaviors>
</system.serviceModel>
</configuration>