クラス JobDetailFactoryBean

java.lang.ObjectSE
org.springframework.scheduling.quartz.JobDetailFactoryBean
実装されているすべてのインターフェース:
Aware, BeanNameAware, FactoryBean<JobDetail>, InitializingBean, ApplicationContextAware

public class JobDetailFactoryBean extends ObjectSE implements FactoryBean<JobDetail>, BeanNameAware, ApplicationContextAware, InitializingBean
Quartz JobDetail インスタンスを作成するための Spring FactoryBean。JobDetail 構成の Bean スタイルの使用をサポートします。

JobDetail(Impl) 自体はすでに JavaBean ですが、適切なデフォルトがありません。このクラスは、Spring Bean 名をジョブ名として使用し、Quartz デフォルトグループ("DEFAULT" )をジョブグループとして指定します(指定されていない場合)。

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

    • JobDetailFactoryBean

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

    • setName

      public void setName(StringSE name)
      ジョブの名前を指定します。
    • setGroup

      public void setGroup(StringSE group)
      ジョブのグループを指定します。
    • setJobClass

      public void setJobClass(ClassSE<? extends Job> jobClass)
      ジョブの実装クラスを指定します。
    • setJobDataMap

      public void setJobDataMap(JobDataMap jobDataMap)
      ジョブの JobDataMap を設定します。
      関連事項:
    • getJobDataMap

      public JobDataMap getJobDataMap()
      ジョブの JobDataMap を返します。
    • setJobDataAsMap

      public void setJobDataAsMap(MapSE<StringSE,?> jobDataAsMap)
      指定されたマップを介して JobDataMap にオブジェクトを登録します。

      これらのオブジェクトは、SchedulerContext のオブジェクトとは対照的に、このジョブでのみ使用できます。

      メモ: JobDetail がデータベースに保持される永続的なジョブを使用する場合は、Spring 管理の Bean または ApplicationContext 参照を JobDataMap ではなく SchedulerContext に配置しないでください。

      パラメーター:
      jobDataAsMap - String キーと任意のオブジェクトを値として持つ Map (たとえば、Spring に管理された Bean)
      関連事項:
    • setDurability

      public void setDurability(boolean durability)
      ジョブの永続化を指定します。つまり、トリガーが指していなくても、ジョブストアに保存されたままにするかどうかを指定します。
    • setRequestsRecovery

      public void setRequestsRecovery(boolean requestsRecovery)
      このジョブの回復フラグを設定します。つまり、「回復」または「フェイルオーバー」の状況が発生した場合にジョブを再実行する必要があるかどうかを設定します。
    • setDescription

      public void setDescription(StringSE description)
      このジョブの説明文を設定します。
    • setBeanName

      public void setBeanName(StringSE beanName)
      インターフェースからコピーされた説明: BeanNameAware
      この Bean を作成した Bean ファクトリで Bean の名前を設定します。

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

      次で指定:
      インターフェース BeanNameAwaresetBeanName 
      パラメーター:
      beanName - ファクトリ内の Bean の名前。この名前は、ファクトリで使用される実際の Bean 名であり、最初に指定した名前とは異なる場合があります。特に内部 Bean 名の場合、実際の Bean 名は "#..." サフィックスを追加することで一意になります。必要に応じて、BeanFactoryUtils.originalBeanName(String) メソッドを使用して、元の Bean 名(サフィックスなし)を抽出します。
    • setApplicationContext

      public void setApplicationContext(ApplicationContext applicationContext)
      インターフェースからコピーされた説明: ApplicationContextAware
      このオブジェクトが実行される ApplicationContext を設定します。通常、この呼び出しはオブジェクトの初期化に使用されます。

      通常の Bean プロパティの設定後、ただし InitializingBean.afterPropertiesSet() またはカスタム init メソッドなどの init コールバックの前に呼び出されます。ResourceLoaderAware.setResourceLoader(ResourceLoader)ApplicationEventPublisherAware.setApplicationEventPublisher(ApplicationEventPublisher) および MessageSourceAware の後に呼び出されます(該当する場合)。

      次で指定:
      インターフェース ApplicationContextAwaresetApplicationContext 
      パラメーター:
      applicationContext - このオブジェクトによって使用される ApplicationContext オブジェクト
      関連事項:
    • setApplicationContextJobDataKey

      public void setApplicationContextJobDataKey(StringSE applicationContextJobDataKey)
      JobDataMap で公開する ApplicationContext 参照のキーを設定します (例: "applicationContext" )。デフォルトはなしです。Spring ApplicationContext で実行している場合にのみ適用されます。

      QuartzJobBean の場合、参照は Bean プロパティとしてジョブインスタンスに適用されます。そのシナリオでは、"applicationContext" 属性 は "setApplicationContext" メソッドに対応します。

      Quartz 自体がジョブのライフサイクルを担当するため、ApplicationContextAware のような BeanFactory コールバックインターフェースは Quartz ジョブインスタンスに自動的に適用されないことに注意してください。

      メモ: JobDetail の内容がデータベースに保持される永続的なジョブストアを使用する場合は、ApplicationContext 参照を JobDataMap ではなく SchedulerContext に配置してください。

      関連事項:
    • afterPropertiesSet

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

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

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

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

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

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

      FactoryBeans は null オブジェクトを返すことができます。Bean ファクトリはこれを通常の値と見なし、この場合は FactoryBeanNotInitializedException をスローしません。ただし、FactoryBean 実装では、必要に応じて FactoryBeanNotInitializedException 自体をスローすることが推奨されます。

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

      public ClassSE<?> getObjectType()
      インターフェースからコピーされた説明: FactoryBean
      この FactoryBean が作成するオブジェクトの型を返します。事前にわからない場合は null を返します。

      これにより、たとえばオートワイヤーなどで、オブジェクトをインスタンス化せずに特定の型の Bean を確認できます。

      シングルトンオブジェクトを作成する実装の場合、このメソッドはシングルトンの作成を可能な限り回避し、事前に型を推定する必要があります。プロトタイプの場合は、ここで意味のある型を返すことも推奨されます。

      このメソッドは、この FactoryBean が完全に初期化される前に呼び出すことができます。初期化中に作成された状態に依存しないでください。もちろん、利用可能な場合はそのような状態を引き続き使用できます。

      注意 : オートワイヤーは、ここで null を返す FactoryBeans を単に無視します。FactoryBean の現在の状態を使用して、このメソッドを適切に実装することを強くお勧めします。

      次で指定:
      インターフェース FactoryBean<JobDetail>getObjectType 
      戻り値:
      この FactoryBean が作成するオブジェクトの型、または呼び出し時に不明な場合は null 
      関連事項:
    • isSingleton

      public boolean isSingleton()
      インターフェースからコピーされた説明: FactoryBean
      このファクトリによって管理されるオブジェクトはシングルトンですか? つまり、FactoryBean.getObject() は常に同じオブジェクト(キャッシュ可能な参照)を返しますか?

      注意 : FactoryBean がシングルトンオブジェクトを保持していることを示している場合、getObject() から返されたオブジェクトは、所有する BeanFactory によってキャッシュされる可能性があります。FactoryBean が常に同じ参照を公開しない限り、true を返さないでください。

      FactoryBean 自体のシングルトンステータスは、通常、所有する BeanFactory によって提供されます。通常、そこではシングルトンとして定義する必要があります。

      注意 false を返すこのメソッドは、返されるオブジェクトが独立したインスタンスであることを必ずしも示しません。拡張 SmartFactoryBean インターフェースの実装は、SmartFactoryBean.isPrototype() メソッドを通じて独立したインスタンスを明示的に示す場合があります。この拡張インターフェースを実装しないプレーンな FactoryBean 実装は、isSingleton() 実装が false を返す場合、常に独立したインスタンスを返すと単純に想定されます。

      FactoryBean は通常シングルトンインスタンスを管理するため、デフォルトの実装では true が返されます。

      次で指定:
      インターフェース FactoryBean<JobDetail>isSingleton 
      戻り値:
      公開されたオブジェクトがシングルトンかどうか
      関連事項: