@TargetSE(valueSE=TYPESE) @RetentionSE(valueSE=RUNTIMESE) @DocumentedSE @Component public @interface ControllerAdvice
@Controller
クラス間で共有される @ExceptionHandler
、@InitBinder
、@ModelAttribute
メソッドを宣言するクラスの @Component
の特殊化。@ControllerAdvice
を持つクラスは、Spring Bean として明示的に宣言するか、クラスパススキャンを介して自動検出できます。このような Bean はすべて、AnnotationAwareOrderComparator
を介して、つまり @Order
と Ordered
に基づいてソートされ、実行時にこの順序で適用されます。例外を処理するために、例外に一致する最初の @ExceptionHandler
が使用されます。モデル属性および InitBinder
初期化の場合、@ModelAttribute
および @InitBinder
メソッドも @ControllerAdvice
の順序に従います。
デフォルトでは、@ControllerAdvice
のメソッドはすべてのコントローラーにグローバルに適用されます。セレクター annotations()
、basePackageClasses()
、basePackages()
(またはそのエイリアス value()
)を使用して、対象のコントローラーのより狭いサブセットを定義します。複数のセレクターが宣言されている場合、OR ロジックが適用されます。つまり、選択されたコントローラーは少なくとも 1 つのセレクターと一致する必要があります。セレクターのチェックは実行時に実行されるため、多くのセレクターを追加するとパフォーマンスに悪影響を及ぼし、複雑さが増す可能性があることに注意してください。
修飾子と型 | オプションの要素と説明 |
---|---|
ClassSE<? extends AnnotationSE>[] | annotations アノテーションの配列。 |
ClassSE<?>[] | assignableTypes クラスの配列。 |
ClassSE<?>[] | basePackageClasses @ControllerAdvice アノテーション付きクラスによって支援されるコントローラーを選択するパッケージを指定するための、value() の型安全な代替手段。 |
StringSE[] | basePackages 基本パッケージの配列。 |
StringSE[] | value basePackages() 属性のエイリアス。 |
@AliasFor(value="basePackages") public abstract StringSE[] value
basePackages()
属性のエイリアス。 より簡潔なアノテーション宣言を可能にします。例: @ControllerAdvice("org.my.pkg")
は @ControllerAdvice(basePackages="org.my.pkg")
と同等です。
basePackages()
@AliasFor(value="value") public abstract StringSE[] basePackages
それらの基本パッケージまたはそのサブパッケージに属するコントローラーが含まれます(例: @ControllerAdvice(basePackages="org.my.pkg")
または @ControllerAdvice(basePackages={"org.my.pkg", "org.my.other.pkg"})
)。
value()
はこの属性のエイリアスであり、アノテーションをより簡潔に使用できるようにします。
文字列ベースのパッケージ名の型安全な代替として basePackageClasses()
を使用することも検討してください。
public abstract ClassSE<?>[] assignableTypes
指定された型の少なくとも 1 つに割り当て可能なコントローラーは、@ControllerAdvice
アノテーション付きクラスによって支援されます。
public abstract ClassSE<? extends AnnotationSE>[] annotations
これまたはこれらのアノテーションの 1 つでアノテーションが付けられたコントローラーは、@ControllerAdvice
アノテーション付きクラスによって支援されます。
特別なアノテーションの作成を検討するか、@RestController
などの事前定義されたアノテーションを使用してください。