JavaTM Platform
Standard Ed. 6

org.omg.PortableInterceptor
インタフェース ServerRequestInterceptorOperations

すべてのスーパーインタフェース:
InterceptorOperations
既知のサブインタフェースの一覧:
ServerRequestInterceptor

public interface ServerRequestInterceptorOperations
extends InterceptorOperations

サーバー側の要求インタセプタです。

要求インタセプタは、ORB の応答や要求シーケンスの流れを特定のポイントで遮断できるように設計されています。これにより、サービスは、要求情報を問い合わせたり、クライアントとサーバー間で伝播されるサービスコンテキストを操作したりできます。要求インタセプタは主に、ORB サービスがクライアントとサーバー間でコンテキスト情報を転送できるようにするために使用されます。要求インタセプタには、クライアント側とサーバー側の 2 種類があります。 

サーバー側のインタセプタを作成するには、ServerRequestInterceptor インタフェースを実装します。

関連項目:
ServerRequestInfo

メソッドの概要
 void receive_request_service_contexts(ServerRequestInfo ri)
          インタセプタでサービスコンテキスト情報を処理できるようにします。
 void receive_request(ServerRequestInfo ri)
          オペレーションパラメータなどのすべての情報が使用できるようになったあとで、インタセプタが要求情報を照会できるようにします。
 void send_exception(ServerRequestInfo ri)
          例外がクライアントにスローされる前に、インタセプタが例外情報を照会したり、応答サービスコンテキストを変更したりできるようにします。
 void send_other(ServerRequestInfo ri)
          要求によって通常の応答または例外以外のものが返されたときに、インタセプタが利用可能な情報を照会できるようにします。
 void send_reply(ServerRequestInfo ri)
          ターゲットオペレーションが呼び出されてから応答がクライアントに返されるまで、インタセプタが応答情報を照会したり、応答サービスコンテキストを変更したりできるようにします。
 
インタフェース org.omg.PortableInterceptor.InterceptorOperations から継承されたメソッド
destroy, name
 

メソッドの詳細

receive_request_service_contexts

void receive_request_service_contexts(ServerRequestInfo ri)
                                      throws ForwardRequest
インタセプタでサービスコンテキスト情報を処理できるようにします。

この遮断点で、インタセプタは着信要求からそのサービスコンテキスト情報を取得し、それを PortableInterceptor.Current のスロットに転送する必要があります。

この遮断点は、サーバントマネージャーが呼び出される前に呼び出されます。オペレーションパラメータは、この時点ではまだ使用できません。この遮断点は、ターゲットの呼び出しと同じスレッド内で動作する場合もしない場合もあります。

この遮断点では、システム例外がスローされる場合があります。この例外がスローされた場合、ほかのインタセプタの receive_request_service_contexts オペレーションは呼び出されません。フロースタック上のそれらのインタセプタが表示され、その send_exception 遮断点が呼び出されます。

この遮断点では、ForwardRequest 例外がスローされる場合もあります。この例外がスローされた場合、ほかのインタセプタの receive_request_service_contexts オペレーションは呼び出されません。フロースタック上のそれらのインタセプタが表示され、その send_other 遮断点が呼び出されます。

この遮断点からシステム例外をスローする場合、準拠しているインタセプタは completion_status セマンティクスに厳密に従います。completion_statusCOMPLETED_NO になります。

パラメータ:
ri - 遮断される現在の要求に関する情報
例外:
ForwardRequest - スローされた場合は、例外に指定されている 新しいオブジェクトを使って要求の再試行が行われることを ORB に通知する

receive_request

void receive_request(ServerRequestInfo ri)
                     throws ForwardRequest
オペレーションパラメータなどのすべての情報が使用できるようになったあとで、インタセプタが要求情報を照会できるようにします。この遮断点は、ターゲットの呼び出しと同じスレッド内で動作します。

DSI モデルでは、ユーザーコードによって arguments が呼び出された時点で初めてパラメータが使用できるようになるため、receive_requestarguments 内から呼び出されます。DSI モデルでは、arguments が呼び出されないこともあります。また、set_exception が呼び出されてから、arguments が呼び出されることもあります。ORB では、arguments または set_exception のどちらかを介して receive_request が 1 度だけ呼び出されることを保証しています。set_exception を介して呼び出された場合、引数を要求すると、標準マイナーコード 1 が設定された NO_RESOURCES がスローされます。 

この遮断点では、システム例外がスローされる場合があります。この例外がスローされた場合、ほかのインタセプタの receive_request オペレーションは呼び出されません。フロースタック上のそれらのインタセプタが表示され、その send_exception 遮断点が呼び出されます。

