WINGSプロジェクト 土井 毅 [著] 山田 祥寛 [監修] 2008/04/25 00:00

サンプルファイル 26.59 KB

前回に続き、.NET Framework 3.0から導入されたコンポーネントとVisual Studio 2008でのサポートについて解説していきます。今回扱うのは通信フレームワークであるWCF(Windows Communication Foundation)です。.NET Framework 3.5でさまざまな新機能が追加され、より実用的なサービスの提供が可能となりました。

1 2 3 4 →

はじめに

 前回に続き、.NET Framework 3.0から導入されたコンポーネントとVisual Studio 2008でのサポートについて解説していきます。今回扱うのは通信フレームワークであるWCF(Windows Communication Foundation)です。.NET Framework 3.5でさまざまな新機能が追加され、より実用的なサービスの提供が可能となりました。

対象読者

  • VS 2008に興味がある方
  • WCFに興味がある方
  • .NET技術でのWebサービス構築に興味がある方

必要な環境

 シリーズ第1回を参考に、Visual Studio 2008のインストールを行ってください。

WCFについて

 WCFは.NET Framework 3.0で導入された統合通信フレームワークです。

 WCF導入前に存在したさまざまな通信フレームワークは、相互に互換性が無く、通信方式を簡単に差し替えることはできませんでした。例えば、.NETコンポーネント間で使われているTCPベースの.NET Remotingで構築したアプリケーションを、SOAPベースのWebサービスに対応させようとするなら、通信部分について、多くの書き換えが必要になっていました。

 WCFはこうした複数の通信フレームワークを統合しており、共通のアプローチで複数の通信方式を扱うことができます。

具体的には

 やや抽象的な話になってしまいましたが、具体的にはどんな効能があるのでしょうか。WCFはRPC(Remote Procedure Call:遠隔手続呼出)の一種であり、ネットワークを介してアプリケーション同士がお互いの公開する処理を相互に呼び出すための仕組みです。

 これでもまだ抽象的です。「アプリケーション同士」とか「お互いの公開する処理」といった部分は、具体的には何を指すのでしょうか? 一番身近に感じられるWCFのユースケースは「WebサーバとWebブラウザ」あるいは「Webサーバ同士」が、「Webサービス」を公開する/呼び出すために使用する、というものでしょう。

WCFの他のユースケース
 もちろんWCFはWebに依存しない汎用通信フレームワークですので、他にも次のようなさまざまなユースケースがあります。
  • エンタープライズシステムで、Microsoft Message Queuingを使ったメッセージキューサービスを使用するため
  • P2P(Peer to Peer)通信をサポートするため
  • .NET Remotingで相互通信を行っていたアプリケーションをWCFベースの処理に移行するため
WCFにはWebに限定されない広範な用途があることを踏まえつつ、本記事では最も使われるであろう、Webサービスに関連したテーマで活用方法を説明していきます。

 .NET Framework 3.0では、SOAPベースのXML Webサービスのみがサポートされていましたが、.NET Framework 3.5の新機能として、WCF Webプログラミング モデルがサポートされ、SOAPを使わない簡潔な方式の、いわゆる「RESTスタイル」のWebサービスや、AJAXでしばしば用いられるJSON(JavaScript Object Notation)形式のサポート、RSS/ATOMを使った配信のサポートなどが追加され、Webサービスの構築において、より実際的なフレームワークとなりました。

REST?POX?
 MSDNではRESTスタイルのWebサービスのことを、「POX(Plain Old XML)スタイルのWebサービス」と呼ぶ場合があります。本記事では一般的に受け入れられている「REST」を用語として用います(MSDNではRESTという用語も用いられています)。
RESTの定義はさまざまありますが、本記事では次のような条件を満たすサービスをRESTスタイルのWebサービスとして扱います。
  • ステートレスな(状態を持たない)プロトコル
  • すべてのリソースはURIで一意に表される
  • HTTPの基本操作(GET/PUT/DELETEなど)を用いる
  • SOAPのようにメッセージの厳密な抽象化を行わず、XMLを直接扱う

 本記事では、WCFの基本概念を説明した後に、SOAPベースのWebサービスの公開、RESTスタイルのWebサービスの公開、JSON形式のサポートなどのサンプルを見ていきます。

 特に、WCFでWebサービスを提供することを主眼に記事を進めていきますので、WCFでクライアント側の処理を実装する部分については省略します。

WCFについての他の記事
 WCFを使ったTCPベース通信のサンプルや、WCFを使ったクライアント実装については、Visual Studio 2005 + WCF Extensionsの解説記事を参照してください。

