@Target(value=TYPE) @Retention(value=RUNTIME) @Documented @Component public @interface ControllerAdvice
Serves as a specialization of @Component, allowing for
 implementation classes to be autodetected through classpath scanning.
 
It is typically used to define @ExceptionHandler,
 @InitBinder, and @ModelAttribute
 methods that apply to all @RequestMapping methods.
 
One of annotations(), basePackageClasses(),
 basePackages() or its alias value()
 may be specified to define specific subsets of Controllers
 to assist. When multiple selectors are applied, OR logic is applied -
 meaning selected Controllers should match at least one selector.
 
The default behavior (i.e. if used without any selector),
 the @ControllerAdvice annotated class will
 assist all known Controllers.
 
Note that those checks are done at runtime, so adding many attributes and using multiple strategies may have negative impacts (complexity, performance).
| Modifier and Type | Optional Element and Description | 
|---|---|
| Class<? extends Annotation>[] | annotationsArray of annotations. | 
| Class<?>[] | assignableTypesArray of classes. | 
| Class<?>[] | basePackageClassesType-safe alternative to  value()for specifying the packages
 to select Controllers to be assisted by the@ControllerAdviceannotated class. | 
| String[] | basePackagesArray of base packages. | 
| String[] | valueAlias for the  basePackages()attribute. | 
public abstract String[] value
basePackages() attribute.
 Allows for more concise annotation declarations e.g.:
 @ControllerAdvice("org.my.pkg") is equivalent to
 @ControllerAdvice(basePackages="org.my.pkg").public abstract String[] basePackages
@ControllerAdvice(basePackages="org.my.pkg") or
 @ControllerAdvice(basePackages={"org.my.pkg","org.my.other.pkg"})
 value() is an alias for this attribute.
 
Also consider using basePackageClasses() as a type-safe
 alternative to String-based package names.
public abstract Class<?>[] basePackageClasses
value() for specifying the packages
 to select Controllers to be assisted by the @ControllerAdvice
 annotated class.
 Consider creating a special no-op marker class or interface in each package that serves no purpose other than being referenced by this attribute.
public abstract Class<?>[] assignableTypes
@ControllerAdvice annotated class.public abstract Class<? extends Annotation>[] annotations
@ControllerAdvice annotated class.
 Consider creating a special annotation or use a predefined one,
 like @RestController.