クラス AbstractSingletonProxyFactoryBean
- 実装されたすべてのインターフェース:
SerializableSE
、Aware
、BeanClassLoaderAware
、FactoryBean<ObjectSE>
、InitializingBean
- 既知の直属サブクラス
CacheProxyFactoryBean
,TransactionProxyFactoryBean
FactoryBean
型の便利なスーパークラス。 インターセプターの前後を管理し(ProxyFactoryBean
のようなインターセプター名ではなく参照)、一貫したインターフェース管理を提供します。
- 導入:
- 2.0
- 作成者:
- Juergen Hoeller
- 関連事項:
フィールドサマリー
インターフェース org.springframework.beans.factory.FactoryBean から継承されたフィールド
OBJECT_TYPE_ATTRIBUTE
コンストラクターのサマリー
メソッドのサマリー
修飾子と型メソッド説明void
protected abstract ObjectSE
このプロキシファクトリ Bean の「メイン」インターセプタを作成します。protected TargetSource
createTargetSource
(ObjectSE target) 指定されたターゲット(または TargetSource)の TargetSource を決定します。このファクトリによって管理されるオブジェクトのインスタンス(おそらく共有または独立)を返します。ClassSE<?>
この FactoryBean が作成するオブジェクトの型、または事前に不明な場合はnull
を返します。final boolean
このファクトリによって管理されるオブジェクトはシングルトンですか? つまり、FactoryBean.getObject()
は常に同じオブジェクト(キャッシュ可能な参照)を返しますか?protected void
postProcessProxyFactory
(ProxyFactory proxyFactory) サブクラスがProxyFactory
を使用してプロキシインスタンスを作成する前に後処理するためのフック。void
setAdvisorAdapterRegistry
(AdvisorAdapterRegistry advisorAdapterRegistry) 使用する AdvisorAdapterRegistry を指定します。void
setBeanClassLoader
(ClassLoaderSE classLoader) Beanclass loader
SE を Bean インスタンスに提供するコールバック。void
setPostInterceptors
(ObjectSE[] postInterceptors) 暗黙のトランザクションインターセプターの後に適用する追加のインターセプター(またはアドバイザー)を設定します。void
setPreInterceptors
(ObjectSE[] preInterceptors) 暗黙のトランザクションインターセプターの前に適用される追加のインターセプター(またはアドバイザー)を設定します。void
setProxyClassLoader
(ClassLoaderSE classLoader) ClassLoader を設定して、プロキシクラスを生成します。void
setProxyInterfaces
(ClassSE<?>[] proxyInterfaces) プロキシされるインターフェースのセットを指定します。void
ターゲットオブジェクト、つまりトランザクションプロキシでラップする Bean を設定します。クラス org.springframework.aop.framework.ProxyConfig から継承されたメソッド
copyFrom, isExposeProxy, isFrozen, isOpaque, isOptimize, isProxyTargetClass, setExposeProxy, setFrozen, setOpaque, setOptimize, setProxyTargetClass, toString
コンストラクターの詳細
AbstractSingletonProxyFactoryBean
public AbstractSingletonProxyFactoryBean()
メソッドの詳細
setTarget
ターゲットオブジェクト、つまりトランザクションプロキシでラップする Bean を設定します。ターゲットはどのオブジェクトでもかまいません。その場合、SingletonTargetSource が作成されます。TargetSource の場合、ラッパー TargetSource は作成されません。これにより、プーリングやプロトタイプ TargetSource などの使用が可能になります。
setProxyInterfaces
プロキシされるインターフェースのセットを指定します。指定されていない場合(デフォルト)、AOP インフラストラクチャは、ターゲットを分析して、ターゲットオブジェクトが実装するすべてのインターフェースをプロキシすることで、プロキシが必要なインターフェースを特定します。
setPreInterceptors
暗黙のトランザクションインターセプターの前に適用される追加のインターセプター(またはアドバイザー)を設定します。PerformanceMonitorInterceptor。任意の AOP アライアンス MethodInterceptors または他の Spring AOP アドバイス、および Spring AOP アドバイザーを指定できます。
setPostInterceptors
暗黙のトランザクションインターセプターの後に適用する追加のインターセプター(またはアドバイザー)を設定します。任意の AOP アライアンス MethodInterceptors または他の Spring AOP アドバイス、および Spring AOP アドバイザーを指定できます。
setAdvisorAdapterRegistry
使用する AdvisorAdapterRegistry を指定します。デフォルトはグローバル AdvisorAdapterRegistry です。setProxyClassLoader
ClassLoader を設定して、プロキシクラスを生成します。デフォルトは Bean ClassLoader、つまり、すべての Bean クラスをロードするために、それを含む BeanFactory によって使用される ClassLoader です。これは、特定のプロキシに対してここでオーバーライドできます。
setBeanClassLoader
インターフェースからコピーされた説明:BeanClassLoaderAware
Beanclass loader
SE を Bean インスタンスに提供するコールバック。通常の Bean プロパティの設定後、ただし
InitializingBean's
InitializingBean.afterPropertiesSet()
メソッドやカスタム init-method などの初期化コールバックの前に呼び出されます。- 次で指定:
- インターフェース
BeanClassLoaderAware
のsetBeanClassLoader
- パラメーター:
classLoader
- 所有クラスローダー
afterPropertiesSet
public void afterPropertiesSet()インターフェースからコピーされた説明:InitializingBean
すべての Bean プロパティを設定し、BeanFactoryAware
、ApplicationContextAware
などを満たした後、包含BeanFactory
によって呼び出されます。このメソッドにより、Bean インスタンスは、すべての Bean プロパティが設定されたときに、その全体的な構成の検証と最終的な初期化を実行できます。
- 次で指定:
- インターフェース
InitializingBean
のafterPropertiesSet
createTargetSource
指定されたターゲット(または TargetSource)の TargetSource を決定します。- パラメーター:
target
- ターゲット。これが TargetSource の実装である場合は、TargetSource として使用されます。それ以外の場合は、SingletonTargetSource でラップされます。- 戻り値:
- このオブジェクトの TargetSource
postProcessProxyFactory
サブクラスがProxyFactory
を使用してプロキシインスタンスを作成する前に後処理するためのフック。- パラメーター:
proxyFactory
- 使用される AOP ProxyFactory- 導入:
- 4.2
getObject
インターフェースからコピーされた説明:FactoryBean
このファクトリによって管理されるオブジェクトのインスタンス(おそらく共有または独立)を返します。BeanFactory
と同様に、これにより、シングルトンとプロトタイプの両方のデザインパターンをサポートできます。この FactoryBean が呼び出し時にまだ完全に初期化されていない場合(たとえば、循環参照に関係しているため)、対応する
FactoryBeanNotInitializedException
をスローします。Spring 2.0 以降、FactoryBeans は
null
オブジェクトを返すことができます。ファクトリはこれを通常の値として使用します。この場合、FactoryBeanNotInitializedException はスローされません。FactoryBean の実装では、必要に応じて FactoryBeanNotInitializedException 自体をすぐにスローすることをお勧めします。- 次で指定:
- インターフェース
FactoryBean<ObjectSE>
のgetObject
- 戻り値:
- Bean のインスタンス (
null
にすることができます) - 関連事項:
getObjectType
インターフェースからコピーされた説明:FactoryBean
この FactoryBean が作成するオブジェクトの型、または事前に不明な場合はnull
を返します。これにより、たとえばオートワイヤーなどで、オブジェクトをインスタンス化せずに特定の型の Bean を確認できます。
シングルトンオブジェクトを作成している実装の場合、このメソッドはシングルトンの作成を可能な限り回避しようとします。むしろ、事前に型を推定する必要があります。プロトタイプの場合、ここで意味のある型を返すこともお勧めします。
このメソッドは、この FactoryBean が完全に初期化される前に呼び出すことができます。初期化中に作成された状態に依存しないでください。もちろん、利用可能な場合はそのような状態を引き続き使用できます。
注意 : オートワイヤーは、ここで
null
を返す FactoryBeans を単に無視します。FactoryBean の現在の状態を使用して、このメソッドを適切に実装することを強くお勧めします。- 次で指定:
- インターフェース
FactoryBean<ObjectSE>
のgetObjectType
- 戻り値:
- この FactoryBean が作成するオブジェクトの型、または呼び出し時に不明な場合は
null
- 関連事項:
isSingleton
public final boolean isSingleton()インターフェースからコピーされた説明:FactoryBean
このファクトリによって管理されるオブジェクトはシングルトンですか? つまり、FactoryBean.getObject()
は常に同じオブジェクト(キャッシュ可能な参照)を返しますか?注意 : FactoryBean がシングルトンオブジェクトを保持することを示す場合、
getObject()
から返されたオブジェクトは所有 BeanFactory によってキャッシュされる可能性があります。FactoryBean が常に同じ参照を公開しない限り、true
を返さないでください。FactoryBean 自体のシングルトンステータスは、通常、所有する BeanFactory によって提供されます。通常、そこではシングルトンとして定義する必要があります。
注意 :
false
を返すこのメソッドは、返されるオブジェクトが独立したインスタンスであることを必ずしも示しません。拡張SmartFactoryBean
インターフェースの実装は、SmartFactoryBean.isPrototype()
メソッドを通じて独立したインスタンスを明示的に示す場合があります。この拡張インターフェースを実装しないプレーンなFactoryBean
実装は、isSingleton()
実装がfalse
を返す場合、常に独立したインスタンスを返すと単純に想定されます。FactoryBean
は通常シングルトンインスタンスを管理するため、デフォルトの実装ではtrue
が返されます。- 次で指定:
- インターフェース
FactoryBean<ObjectSE>
のisSingleton
- 戻り値:
- 公開されたオブジェクトがシングルトンかどうか
- 関連事項:
createMainInterceptor
このプロキシファクトリ Bean の「メイン」インターセプタを作成します。通常はアドバイザーですが、どのような型のアドバイスでもかまいません。事前インターセプターは前に適用され、リアクティブインターセプターはこのインターセプターの後に適用されます。