次の方法で共有


方法 : サービス モニカを登録および構成する

COM アプリケーションの Windows Communication Foundation (WCF) サービス モニカを型付きコントラクトで使うには、必要な属性を備えた型を COM に登録し、COM アプリケーションとモニカに、必要なバインディング設定を組み込まなければなりません。

必要な属性を備えた型を COM に登録するには

  1. ServiceModel Metadata Utility Tool (Svcutil.exe) ツールを使用して、WCF サービスからメタデータ コントラクトを取得します。これにより、WCF クライアント アセンブリに組み込むソース コードと、クライアント アプリケーションの構成ファイルが生成されます。

  2. アセンブリ内で定義されている型に ComVisible という設定をします。Visual Studio プロジェクトで、AssemblyInfo.cs ファイルに次の属性を追加してください。

    [assembly: ComVisible(true)]
    
  3. マネージ WCF クライアントを、厳密な名前のアセンブリとしてコンパイルします。そのためには暗号キー ペアで署名する必要があります。詳細な情報については、次のページを参照してください。 『.NET 開発者ガイド』の「厳密な名前でのアセンブリへの署名」を参照してください。

  4. アセンブリ登録 (Regasm.exe) ツールに /tlb オプションを指定して、アセンブリで定義されている型を COM に登録します。

  5. グローバル アセンブリ キャッシュ ツール (Gacutil.exe) で、グローバル アセンブリ キャッシュにアセンブリを追加します。

    ms734731.note(ja-jp,VS.90).gifメモ :
    アセンブリへの署名とグローバル アセンブリ キャッシュへの追加は、必須ではありません。しかしこれを済ませておくと、実行時には、適切な場所からアセンブリを読み込むための手順が簡単になります。

COM アプリケーションとモニカに必要なバインディングを設定するには

  • ServiceModel Metadata Utility Tool (Svcutil.exe) で生成したバインディング定義を、クライアント アプリケーションの構成ファイルにコピーします。たとえば、Visual Basic 6.0 で開発した実行可能ファイルの名前が CallCenterClient.exe の場合、これと同じディレクトリに、CallCenterConfig.exe.config という名前で構成ファイルを作成します。するとクライアント アプリケーションはモニカを使えるようになります。なお、WCF に組み込まれている標準のバインディング型を使うのであれば、バインディングの設定は必要ありません。

    次の型が登録されています。

    using System.ServiceModel;
    
    ...
    
    [ServiceContract] 
    public interface IMathService 
    {
    [OperationContract]
    public int Add(int x, int y);
    [OperationContract]
    public int Subtract(int x, int y);
    }
    

    このアプリケーションは、wsHttpBinding バインディングを使用して公開されています。このような型とアプリケーション設定であれば、次のようなモニカ文字列が使用されます。

    service:address=https://localhost/MathService, binding=wsHttpBinding, bindingConfiguration=Binding1
    

    or

    service:address=https://localhost/MathService, binding=wsHttpBinding, bindingConfiguration=Binding1, contract={36ADAD5A-A944-4d5c-9B7C-967E4F00A090}
    

    IMathService 型を定義するアセンブリへの参照を追加すれば、次のコード例のように、Visual Basic 6.0 アプリケーションに上記のモニカ文字列 (どちらの形式でも可) を記述できるようになります。

    Dim MathProxy As IMathService
    Dim result As Integer
    
    Set MathProxy = GetObject( _
            "service:address=https://localhost/MathService, _
            binding=wsHttpBinding, _
            bindingConfiguration=Binding1")
    
    result = MathProxy.Add(3, 5)
    

    この例で、バインディング構成 Binding1 の定義は、クライアント アプリケーションごとに、vb6appname.exe.config など該当する名前の構成ファイルに記述します。

    ms734731.note(ja-jp,VS.90).gifメモ :
    同様のコードを C#、C++、およびその他の .NET 言語アプリケーションで使用できます。

    ms734731.note(ja-jp,VS.90).gifメモ :
    モニカの形式が正しくないか、サービスを使用できない場合は、GetObject を呼び出すと、"構文が無効です" というエラーが返されます。このエラーを受信した場合は、使用しているモニカが正しく、サービスが使用可能であることを確認してください。

    このトピックでは、主に VB 6.0 コードからサービス モニカを使用する方法について説明していますが、他の言語からサービス モニカを使用することもできます。C++ コードからモニカを使用している場合、次のコードに示すように、Svcutil.exe によって生成されたアセンブリを、"no_namespace named_guids raw_interfaces_only" と共にインポートする必要があります。

    #import "ComTestProxy.tlb" no_namespace named_guids
    

    これにより、インポートされたインターフェイス定義は、すべてのメソッドが HResult を返すように変更されます。他の戻り値は、出力パラメータに変換されます。メソッドの実行全体は、同じままです。このために、プロキシでメソッドを呼び出したときの例外の原因を特定できます。この機能は C++ コードからのみ使用できます。

関連項目

その他の技術情報

Service Model Metadata Utility Tool (Svcutil.exe)