この遮断点では、ForwardRequest 例外がスローされる場合もあります。この例外がスローされた場合、ほかのインタセプタの receive_request オペレーションは呼び出されません。フロースタック上のそれらのインタセプタが表示され、その send_other 遮断点が呼び出されます。

この遮断点からシステム例外をスローする場合、準拠しているインタセプタは completion_status セマンティクスに厳密に従います。completion_statusCOMPLETED_NO になります。

パラメータ:
ri - 遮断される現在の要求に関する情報
例外:
ForwardRequest - スローされた場合は、例外に指定されている 新しいオブジェクトを使って要求の再試行が行われることを ORB に通知する

send_reply

void send_reply(ServerRequestInfo ri)
ターゲットオペレーションが呼び出されてから応答がクライアントに返されるまで、インタセプタが応答情報を照会したり、応答サービスコンテキストを変更したりできるようにします。この遮断点は、ターゲットの呼び出しと同じスレッド内で動作します。

この遮断点では、システム例外がスローされる場合があります。この例外がスローされた場合、ほかのインタセプタの send_reply オペレーションは呼び出されません。フロースタック内の残りのインタセプタが表示され、その send_exception 遮断点が呼び出されます。

この遮断点からシステム例外をスローする場合、準拠しているインタセプタは completion_status セマンティクスに厳密に従います。completion_statusCOMPLETED_YES になります。

パラメータ:
ri - 遮断される現在の要求に関する情報

send_exception

void send_exception(ServerRequestInfo ri)
                    throws ForwardRequest
例外がクライアントにスローされる前に、インタセプタが例外情報を照会したり、応答サービスコンテキストを変更したりできるようにします。例外が発生すると、この遮断点が呼び出されます。この遮断点は、ターゲットの呼び出しと同じスレッド内で動作します。

この遮断点では、システム例外がスローされる場合があります。この例外がスローされると、フロースタックから表示された後続のインタセプタがその send_exception 呼び出しで受信する例外が変更されます。クライアントにスローされる例外は、インタセプタによって最後にスローされる例外となります。 ただし、例外を変更するインタセプタがない場合は元の例外となります。

この遮断点では、ForwardRequest 例外がスローされる場合もあります。この例外がスローされた場合、ほかのインタセプタの send_exception オペレーションは呼び出されません。フロースタック内の残りのインタセプタが表示され、その send_other 遮断点が呼び出されます。

この例外の completion_statusCOMPLETED_NO の場合、この遮断点によって ForwardRequest 例外がスローされるのは適切ではありません。この要求の「最大で 1 回」というセマンティクスが失われます。

この遮断点からシステム例外をスローする場合、準拠しているインタセプタは completion_status セマンティクスに厳密に従います。元の例外がシステム例外である場合、新しい例外の completion_status は元の例外のそれと同じになります。元の例外がユーザー例外である場合、新しい例外の completion_statusCOMPLETED_YES になります。

パラメータ:
ri - 遮断される現在の要求に関する情報
例外:
ForwardRequest - スローされた場合は、例外に指定されている 新しいオブジェクトを使って要求の再試行が行われることを ORB に通知する

send_other

void send_other(ServerRequestInfo ri)
                throws ForwardRequest
要求によって通常の応答または例外以外のものが返されたときに、インタセプタが利用可能な情報を照会できるようにします。たとえば、要求によって再試行が生じる可能性があります (LOCATION_FORWARD 状態が設定された GIOP 応答が受信された場合など)。この遮断点は、ターゲットの呼び出しと同じスレッド内で動作します。

この遮断点では、システム例外がスローされる場合があります。この例外がスローされた場合、ほかのインタセプタの send_other オペレーションは呼び出されません。フロースタック内の残りのインタセプタが表示され、その send_exception 遮断点が呼び出されます。

この遮断点では、ForwardRequest 例外がスローされる場合もあります。この例外がスローされた場合は、後続のインタセプタの send_other オペレーションが呼び出され、ForwardRequest 例外によって新しい情報が提供されます。

この遮断点からシステム例外をスローする場合、準拠しているインタセプタは completion_status セマンティクスに厳密に従います。completion_statusCOMPLETED_NO になります。

パラメータ:
ri - 遮断される現在の要求に関する情報
例外:
ForwardRequest - スローされた場合は、例外に指定されている 新しいオブジェクトを使って要求の再試行が行われることを ORB に通知する

JavaTM Platform
Standard Ed. 6

バグの報告と機能のリクエスト
さらに詳しい API リファレンスおよび開発者ドキュメントについては、Java SE 開発者用ドキュメントを参照してください。開発者向けの詳細な解説、概念の概要、用語の定義、バグの回避策、およびコード実例が含まれています。

Copyright 2009 Sun Microsystems, Inc. All rights reserved. Use is subject to license terms. Documentation Redistribution Policy も参照してください。