クラス AbstractSingletonProxyFactoryBean

java.lang.ObjectSE
org.springframework.aop.framework.ProxyConfig
org.springframework.aop.framework.AbstractSingletonProxyFactoryBean
実装されたすべてのインターフェース:
SerializableSEAwareBeanClassLoaderAwareFactoryBean<ObjectSE>InitializingBean
既知の直属サブクラス
CacheProxyFactoryBeanTransactionProxyFactoryBean

public abstract class AbstractSingletonProxyFactoryBean extends ProxyConfig implements FactoryBean<ObjectSE>, BeanClassLoaderAware, InitializingBean
シングルトンスコープのプロキシオブジェクトを生成する FactoryBean 型の便利なスーパークラス。

インターセプターの前後を管理し(ProxyFactoryBean のようなインターセプター名ではなく参照)、一貫したインターフェース管理を提供します。

導入:
2.0
作成者:
Juergen Hoeller
関連事項:
  • コンストラクターの詳細

    • AbstractSingletonProxyFactoryBean

      public AbstractSingletonProxyFactoryBean()
  • メソッドの詳細

    • setTarget

      public void setTarget(ObjectSE target)
      ターゲットオブジェクト、つまりトランザクションプロキシでラップする Bean を設定します。

      ターゲットはどのオブジェクトでもかまいません。その場合、SingletonTargetSource が作成されます。TargetSource の場合、ラッパー TargetSource は作成されません。これにより、プーリングやプロトタイプ TargetSource などの使用が可能になります。

      関連事項:
    • setProxyInterfaces

      public void setProxyInterfaces(ClassSE<?>[] proxyInterfaces)
      プロキシされるインターフェースのセットを指定します。

      指定されていない場合(デフォルト)、AOP インフラストラクチャは、ターゲットを分析して、ターゲットオブジェクトが実装するすべてのインターフェースをプロキシすることで、プロキシが必要なインターフェースを特定します。

    • setPreInterceptors

      public void setPreInterceptors(ObjectSE[] preInterceptors)
      暗黙のトランザクションインターセプターの前に適用される追加のインターセプター(またはアドバイザー)を設定します。PerformanceMonitorInterceptor。

      任意の AOP アライアンス MethodInterceptors または他の Spring AOP アドバイス、および Spring AOP アドバイザーを指定できます。

      関連事項:
    • setPostInterceptors

      public void setPostInterceptors(ObjectSE[] postInterceptors)
      暗黙のトランザクションインターセプターの後に適用する追加のインターセプター(またはアドバイザー)を設定します。

      任意の AOP アライアンス MethodInterceptors または他の Spring AOP アドバイス、および Spring AOP アドバイザーを指定できます。

    • setAdvisorAdapterRegistry

      public void setAdvisorAdapterRegistry(AdvisorAdapterRegistry advisorAdapterRegistry)
      使用する AdvisorAdapterRegistry を指定します。デフォルトはグローバル AdvisorAdapterRegistry です。
      関連事項:
    • setProxyClassLoader

      public void setProxyClassLoader(ClassLoaderSE classLoader)
      ClassLoader を設定して、プロキシクラスを生成します。

      デフォルトは Bean ClassLoader、つまり、すべての Bean クラスをロードするために、それを含む BeanFactory によって使用される ClassLoader です。これは、特定のプロキシに対してここでオーバーライドできます。

    • setBeanClassLoader

      public void setBeanClassLoader(ClassLoaderSE classLoader)
      インターフェースからコピーされた説明: BeanClassLoaderAware
      Bean class loaderSE を Bean インスタンスに提供するコールバック。

      通常の Bean プロパティの設定、ただし InitializingBean's InitializingBean.afterPropertiesSet() メソッドやカスタム init-method などの初期化コールバックの前に呼び出さます。

      次で指定:
      インターフェース BeanClassLoaderAwaresetBeanClassLoader 
      パラメーター:
      classLoader - 所有クラスローダー
    • afterPropertiesSet

      public void afterPropertiesSet()
      インターフェースからコピーされた説明: InitializingBean
      すべての Bean プロパティを設定し、BeanFactoryAwareApplicationContextAware などを満たした後、包含 BeanFactory によって呼び出されます。

      このメソッドにより、Bean インスタンスは、すべての Bean プロパティが設定されたときに、その全体的な構成の検証と最終的な初期化を実行できます。

      次で指定:
      インターフェース InitializingBeanafterPropertiesSet 
    • createTargetSource

      protected TargetSource createTargetSource(ObjectSE target)
      指定されたターゲット(または TargetSource)の TargetSource を決定します。
      パラメーター:
      target - ターゲット。これが TargetSource の実装である場合は、TargetSource として使用されます。それ以外の場合は、SingletonTargetSource でラップされます。
      戻り値:
      このオブジェクトの TargetSource
    • postProcessProxyFactory

      protected void postProcessProxyFactory(ProxyFactory proxyFactory)
      サブクラスが ProxyFactory を使用してプロキシインスタンスを作成する前に後処理するためのフック。
      パラメーター:
      proxyFactory - 使用される AOP ProxyFactory
      導入:
      4.2
    • getObject

      public ObjectSE getObject()
      インターフェースからコピーされた説明: FactoryBean
      このファクトリによって管理されるオブジェクトのインスタンス(おそらく共有または独立)を返します。

      BeanFactory と同様に、これにより、シングルトンとプロトタイプの両方のデザインパターンをサポートできます。

      この FactoryBean が呼び出し時にまだ完全に初期化されていない場合(たとえば、循環参照に関係しているため)、対応する FactoryBeanNotInitializedException をスローします。

      Spring 2.0 以降、FactoryBeans は null オブジェクトを返すことができます。ファクトリはこれを通常の値として使用します。この場合、FactoryBeanNotInitializedException はスローされません。FactoryBean の実装では、必要に応じて FactoryBeanNotInitializedException 自体をすぐにスローすることをお勧めします。

      次で指定:
      インターフェース FactoryBean<ObjectSE>getObject 
      戻り値:
      Bean のインスタンス (null にすることができます)
      関連事項:
    • getObjectType

      @Nullable public ClassSE<?> 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

      protected abstract ObjectSE createMainInterceptor()
      このプロキシファクトリ Bean の「メイン」インターセプタを作成します。通常はアドバイザーですが、どのような型のアドバイスでもかまいません。

      事前インターセプターは前に適用され、リアクティブインターセプターはこのインターセプターの後に適用されます。