JavaTM 2
Platform
Std. Ed. v1.4.0

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

すべてのスーパーインタフェース:
IDLEntity, Object, ORBInitializerOperations, Serializable

public interface ORBInitializer
extends ORBInitializerOperations, Object, IDLEntity

インタセプタの登録と ORB の初期化を容易にします。

インタセプタは、ORB サービスが ORB 処理にアクセスして、事実上 ORB の一部になるための手段となるよう意図されています。インタセプタは ORB の一部であるため、ORB.init が ORB を返すときは、インタセプタの登録が完了しています。ORB.init の呼び出しによって ORB が返されたあとでインタセプタを ORB に登録することはできません。

インタセプタの登録は、ORBInitializer インタフェースを実装する関連付けられた ORBInitializer オブジェクトを登録する方法で行われます。ORB は、初期化しているときに、登録されている各 ORBInitializer を呼び出し、そのインタセプタの登録に使用される ORBInitInfo オブジェクトをそれに渡します。

Java で ORB 初期化子を登録する

ORBInitializers は、Java ORB プロパティを経由して登録されます。

プロパティ名は、以下の形式をとります。

org.omg.PortableInterceptor.ORBInitializerClass.<Service>
<Service> は、次のプロパティを実装するクラスの文字列名です。
org.omg.PortableInterceptor.ORBInitializer
名前の重複を避けるために、逆の DNS 命名規則が使用されます。たとえば、X という会社にイニシャライザが 3 つある場合は、次のプロパティを定義できます。 ORB.init では、org.omg.PortableInterceptor.ORBInitializerClass で始まる ORB プロパティが収集され、それぞれのプロパティから <Service> の部分が抽出され、オブジェクトはクラス名として <Service> 文字列でインスタンスが生成され、そのオブジェクトで pre_init メソッドと post_init メソッドが呼び出されます。例外が発生しても、ORB はそれを無視して、処理を続行します。

たとえば、X 社が記述クライアント側のロギングサービスに次の ORBInitializer 実装があるとします。

package com.x.logging;
 
import org.omg.PortableInterceptor.Interceptor; 
import org.omg.PortableInterceptor.ORBInitializer; 
import org.omg.PortableInterceptor.ORBInitInfo; 
 
public class LoggingService implements ORBInitializer { 
void pre_init( ORBInitInfo info ) { 
// Instantiate the Logging Service s Interceptor. 
Interceptor interceptor = new LoggingInterceptor(); 
// Register the Logging Service s Interceptor. 
info.add_client_request_interceptor( interceptor ); 
     } 
 
void post_init( ORBInitInfo info ) { 
// This service does not need two init points. 
     } 
 } 
このロギングサービスを使って MyApp というプログラムを実行するには、ユーザは次のように入力します。
java -Dorg.omg.PortableInterceptor.ORBInitializerClass.com.x.Logging.LoggingService MyApp

インタセプタ登録時の注意

要求インタセプタは、ORB ベースで登録されます。

オブジェクトごとの仮想インタセプタを実現するには、遮断点におけるターゲット上のポリシー問い合わせ、作業の必要性の有無を決定します。

POA ごとの仮想インタセプタを実現する場合は、各 POA を異なる ORB でインスタンス化してください。インタセプタは管理しやすいように順序付けられていますが、インタセプタの登録と順序は何の関係もありません。要求インタセプタは、サービスコンテキストに関係しています。サービスコンテキストには順番がないため、要求インタセプタに順番を付ける必要はありません。IOR インタセプタはタグ付きコンポーネントに関係しています。タグ付きコンポーネントにも順番がないため、IOR インタセプタに順番を付ける必要はありません。

登録コード内では ORB を使用する (orb_id を指定して ORB.init を呼び出す) ことは避けてください。ORB の初期化中に登録が行われるため、この状態にある限り、この ORB の呼び出し結果は保証されません。

関連項目:
ORBInitInfo

インタフェース org.omg.PortableInterceptor.ORBInitializerOperations から継承したメソッド
post_init, pre_init
 
インタフェース org.omg.CORBA.Object から継承したメソッド
_create_request, _create_request, _duplicate, _get_domain_managers, _get_interface_def, _get_policy, _hash, _is_a, _is_equivalent, _non_existent, _release, _request, _set_policy_override
 


JavaTM 2
Platform
Std. Ed. v1.4.0

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

Java、Java 2D、および JDBC は米国ならびにその他の国における米国 Sun Microsystems, Inc. の商標もしくは登録商標です。
Copyright 1993-2002 Sun Microsystems, Inc. 901 San Antonio Road
Palo Alto, California, 94303, U.S.A. All Rights Reserved.