public class MBeanProxyFactoryBean extends MBeanClientInterceptor implements FactoryBean<java.lang.Object>, BeanClassLoaderAware, InitializingBean
マネージリソースがプロキシインターフェースを実装する必要はありませんが、便利な場合があります。管理インターフェースのすべての操作と属性が、プロキシインターフェースの対応するプロパティまたはメソッドと一致する必要はありません。
管理インターフェースに対応していないプロキシインターフェースのメソッドまたはプロパティを呼び出したりアクセスしたりしようとすると、InvalidInvocationException
が発生します。
MBeanClientInterceptor
, InvalidInvocationException
logger
コンストラクターと説明 |
---|
MBeanProxyFactoryBean() |
修飾子と型 | メソッドと説明 |
---|---|
void | afterPropertiesSet() proxyInterface が指定されていることを確認してから、ターゲット MBean のプロキシを生成します。 |
java.lang.Object | getObject() このファクトリによって管理されるオブジェクトのインスタンス(おそらく共有または独立)を返します。 |
java.lang.Class<?> | getObjectType() この FactoryBean が作成するオブジェクトの型、または事前に不明な場合は null を返します。 |
boolean | isSingleton() このファクトリによって管理されるオブジェクトはシングルトンですか? つまり、 FactoryBean.getObject() は常に同じオブジェクト(キャッシュ可能な参照)を返しますか? |
void | setBeanClassLoader(java.lang.ClassLoader classLoader) Bean class loader を Bean インスタンスに提供するコールバック。 |
void | setProxyInterface(java.lang.Class<?> proxyInterface) 生成されたプロキシが実装するインターフェースを設定します。 |
convertResultValueIfNecessary, destroy, doInvoke, getEnvironment, getManagementInterface, handleConnectFailure, invoke, isPrepared, prepare, setAgentId, setConnectOnStartup, setEnvironment, setManagementInterface, setObjectName, setRefreshOnConnectFailure, setServer, setServiceUrl, setUseStrictCasing
public void setProxyInterface(java.lang.Class<?> proxyInterface)
これは通常、ターゲット MBean に一致する管理インターフェースであり、MBean 属性の Bean プロパティ setter および getter と、MBean 操作の従来の Java メソッドを公開します。
public void setBeanClassLoader(java.lang.ClassLoader classLoader)
BeanClassLoaderAware
class loader
を Bean インスタンスに提供するコールバック。 通常の Bean プロパティの設定後、ただし InitializingBean's
InitializingBean.afterPropertiesSet()
メソッドやカスタム init-method などの初期化コールバックの前に呼び出されます。
BeanClassLoaderAware
の setBeanClassLoader
MBeanClientInterceptor
の setBeanClassLoader
classLoader
- 所有クラスローダー public void afterPropertiesSet() throws MBeanServerNotFoundException, MBeanInfoRetrievalException
proxyInterface
が指定されていることを確認してから、ターゲット MBean のプロキシを生成します。InitializingBean
の afterPropertiesSet
MBeanClientInterceptor
の afterPropertiesSet
MBeanServerNotFoundException
MBeanInfoRetrievalException
@Nullable public java.lang.Object getObject()
FactoryBean
BeanFactory
と同様に、これにより、シングルトンとプロトタイプの両方のデザインパターンをサポートできます。
この FactoryBean が呼び出し時にまだ完全に初期化されていない場合(たとえば、循環参照に関係しているため)、対応する FactoryBeanNotInitializedException
をスローします。
Spring 2.0 以降、FactoryBeans は null
オブジェクトを返すことができます。ファクトリはこれを通常の値として使用します。この場合、FactoryBeanNotInitializedException はスローされません。FactoryBean の実装では、必要に応じて FactoryBeanNotInitializedException 自体をすぐにスローすることをお勧めします。
FactoryBean<java.lang.Object>
の getObject
null
にすることができます)FactoryBeanNotInitializedException
public java.lang.Class<?> getObjectType()
FactoryBean
null
を返します。これにより、たとえばオートワイヤーなどで、オブジェクトをインスタンス化せずに特定の型の Bean を確認できます。
シングルトンオブジェクトを作成している実装の場合、このメソッドはシングルトンの作成を可能な限り回避しようとします。むしろ、事前に型を推定する必要があります。プロトタイプの場合、ここで意味のある型を返すこともお勧めします。
このメソッドは、この FactoryBean が完全に初期化される前に呼び出すことができます。初期化中に作成された状態に依存しないでください。もちろん、利用可能な場合はそのような状態を引き続き使用できます。
注意 : オートワイヤーは、ここで null
を返す FactoryBeans を単に無視します。FactoryBean の現在の状態を使用して、このメソッドを適切に実装することを強くお勧めします。
FactoryBean<java.lang.Object>
の getObjectType
null
ListableBeanFactory.getBeansOfType(java.lang.Class<T>)
public boolean isSingleton()
FactoryBean
FactoryBean.getObject()
は常に同じオブジェクト(キャッシュ可能な参照)を返しますか? 注意 : FactoryBean がシングルトンオブジェクトを保持することを示す場合、getObject()
から返されたオブジェクトは所有 BeanFactory によってキャッシュされる可能性があります。FactoryBean が常に同じ参照を公開しない限り、true
を返さないでください。
FactoryBean 自体のシングルトンステータスは、通常、所有する BeanFactory によって提供されます。通常、そこではシングルトンとして定義する必要があります。
注意 : false
を返すこのメソッドは、返されるオブジェクトが独立したインスタンスであることを必ずしも示しません。拡張 SmartFactoryBean
インターフェースの実装は、SmartFactoryBean.isPrototype()
メソッドを通じて独立したインスタンスを明示的に示す場合があります。この拡張インターフェースを実装しないプレーンな FactoryBean
実装は、isSingleton()
実装が false
を返す場合、常に独立したインスタンスを返すと単純に想定されます。
FactoryBean
は通常シングルトンインスタンスを管理するため、デフォルトの実装では true
が返されます。
FactoryBean<java.lang.Object>
の isSingleton
FactoryBean.getObject()
, SmartFactoryBean.isPrototype()