WCFがサポートする通信方式

 WCFは特定の通信方式に依存しないフレームワークで、現在のところ以下の通信方式をサポートしています。

WCFで使用可能な通信方式
通信方式概要相互運用性
TCPTCP/IPベースのテキスト/バイナリ通信WCFコンポーネント
HTTPHTTPベースで、SOAPを使ったXML Web Services(Basic-ProfileないしはWebサービス拡張仕様)や、RESTスタイルのWebサービス、JSONなどをサポートWebサービス(SOAP/REST/JSONなど)をサポートするアプリケーション
名前付きパイプ名前付きパイプを使用する通信方式同一マシン内のWCFコンポーネント同士
MSMQMicrosoft Message Queuingを使用する通信方式WCFコンポーネント/MSMQをサポートするアプリケーション
Peer to PeerWindows Peer-to-Peer Networkingを使用する通信方式WCFコンポーネント

 さまざまな通信方式がサポートされていますが、相互運用性の観点からすると、HTTPベースのWebサービスを使うケースが多いでしょう。WCFを使えば、必要に応じて以上の通信方式を切り替える、ないしは共存させることができます。

 WCFはABC(Address , Binding , Contract)という基本的な概念を導入することで、通信方式とロジックの分離を図り、通信方式の切り替えを容易にしています。

 まずはこれらの概念を確認しておきましょう。

WCFのキーワード:ABC(+Bv)=E

 WCFの基本的な概念を表すキーワードが「ABC(+Bv)=E」です。

 ABC(+Bv)は「どこで(A:Address)、どのように(B:Binding , Bv:Behavior)、何を(C:Contract)」提供するかを表すキーワードの集合です。これらで構成されたサービスの提供口をエンドポイント(E:Endpoint)と呼びます。

WCFのキーワード 「ABC(+Bv)=E」
頭文字キーワード意味
AAddressサービスを提供する場所
BBindingサービスで使用するデータの表現形式
CContractサービス内容の定義
BvBehaivorサービスの細かな挙動
EEndpointABC(+Bv)で構成されたサービスの提供口

 それぞれのキーワードについて説明していきましょう。

A:Address

 「どこでサービスを提供するか」を表すAはAddress(アドレス)の略で、サービスを提供するURIを表します。WCFサービスを利用するクライアントはこのURIに対してリクエストを発行することになります。

 以下にアドレスの例を示します。

通信方式ごとのURIの例
使用する通信方式URI
HTTPhttp://somehost:8080/BasicService
TCPnet.tcp://somehost:8081/TcpService
名前付きパイプnet.pipe://somehost/NamedPipeService

 本記事で解説するWebサービスの場合は、HTTP/HTTPSプロトコルを使ったURIがAddressとなります。

 

1 2 3 4
→
INDEX
Visual Studio 2008で標準搭載されたWindows Communication Foundation
Page1
はじめに
対象読者
必要な環境
WCFについて
サンプル1:SOAPスタイルのWebサービス
サンプル2:RESTスタイルのWebサービス
サンプル3:JSONサポート
まとめ
参考資料
プロフィール
WINGSプロジェクト 土井 毅 ドイ ツヨシ

WINGSプロジェクトについて>
有限会社 WINGSプロジェクトが運営する、テクニカル執筆コミュニティ(代表 山田祥寛)。主にWeb開発分野の書籍/記事執筆、翻訳、講演等を幅広く手がける。2011年7月時点での登録メンバは36名で、現在も執筆メンバを募集中。興味のある方は、どしどし応募頂きたい。著書記事多数。


プロフィール
山田 祥寛 ヤマダ ヨシヒロ

静岡県榛原町生まれ。一橋大学経済学部卒業後、NECにてシステム企画業務に携わるが、2003年4月に念願かなってフリーライターに転身。Microsoft MVP for ASP/ASP.NET。執筆コミュニティ「WINGSプロジェクト」代表。
主な著書に「入門シリーズ(サーバサイドAjax/XMLDB/PEAR/Smarty)」「独習シリーズ(ASP.NET/PHP)」「10日でおぼえる入門教室シリーズ(ASP.NET/PHP/Jakarta/JSP&サーブレット/XML)」「Pocket詳解辞典シリーズ(ASP.NET/PHP/Perl&CGI)」「今日からつかえるシリーズ(PHP/JSP&サーブレット/XML/ASP)」「書き込み式 SQLのドリル」他、著書多数


記事へのコメント・トラックバック機能は2011年6月に廃止させていただきました。記事に対する反響はTwitterやFacebook、ソーシャルブックマークサービスのコメントなどでぜひお寄せください。

スポンサーサイト