BizTalk Serverを使用して SAP で RFC を呼び出す
SAP アダプターは、SAP システムによって公開される RFC を、アダプター クライアントが呼び出すことができる操作として表示します。 このセクションでは、Microsoft BizTalk Serverで SAP アダプターを使用して SAP システムで RFC を呼び出す手順について説明します。 SAP アダプターが SAP システムでの RFC の呼び出しをサポートする方法の詳細については、「SAP での RFC に対する操作」を参照してください。 RFC を呼び出すための SOAP メッセージの構造の詳細については、「RFC 操作のメッセージ スキーマ」を参照してください。
SAP システムで RFC を呼び出す方法
BizTalk Serverを使用して SAP アダプターを使用して SAP システムで操作を実行するには、「SAP アプリケーションを作成するための構成要素」で説明されている手続き型タスクが含まれます。 SAP システムで RFC を呼び出すには、次のタスクを実行します。
BizTalk プロジェクトを作成し、SAP システムで呼び出す RFC のスキーマを生成します。
SAP システムからメッセージを送受信するためのメッセージを BizTalk プロジェクトに作成します。
SAP システムで RFC を呼び出すオーケストレーションを作成します。
BizTalk プロジェクトをビルドして展開します。
物理送受信ポートを作成して BizTalk アプリケーションを構成します。
BizTalk アプリケーションを起動します。
このトピックでは、これらのタスクを実行する手順について説明します。
スキーマの生成
このトピックでは、SAP システムで RFC を呼び出す方法を示すために、 RFC_CUSTOMER_GETのスキーマを生成します。 スキーマの生成方法の詳細については、「 SAP での RFC 操作のメタデータの参照、検索、取得 」を参照してください。
メッセージとメッセージの種類の定義
前に生成したスキーマでは、オーケストレーション内のメッセージに必要な "型" について説明します。 通常、メッセージは変数であり、対応するスキーマによって定義される型です。 生成したスキーマを BizTalk プロジェクトのオーケストレーション ビューからメッセージにリンクする必要があります。
このトピックでは、2 つのメッセージを作成する必要があります。1 つは SAP システムに要求を送信し、もう 1 つは応答を受信するメッセージです。
メッセージを作成し、スキーマにリンクするには、次の手順を実行します。
メッセージを作成し、スキーマにリンクするには
まだ開いていない場合は、オーケストレーション ビュー BizTalk プロジェクトを開きます。 [ 表示] をクリックし、[ その他のウィンドウ] をポイントして、[ オーケストレーション ビュー] をクリックします。
オーケストレーション ビューで、[メッセージ] を右クリックし、[新しいメッセージ] をクリックします。
新しく作成したメッセージを右クリックし、[ プロパティ ウィンドウ] を選択します。
Message_1の [プロパティ] ウィンドウで、次の操作を行います。
プロパティ 目的 識別子 「 Request」と入力します。 メッセージ型 ドロップダウン リストから [ スキーマ] を展開し、[ InvokeRFC.SAPBindingSchema.RFC_CUSTOMER_GET] を選択します。 ここで、InvokeRFC は BizTalk プロジェクトの名前です。 SAPBindingSchema は、 RFC_CUSTOMER_GET用に生成されるスキーマです。 前の手順を繰り返して、新しいメッセージを作成します。 新しいメッセージの [プロパティ ] ペインで、次の操作を行います。
プロパティ 目的 識別子 「 応答」と入力します。 メッセージ型 ドロップダウン リストから [ スキーマ] を展開し、[ InvokeRFC.SAPBindingSchema.RFC_CUSTOMER_GETResponse] を選択します。
オーケストレーションの設定
SAP システムで RFC を呼び出すためにBizTalk Serverを使用するには、BizTalk オーケストレーションを作成する必要があります。 このオーケストレーションでは、定義された受信場所に要求メッセージをドロップします。 SAP アダプターはメッセージを使用し、それを SAP システムに渡します。 SAP システムからの応答は、別の場所に保存されます。 SAP システムで RFC を呼び出すための一般的なオーケストレーションには、次のものが含まれます。
SAP システムにメッセージを送信し、応答を受信する図形の送受信。
SAP システムに送信する要求メッセージを受信する一方向の受信ポート。
SAP システムに要求メッセージを送信し、応答を受信するための双方向送信ポート。
SAP システムからフォルダーに応答を送信する一方向送信ポート。
サンプル オーケストレーションは次のようになります。
メッセージ図形の追加
メッセージ図形ごとに次のプロパティを指定してください。 [図形] 列に表示される名前は、前のオーケストレーションに表示されているメッセージ図形の名前です。
図形 | 図形の種類 | プロパティ |
---|---|---|
Receive_Request | 受信 | - [名前] を [Receive_Request] に設定します - Activate をTrue に設定する |
Send_LOB | Send | - [名前] を [Send_LOB] に設定します |
Receive_LOB | 受信 | - [名前] を [Receive_LOB] に設定します - Activate をFalse に設定する |
Send_Response | Send | - [名前] を [Send_Response] に設定します |
ポートの追加
論理ポートごとに次のプロパティを指定します。 [ ポート ] 列に表示される名前は、オーケストレーションに表示されるポートの名前です。
Port | プロパティ |
---|---|
ReceiveMsgPort | - 識別子を ReceiveMsgPort に設定する - 型を ReceiveMsgPortType に設定する - 通信パターンを一方向に設定する - 受信する通信方向を設定する |
SendToLOBPort | - 識別子を SendToLOBPort に設定する - 型を SendToLOBPortType に設定する - 通信パターンを Request-Response に設定する - [通信の方向] を [送受信] に設定する |
SendMsgPort | - 識別子を SendMsgPort に設定する - Type を SendMsgPortType に設定する - 通信パターンを一方向に設定する - [通信の方向] を [送信] に設定する |
アクション図形のメッセージを指定し、ポートに接続する
次の表では、アクション図形のメッセージを指定し、ポートにリンクするために設定するプロパティとその値を指定します。 [図形] 列に表示される名前は、前のオーケストレーションに表示されているメッセージ図形の名前です。
図形 | プロパティ |
---|---|
Receive_Request | - メッセージを要求に設定する - 操作を ReceiveMsgPort.Operation_1.Request に設定する |
Send_LOB | - メッセージを要求に設定する - 操作を SendToLOBPort.Operation_1.Request に設定する |
Receive_LOB | - [メッセージ] を [応答] に設定する - 操作を SendToLOBPort.Operation_1.Response に設定する |
Send_Response | - [メッセージ] を [応答] に設定する - 操作を SendMsgPort.Operation_1.Request に設定する |
これらのプロパティを指定すると、メッセージの図形とポートが接続され、オーケストレーションが完了します。
BizTalk ソリューションをビルドし、BizTalk Serverに展開する必要があります。 詳細については、「オーケストレーションの ビルドと実行」を参照してください。
BizTalk アプリケーションの構成
BizTalk プロジェクトを展開すると、前に作成したオーケストレーションが、BizTalk Server管理コンソールの [オーケストレーション] ウィンドウの下に一覧表示されます。 アプリケーションを構成するには、BizTalk Server管理コンソールを使用する必要があります。 アプリケーションの構成の詳細については、「アプリケーション を構成する方法」を参照してください。
アプリケーションの構成には、次の作業が含まれます。
アプリケーションのホストの選択。
オーケストレーションで作成したポートを、BizTalk Server管理コンソールの物理ポートにマッピングします。 このオーケストレーションでは、次の操作を行う必要があります。
ハード ディスク上の場所と、要求メッセージを削除する対応するファイル ポートを定義します。 BizTalk オーケストレーションは、要求メッセージを使用して SAP システムに送信します。
ハード ディスク上の場所と、BizTalk オーケストレーションが SAP システムからの応答を含む応答メッセージを削除する対応するファイル ポートを定義します。
SAP システムにメッセージを送信するための物理 WCF-Custom または WCF-SAP 送信ポートを定義します。 また、送信ポートでアクションを指定する必要があります。 ポートを作成する方法については、「 SAP アダプターへの物理ポート バインドを手動で構成する」を参照してください。
Note
アダプター サービス BizTalk プロジェクト アドインを使用してスキーマを生成すると、ポートとそれらのポートに設定するアクションに関する情報を含むバインド ファイルも作成されます。 このバインド ファイルをBizTalk Server管理コンソールからインポートして、送信ポート (送信呼び出しの場合) または受信ポート (受信呼び出し用) を作成できます。 詳細については、「 SAP へのポート バインド ファイルを使用して物理ポート バインドを構成する」を参照してください。
アプリケーションの起動
SAP システムで RFC を呼び出すには、BizTalk アプリケーションを起動する必要があります。 BizTalk アプリケーションを起動する手順については、「 オーケストレーションを開始する方法 」または「 アプリケーションを起動する方法」を参照してください。
この段階で、次のことを確認します。
オーケストレーションの要求メッセージを受信する FILE 受信ポートが実行されています。
オーケストレーションから応答メッセージを受信する FILE 送信ポートが実行されています。
SAP システムにメッセージを送信するための WCF-Custom または WCF-SAP 送信ポートが実行されています。
操作の BizTalk オーケストレーションが実行されています。
操作の実行
アプリケーションを実行した後、オーケストレーションの要求メッセージを定義済みの場所にドロップする必要があります。 SAP システムで RFC を呼び出すための要求メッセージのスキーマについては、「 RFC 操作 のメッセージ スキーマ」を参照してください。 たとえば、RFC_CUSTOMER_GETを呼び出す要求メッセージは次のとおりです。
<RFC_CUSTOMER_GET xmlns="http://Microsoft.LobServices.Sap/2007/03/Rfc/">
<KUNNR>0000001390</KUNNR>
<NAME1>*</NAME1>
<CUSTOMER_T/>
</RFC_CUSTOMER_GET>
オーケストレーションによってメッセージが使用され、SAP システムに送信されます。 SAP システムからの応答は、オーケストレーションの一部として定義されている他のファイルの場所に保存されます。 たとえば、上記の要求メッセージに対する SAP システムからの応答は次のようになります。
<?xml version="1.0" encoding="utf-8" ?>
<RFC_CUSTOMER_GETResponse xmlns="http://Microsoft.LobServices.Sap/2007/03/Rfc/">
<CUSTOMER_T>
<RFCCUST xmlns="http://Microsoft.LobServices.Sap/2007/03/Types/Rfc/">
<KUNNR>0000001390</KUNNR>
<ANRED>Firma</ANRED>
<NAME1>Contoso, Ltd.</NAME1>
<PFACH />
<STRAS>4567 Main Street</STRAS>
<PSTLZ>98052</PSTLZ>
<ORT01>USA</ORT01>
<TELF1>555-0101</TELF1>
<TELFX>555-0102</TELFX>
</RFCCUST>
</CUSTOMER_T>
</RFC_CUSTOMER_GETResponse>
考えられる例外
BizTalk Serverを使用して SAP システムで RFC を呼び出すときに発生する可能性がある例外については、「SAP アダプターでの例外とエラー処理」を参照してください。
ベスト プラクティス
BizTalk プロジェクトを展開して構成したら、バインド ファイルと呼ばれる XML ファイルに構成設定をエクスポートできます。 バインド ファイルを生成したら、同じオーケストレーションに対して送信ポートや受信ポートなどを作成する必要がないように、ファイルから構成設定をインポートできます。 バインド ファイルの詳細については、「 SAP アダプター バインドを再利用する」を参照してください。