Skip to content

Spring Annotations

A comprehensive list of Spring Boot annotations, covering core Spring Boot, configuration, web, data, testing, and more. I'll organize them by categories with keys (annotation names) and values (purpose/use cases) for easy reference.

Core Annotations

Annotation Purpose/Use Case
@SpringBootApplication Main entry point for a Spring Boot application. Combines @Configuration, @ComponentScan, and @EnableAutoConfiguration.
@EnableAutoConfiguration Enables automatic configuration of Spring beans based on the classpath and defined properties.
@ComponentScan Scans the package and its sub-packages for Spring components (e.g., @Component, @Service).
@Configuration Marks a class as a source of bean definitions. Used to define Spring beans programmatically.
@Bean Declares a method as a Spring bean, registered in the application context.
@Import Imports additional configuration classes.
@ImportResource Loads bean definitions from external XML configuration files.

Web and REST Annotations

Annotation Purpose/Use Case
@RestController Marks a class as a REST API controller. Combines @Controller and @ResponseBody.
@Controller Marks a class as a web controller. Works with view templates (like Thymeleaf).
@RequestMapping Maps HTTP requests to specific handler methods or classes. Can be used on classes or methods.
@GetMapping Maps HTTP GET requests to specific handler methods.
@PostMapping Maps HTTP POST requests to specific handler methods.
@PutMapping Maps HTTP PUT requests to specific handler methods.
@DeleteMapping Maps HTTP DELETE requests to specific handler methods.
@PatchMapping Maps HTTP PATCH requests to specific handler methods.
@RequestBody Binds the HTTP request body to a Java object. Used in REST controllers.
@ResponseBody Binds the return value of a method directly to the HTTP response body.
@RequestParam Binds HTTP query parameters to method arguments.
@PathVariable Binds URI template variables to method parameters.
@RequestHeader Binds HTTP request headers to method parameters.
@CookieValue Binds cookie values to method parameters.
@ModelAttribute Binds form data to a model object.
@SessionAttributes Declares session-scoped model attributes.
@CrossOrigin Enables cross-origin requests (CORS) for specific endpoints.

JPA, JDBC Annotations

Annotation Purpose/Use Case
@Entity Marks a class as a JPA entity.
@Table Specifies the database table for a JPA entity.
@Id Marks a field as the primary key of a JPA entity.
@GeneratedValue Specifies how the primary key value should be generated.
@Column Specifies the mapping of a field to a database column.
@OneToOne Establishes a one-to-one relationship between entities.
@OneToMany Establishes a one-to-many relationship between entities.
@ManyToOne Establishes a many-to-one relationship between entities.
@ManyToMany Establishes a many-to-many relationship between entities.
@JoinColumn Specifies the foreign key column for a relationship.
@Query Defines a custom JPQL or SQL query on a repository method.
@Transactional Marks a method or class as transactional. Ensures ACID properties in data operations.
@EnableJpaRepositories Enables JPA repositories for data access.
@Repository Marks a class as a data repository.
@EnableTransactionManagement Enables declarative transaction management.

Security Annotations

Annotation Purpose/Use Case
@EnableWebSecurity Enables Spring Security for web applications.
@EnableGlobalMethodSecurity Enables method-level security annotations like @PreAuthorize and @PostAuthorize.
@PreAuthorize Applies authorization logic before a method is invoked.
@PostAuthorize Applies authorization logic after a method has executed.
@Secured Secures a method by roles (deprecated in favor of @PreAuthorize).
@RolesAllowed Specifies which roles are allowed to access a method.
@WithMockUser Simulates a user for testing security.

Testing Annotations

Annotation Purpose/Use Case
@SpringBootTest Runs integration tests for a Spring Boot application. Loads the full application context.
@WebMvcTest Tests only web layer components (e.g., controllers).
@DataJpaTest Tests only JPA repositories. Configures an in-memory database.
@MockBean Replaces a bean with a mock during tests.
@SpyBean Replaces a bean with a spy during tests.
@TestConfiguration Provides additional bean configurations for tests.
@BeforeEach Runs before each test method in a test class.
@AfterEach Runs after each test method in a test class.

Profiles Annotations

Annotation Purpose/Use Case
@ConfigurationProperties Binds external configuration properties to a Java bean.
@EnableConfigurationProperties Enables support for @ConfigurationProperties beans.
@Profile Specifies the profile under which a bean is active (e.g., dev, prod).
@Value Injects a value from the properties or environment.
@PropertySource Loads properties from an external file.
@Environment Provides access to the current environment settings.

Actuator & Metrics Annotations

Annotation Purpose/Use Case
@Endpoint Defines a custom Actuator endpoint.
@ReadOperation Marks a method as a read operation for an Actuator endpoint.
@WriteOperation Marks a method as a write operation for an Actuator endpoint.
@DeleteOperation Marks a method as a delete operation for an Actuator endpoint.
@Timed Measures the execution time of a method.
@Gauge Exposes a gauge metric to Actuator.
@Metered Marks a method to be counted as a metric (deprecated in favor of @Timed).

Microservices Annotations

Annotation Purpose/Use Case
@EnableDiscoveryClient Enables service registration with Eureka, Consul, or Zookeeper.
@EnableFeignClients Enables Feign clients for inter-service communication.
@CircuitBreaker Implements circuit-breaking logic using Resilience4j.
@Retryable Enables retry logic for a method.
@LoadBalanced Enables load balancing for REST clients.

Miscellaneous Annotations

Annotation Purpose/Use Case
@Conditional Conditionally registers a bean based on custom logic.
@Async Marks a method to run asynchronously.
@Scheduled Schedules a method to run at fixed intervals or cron expressions.
@EventListener Marks a method to listen for application events.
@Cacheable Caches the result of a method.
@CacheEvict Evicts entries from a cache.

Summary

This is a comprehensive list of all major Spring Boot annotations, categorized by their functionality. With these annotations, Spring Boot makes it easier to develop applications by reducing boilerplate code, automating configuration, and offering powerful tools for testing, security, and microservices development.