blob: d5974023dcc6641e73ab59892aca33ffe33265ca [file] [log] [blame]
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
<html>
<head><link rel="stylesheet" href="../../../print.css" type="text/css" media="print">
<title>高度なWebサービス相互運用性 - NetBeans IDEチュートリアル</title>
<meta name="description"
content="This tutorial shows how to use the IDE to configure security mechanisms for web services.">
<meta name="KEYWORDS" content="NETBEANS, TUTORIAL, GUIDE, USER, DOCUMENTATION, WEB SERVICE, WEB SERVICES, MTOM, METRO, WS-I, WS-RM, RELIABLE MESSAGING, SECURITY, WCF, WINDOWS COMMUNICATION FOUNDATION">
<link rel="stylesheet" href="../../../netbeans.css">
<meta http-equiv="Content-Type" content="text/html; charset=UTF-8"></head>
<body>
<h1>高度なWebサービス相互運用性</h1>
<p>高度なWebサービス相互運用性(WSIT)は、Webサービスの「サービス品質」とも呼ばれ、Java Webサービスと .Net Webサービスの間の相互運用性を可能にするコンポーネントを含みます。このドキュメントでは、WSITを使用するWebサービスおよびクライアントを構成するためのIDEのサポートの一部をについて説明します。WSITの使用の詳細は、<a href="http://docs.oracle.com/cd/E19159-01/820-1072/index.html">WSITチュートリアル</a><a href="http://docs.oracle.com/cd/E19159-01/820-1072/ahibn/index.html">第3章のWebコンテナおよびNetBeans IDEを使用したWSITの例</a>を参照してください。</p>
<p><b>目次</b></p>
<img alt="このページの内容は、NetBeans IDE 7.2、7.3および7.4に適用されます" class="stamp" src="../../../images_www/articles/72/netbeans-stamp-74-73-72.png" title="このページの内容は、NetBeans IDE 7.2、7.3および7.4に適用されます">
<ul>
<li><a href="#Exercise_1">カリキュレータ・サンプルの理解</a>
<ul><li><a href="#Exercise_1_1">サンプルの操作</a></li>
<li><a href="#Exercise_1_2">カリキュレータ・サンプルのデプロイおよびテスト</a></li>
</ul>
<li><a href="#Exercise_2">セキュリティ保護されたカリキュレータ・サンプルの理解</a>
<ul><li><a href="#Exercise_2_1">サンプルの操作</a></li>
<li><a href="#Exercise_2_2">セキュリティ保護されたカリキュレータ・サンプルのデプロイおよびテスト</a></li>
</ul>
</ul>
<p><b>このチュートリアルに従うには、次のソフトウェアとリソースが必要です。</b></p>
<table>
<tbody>
<tr>
<th class="tblheader" scope="col">ソフトウェアまたはリソース</th>
<th class="tblheader" scope="col">必須バージョン</th>
</tr>
<tr>
<td class="tbltd1"><a href="https://netbeans.org/downloads/index.html" target="_blank">NetBeans IDE</a></td>
<td class="tbltd1">Java EEダウンロード・バンドル</td>
</tr>
<tr>
<td class="tbltd1"><a href="http://www.oracle.com/technetwork/java/javase/downloads/index.html" target="_blank">Java Development Kit (JDK)</a></td>
<td class="tbltd1">バージョン6またはバージョン7</td>
</tr>
<tr>
<td class="tbltd1">Java EE互換のWebサーバーまたはアプリケーション・サーバー</td>
<td class="tbltd1">
GlassFish Server Open Source Edition 3.1.x、4.x<br>または<br><a href="http://www.oracle.com/technetwork/middleware/weblogic/overview/index.html" target="_blank">Oracle WebLogic Server</a> 11gまたは12c
</td></tr>
</tbody>
</table>
<p class="notes">GlassFishサーバーは、オプションで、NetBeans IDEのJava EEディストリビューションとともにインストールできます。または、<a href="https://glassfish.java.net/download.html">GlassFishサーバーのダウンロード・ページ</a><a href="http://tomcat.apache.org/download-60.cgi" target="_blank">Apache Tomcatのダウンロード・ページ</a>からダウンロードすることもできます。</p>
<p class="alert"><strong>重要: </strong>Java EEプロジェクトには、GlassFish Server 3.1.x、4.xまたはOracle WebLogic Server 12cが必要です。</p>
<!--Exercise 1: -->
<a name="Exercise_0"></a>
<h2>概要</h2>
<p>高度なWebサービス相互運用性に関連するコンポーネントは、4つの主なカテゴリに分類されます。</p>
<ul>
<li><b>ブートストラップと構成。</b>Webサービスにアクセスしてこれを利用できるWebサービス・クライアントを作成するために実行されるプロセスです。</li>
<li><b>メッセージ・セキュリティ。</b>次のセキュリティ構成オプションがサポートされています。
<ul>
<li>署名および暗号化のターゲットのオプション</li>
<li>クライアント/サービスのWebサービス・セキュリティ</li>
<li>クライアント/サービスの信頼のオプション</li>
<li>詳細構成オプション</li>
<li>キーストア構成オプション</li>
</ul>
</li>
<li><b>メッセージの最適化。</b>Webサービスのメッセージが最も効率的な方法でインターネット上で送信されるようにします。Webサービス通信でのメッセージの最適化は、送信前にメッセージをエンコーディングし、最終的な送信先に到達したときにエンコーディングを解除することによって実現されます。</li>
<li><b>信頼できるメッセージ配信。</b>A点からB点までエラーなしでメッセージを送信できるシステム性能で測定されます。</li>
</ul>
<p>「サービス品質」は、「プロジェクト」ウィンドウ内のWebサービスまたはクライアントを表すノードからアクセスできるWebサービス属性エディタで構成されます。このドキュメントでは、IDEとともに配布される2つのサンプル(セキュリティ保護されていないWebサービスのサンプルおよびセキュリティ保護されたWebサービスのサンプル)を紹介します。このドキュメントでは、サンプル間の違いを示し、IDEを使用して独自のWebサービスおよびクライアントにセキュリティを構成する方法について説明します。</p>
<p>サービス品質に関するトピックの完全な全体ガイドについては、<a href="http://download.oracle.com/docs/cd/E17802_01/webservices/webservices/reference/tutorials/wsit/doc/index.html" target="_blank">WSITチュートリアル</a>を参照してください。
<!-- ===================================================================================== -->
<a name="Exercise_1"></a><h2>カリキュレータ・サンプルの理解</h2>
<p>この課題の目標は、IDEにバンドルされているカリキュレータ・サンプルについて理解することです。後でWebサービスを調査するときにわかるように、このサンプルは、次のサンプルとは対照的に保護されていません。</p>
<div class="indent">
<h3 class="tutorial"><a name="Exercise_1_1"></a>サンプルの操作</h3>
<p>この課題では、新規プロジェクト・ウィザードを使用してサンプルを作成し、IDEでサンプルを確認してアプリケーションをデプロイします。</p>
<ol>
<li>「ファイル」>「新規プロジェクト」(LinuxおよびWindowsの場合は[Ctrl]-[Shift]-[N]、MacOSの場合は[⌘]-[Shift]-[N])を選択し、新規プロジェクト・ウィザードを開きます。</li>
<li>「サンプル」カテゴリを展開し、「Webサービス」ノードを選択して、「カリキュレータ」サンプルを選択します。「次」をクリックします。<br> <img alt="カリキュレータ・サンプルを示す新規プロジェクト・ウィザード" class="margin-around b-all" src="../../../images_www/articles/74/websvc/wsit/wsit-newproject.png" title="カリキュレータ・サンプルを示す新規プロジェクト・ウィザード"></li>
<li>「サーバー」ドロップダウン・リストでJava EEに準拠したサーバーが選択されていることを確認します。「終了」をクリックします。
<p>「終了」をクリックすると、2つのプロジェクトが作成されます。
<ul>
<li><strong>CalculatorApp</strong>は、「add」という名前の操作を公開するCalculatorWSという名前のWebサービスを提供します。</li>
<li><strong>CalculatorClientApp</strong>は、Webサービスの「add」操作を呼び出すCalculatorWSServiceという名前のクライアントを提供します。</li>
</ul>
<p class="alert">IDEでCalculatorWSサービスのWSDLを検出できないため、CalculatorClientAppサービスにエラー・アイコンが付いている場合があります。CalculatorAppをデプロイし、CalculatorClientAppを消去してビルドすると、エラーを解決できます。</p>
<img alt="Webサービスとクライアントを表示する「プロジェクト」ウィンドウ" class="margin-around b-all" src="../../../images_www/articles/74/websvc/wsit/wsit-projects.png" title="Webサービスとクライアントを表示する「プロジェクト」ウィンドウ"></li>
<li>CalculatorWS Webサービスをダブルクリックしてファイルをエディタで開き、エディタの上部の「デザインタブをクリックしてビジュアル・デザイナにWebサービスを表示します。<br> <img alt="「デザイン」GUI (ビジュアル・デザイナ)タブのCalculatorWSサービス" class="margin-around b-all" src="../../../images_www/articles/74/websvc/wsit/wsit-design.png" title="「デザイン」GUI (ビジュアル・デザイナ)タブのCalculatorWSサービス">
<p class="notes"><b>注意: </b>サービスの「デザイン」タブの「サービス品質」セクションで、有効にされたオプションが<i>ない</i>ことが確認できます。その結果、サービス品質コンポーネントはこの特定のWebサービスに適用されません。セキュリティ保護されたWebサービスを作成する際、サービス品質コンポーネントが<em>有効な</em>Webサービスについて確認します。</p>
</li>
</ol>
<p>IDEのWebサービスに関する完全なチュートリアルについては、<a href="jax-ws.html">JAX-WS Webサービスについて</a>を参照してください。
<h3 class="tutorial"><a name="Exercise_1_2"></a>カリキュレータ・サンプルのデプロイおよびテスト</h3>
<ol>
<li>「CalculatorApp」プロジェクトを右クリックし、「実行」を選択します。
<p>サーバーが起動し、Webサービスがサーバーにデプロイされます。デフォルト・ブラウザでページが開き、サービスの詳細が一部表示されます。</p>
<img alt="ブラウザのCalculatorWS情報ウィンドウ" class="margin-around b-all" src="../../../images_www/articles/74/websvc/wsit/wsit-browser1.png" title="ブラウザのCalculatorWS情報ウィンドウ"></li>
<li>ブラウザでページのWSDLリンクをクリックすると、Webサービスを定義するWSDLファイルが表示されます。<br><img alt="ブラウザでのCalculator WS WSDL" class="margin-around b-all" src="../../../images_www/articles/74/websvc/wsit/wsit-browser2.png" title="ブラウザでのCalculator WS WSDL">
<p class="notes"><b>注意:</b>WSDLが表示されない場合、ブラウザのロケーション・バーでURLを確認してください。<tt>http://localhost:<em>your_port_number</em>/CalculatorApp/CalculatorWSService?WSDL</tt>を指すようにしてください。</p>
</li>
<li>IDEの「プロジェクト」ウィンドウで、「Webサービス」ノードの下の「CalculatorWS」を右クリックし、ポップアップ・メニューで「Webサービスをテスト」を選択します。<br>
<p>Webサービスをテストする場合、サービスのテスト用のページがブラウザで開きます。</p>
<img alt="ブラウザでのCalculator WSテスター" class="margin-around b-all" src="../../../images_www/articles/74/websvc/wsit/wsit-browser3.png" title="ブラウザでのCalculator WSテスター">
<p>IDEで、Webサービスをテストするためのクライアントが提供され、ブラウザでテスト・アプリケーションが開きます。テスト・アプリケーションで、Webサービスで定義された各フィールドに値を入力できます。テスト・アプリケーションには、サービスの操作の名前のラベルが付いたボタンがあります。ボタンをクリックすると、操作の起動の結果が表示されます。</p>
</li>
<li>「プロジェクト」ウィンドウで、エラー・バッジがないかCalculatorClientAppプロジェクトを調べます。
<p><tt>ClientServlet.java</tt>にエラー・アイコンがある場合、プロジェクト・ノードを右クリックし、ポップアップ・メニューで「消去してビルド」を選択します。エラーが表示されたのは、CalculatorWSサービスがデプロイされていなかったためです。デプロイされたため、IDEはこのWSDLを解析でき、ClientServletがコンパイルされます。</p></li>
<li>「CalculatorClientApp」プロジェクト・ノードを右クリックし、「実行」を選択します。
<p>アプリケーションを実行すると、サービスのインタフェースがブラウザで開きます。</p>
<img alt="ブラウザでのCalculator Serviceクライアント" class="margin-around b-all" src="../../../images_www/articles/74/websvc/wsit/wsit-browser4.png" title="ブラウザでのCalculator Serviceクライアント"></li>
<li>2つのフィールドに値を入力し、「Get Result」をクリックします。
<p>「Get Result」をクリックすると、操作の結果がWebサービスから取得されてクライアントに表示されます。</p></li>
</ol>
<p>Webサービスは正しく機能し、クライアントで結果が取得されますが、このプロジェクトは、サービス品質コンポーネントを使用しません。次の項では、サービス品質コンポーネントを構成する方法について説明します。</p>
</div>
<!-- ===================================================================================== -->
<h2><a name="Exercise_2"></a>
<!--Exercise 1: -->
セキュリティ保護されたカリキュレータ・サンプルの理解</h2>
<p>この課題の目標は、セキュリティ保護されたWebサービスを設定する方法と、クライアントがWebサービスと対話する方法を確認することです。</p>
<div class="indent">
<h3 class="tutorial"><a name="Exercise_2_1"></a>サンプルの操作</h3>
<p>この課題では、新規プロジェクト・ウィザードを使用してサンプルを作成し、サービス品質がアプリケーションに構成されていることを確認します。</p>
<ol>
<li>「ファイル」>「新規プロジェクト」(LinuxおよびWindowsの場合は[Ctrl]-[Shift]-[N]、MacOSの場合は[⌘]-[Shift]-[N])を選択し、新規プロジェクト・ウィザードを開きます。</li>
<li>「サンプル」カテゴリを展開し、「Webサービス」ノードを選択して、「セキュアなカリキュレータ」サンプルを選択します。「次」をクリックします。</li>
<li>「サーバー」ドロップダウン・リストでJava EEに準拠したサーバーが選択されていることを確認します。「終了」をクリックします。
<p>「終了」をクリックすると、2つのプロジェクトが作成されます。
<ul>
<li><strong>SecureCalculatorApp</strong>は、「add」という名前の操作を公開するCalculatorWSという名前のWebサービスを提供します。</li>
<li><strong>SecureCalculatorClientApp</strong>は、Webサービスの「add」操作を呼び出すCalculatorWSServiceという名前のクライアントを提供します。</li>
</ul>
<p class="alert">IDEでCalculatorWSサービスのWSDLを検出できないため、SecureCalculatorClientAppサービスにエラー・アイコンが付いている場合があります。SecureCalculatorAppをデプロイし、SecureCalculatorClientAppを消去してビルドすると、エラーを解決できます。</p>
</li>
<li>SecureCalculatorAppの「Webサービス」フォルダでCalculatorWS Webサービスをダブルクリックしてファイルをエディタで開き、エディタの上部の「デザインタブをクリックしてビジュアル・デザイナにWebサービスを表示します。
<p class="notes"><b>注意: </b>サービスのデザイン・ビューの「サービス品質」セクションで、「セキュア・サービス」オプションは選択され、他の2つのオプションは選択されていないことがわかります。デザイン・ビューの「サービス品質」セクションでは、現在のWebサービスに対してどのサービス品質コンポーネントを<i>有効</i>にするかを指定します。</p>
</li>
<li>「Webサービス属性を編集」をクリックし、Webサービス属性エディタを開きます。<br> <img alt="WS属性エディタの「サービス品質」ページ" class="margin-around b-all" src="../../../images_www/articles/74/websvc/wsit/wsit-quality-dialog.png" title="WS属性エディタの「サービス品質」ページ">
<p>「サービス品質」タブで、「バージョン互換性」オプションが選択されていることが確認できます。インストールされているMetroまたは.NETのバージョンに一致する最新バージョンを選択します。</p>
<p class="alert">バージョン互換性ドロップダウン・リストを有効にするには、最新バージョンのMetroをプロジェクトのクラスパスに追加します。最新のMetroライブラリを追加するには、「プロジェクト」ウィンドウでプロジェクトのノードを右クリックし、プロジェクトの「プロパティ」を開き、「ライブラリ」カテゴリに移動して、最新のMetroライブラリを参照して追加します。</p>
<p>「セキュア・サービス」オプションが選択されていること、およびドロップダウン・リストでセキュリティ・メカニズムが選択されていることに注意してください。セキュリティ・メカニズムは、Webサービス・セキュリティ保護に使用する方法を指定します。
<p>このサンプル・アプリケーションでは、「対称キーを使用したユーザー名認証」セキュリティ・メカニズムが選択されています。オプションの説明および「対称キーを使用したユーザー名認証」セキュリティ・メカニズムの詳細は、<a href="http://docs.oracle.com/cd/E19182-01/821-0015/gggsrv/index.html">対称キーを使用したユーザー名認証</a>を参照してください。その他の使用可能なセキュリティ・メカニズムの詳細は、<a href="http://docs.oracle.com/cd/E19182-01/820-0595/6ncatc2q5/index.html" target="_blank">セキュリティ・メカニズムの構成</a>を参照してください。</p>
</li>
<li>「サービス品質」タブの「入力メッセージ」および「出力メッセージ」セクションを展開します。<br> <img alt="「メッセージ部品」ボタンが有効な「サービス品質」ページ" class="margin-around b-all" src="../../../images_www/articles/74/websvc/wsit/wsit-quality-dialog2.png" title="「メッセージ部品」ボタンが有効な「サービス品質」ページ">
<p>セキュリティ・メカニズムとして「対称キーを使用したユーザー名認証」を選択した場合、「入力メッセージ」および「出力メッセージ」で「メッセージ部品」ボタンが有効です。</p>
<p class="notes"><b>注意: </b>入力メッセージの「認証トークン」ドロップダウン・リストとオプションは、「対称キーを使用したユーザー名認証」セキュリティ・メカニズムの場合、有効ではありません。</p>
</li>
<li>「入力メッセージ」セクションで、「メッセージ部品」ボタンをクリックします。<br> <img alt="「メッセージ部品」ダイアログ" class="margin-around b-all" src="../../../images_www/articles/74/websvc/wsit/wsit-messageparts.png" title="「メッセージ部品」ダイアログ">
<p>「メッセージ部品」ダイアログ・ボックスに、様々な要素のセキュリティ・オプションが表示されます。チェックボックスを選択して、部品の署名、暗号化および必須を有効または無効にできます。要素ごとに次のオプションを指定できます。</p>
<ul>
<li>完全性の保護(デジタル署名)が必要なメッセージの部品または要素を指定するには、<strong>「署名」</strong>を選択します。</li>
<li>機密性(暗号化)が必要なメッセージの部品または要素を指定するには<strong>「暗号化」</strong>を選択します。</li>
<li>メッセージに含まれる必要がある部品または要素を指定するには、<strong>「必須」</strong>を選択します。</li>
</ul>
<p>次に、Webサービス・クライアントのサービス品質がどのように構成されているかを確認します。</p>
</li>
<li>「プロジェクト」ウィンドウで、<strong>「SecureCalculatorClientApp」</strong>プロジェクトの「Webサービス参照」ノードを展開します。</li>
<li>CalculatorWSServiceノードを右クリックし、ポップアップ・メニューで「Webサービス属性を編集」を選択し、「Webサービス属性」ダイアログ・ボックスを開きます。<br> <img alt="Webサービス・クライアントのサービス品質ダイアログ" class="margin-around b-all" src="../../../images_www/articles/74/websvc/wsit/wsit-qos-wsservice.png" title="Webサービス・クライアントのサービス品質ダイアログ">
<p>デフォルト・ユーザー"wsitUser"およびパスワードが存在することを確認できます。デフォルト・ユーザーおよびパスワードは、ファイル・レルムで作成されました。</p>
<p>「セキュリティ」セクションで「開発のデフォルトの使用」オプションを選択すると、IDEは、証明書をGlassFishサーバーのキーストアとトラストストアにインポートし、すぐに開発で使用できるようにします。</p>
<p class="alert"><strong>重要: </strong>本番環境では、多くの場合独自の証明書とユーザー設定を使用しますが、開発環境では、これらのデフォルトが便利である場合があります。</p>
<p>Webサービス・クライアントにセキュリティを構成する方法の詳細は、<a href="http://docs.oracle.com/cd/E19159-01/820-1072/index.html">WSITチュートリアル</a><a href="http://docs.oracle.com/cd/E19159-01/820-1072/6ncp48v3b/index.html">第7章のWSITセキュリティの使用</a>を参照してください。</p>
</li>
</ol>
<h3 class="tutorial"><a name="Exercise_2_2"></a>セキュリティ保護されたカリキュレータ・サンプルのデプロイおよびテスト</h3>
<ol>
<li>Webサービス・プロジェクト・ノードを右クリックし、「実行」を選択してWebサービスをデプロイします。</li>
<li>Webサービス・クライアントのプロジェクト・ノードを右クリックし、「実行」を選択します。
<p>クライアントを実行すると、アプリケーションがデプロイされ、サービスのインタフェースがブラウザで開きます。</p>
<img alt="ブラウザでの保護Webサービス・クライアント" class="margin-around b-all" src="../../../images_www/articles/74/websvc/wsit/wsit-browser-secure1.png" title="ブラウザでの保護Webサービス・クライアント">
</li>
<li>各フィールドに数値を入力し、「Get Result」をクリックします。
<p>「Get Result」をクリックすると、クライアントが認証されたことを示すメッセージおよび操作の結果がページに表示されます。</p>
<img alt="ブラウザで結果を表示する保護Webサービス・クライアント" class="margin-around b-all" src="../../../images_www/articles/74/websvc/wsit/wsit-browser-secure2.png" title="ブラウザで結果を表示する保護Webサービス・クライアント">
</li>
</ol>
<p class="notes">ユーザー/パスワードのペアが無効なため認証に失敗したというエラー・メッセージを受け取る場合、IDEによって作成されたデフォルト・ユーザーに問題があるか、またはクライアントに設定された資格情報が一致しないかのいずれかです。この場合、ユーザー/パスワードのペアを手動で作成する必要があります。手順については、<a href="http://docs.oracle.com/cd/E19159-01/820-1072/index.html">WSITチュートリアル</a><a href="http://docs.oracle.com/cd/E19159-01/820-1072/6ncp48v3b/index.html">第7章のWSITセキュリティの使用</a>を参照してください。</p>
</div>
<div class="feedback-box" ><a href="/about/contact_form.html?to=3&amp;subject=Feedback:WSIT%20Advanced%20Interoperability%20in%20NetBeans%20IDE%206.0">このチュートリアルに関するご意見をお寄せください</a></div>
<!-- ======================================================================================= -->
<br>
<h2><a name="seealso"></a>関連項目</h2>
<p>NetBeans IDEを使用してWebサービスを開発する方法の詳細は、次のリソースを参照してください。
</p>
<ul>
<li><a href="client.html">JAX-WS Webサービス・クライアントの開発</a></li>
<li><a href="jax-ws.html">JAX-WS Webサービスについて</a></li>
<li><a href="rest.html">RESTful Webサービスについて</a></li>
<li><a href="flower_overview.html">バイナリ・データを渡すWebサービス・アプリケーション</a></li>
<li><a href="../../74/websvc/jaxb_ja.html">JAXBによるWSDLのJavaへのバインディング</a></li>
<li><a href="../../trails/web.html">Webサービスの学習</a></li>
</ul>
<p><a href="../../../community/lists/top.html">nbj2ee@netbeans.orgメーリング・リスト</a>に登録することによって、NetBeans IDE Java EE開発機能に関するご意見やご提案を送信したり、サポートを受けたり、最新の開発情報を入手したりできます。</p>
</body>