When configuring a CacheManager in Spring Boot, the _____ property can be used to set the TTL values for cache entries.
- cacheExpiry
- evictionTimeout
- expireAfterWrite
- timeToLive
When configuring a CacheManager in Spring Boot, the expireAfterWrite property can be used to set the time-to-live (TTL) values for cache entries. This property determines how long cache entries remain valid before they are considered expired and potentially removed from the cache. It's essential for controlling cache behavior.
In a Spring Boot application, the HTTP request body can be deserialized using the _____ annotation.
- @PathVariable
- @RequestBody
- @RequestParam
- @ResponseBody
In Spring Boot, the @RequestBody annotation is used to deserialize the HTTP request body into a Java object. This is particularly useful when dealing with POST or PUT requests where data is sent in the request body. The other annotations are used for different purposes, such as specifying response bodies, request parameters, or path variables.
Imagine you are creating a configuration class in Spring Boot that should only be processed if a certain bean is present in the ApplicationContext. How would you accomplish this?
- Create a custom condition class implementing the Condition interface and specify the condition in the configuration class using @Conditional.
- This behavior is not possible in Spring Boot; configuration classes are always processed regardless of the bean's presence.
- Use the @ConditionalOnBean annotation on the configuration class and specify the required bean's class.
- Use the @RequiresBean annotation and specify the required bean's name in the configuration class.
To conditionally process a configuration class based on the presence of a certain bean, you can use the @ConditionalOnBean annotation. This annotation ensures that the configuration class is only processed if the specified bean is present in the ApplicationContext. It's a powerful way to control the activation of configuration based on runtime conditions.
In Spring Boot, which annotation is used to conditionally enable caching only when a certain property is set?
- @Cacheable
- @ConditionalCache
- @ConditionalOnProperty("spring.cache.enabled")
- @EnableCaching
In Spring Boot, you can conditionally enable caching by using the @ConditionalOnProperty annotation with the property name as "spring.cache.enabled." This annotation allows caching to be enabled only when the specified property is set to true. The other annotations do not provide conditional caching based on a property.
To simulate HTTP requests and responses in integration tests, Spring Boot provides the _____ class, allowing for testing of controller methods without starting the server.
- MockMVC
- MockMvc
- TestRestTemplate
- WebMvcConfigurer
Spring Boot provides the MockMvc class, which allows you to simulate HTTP requests and responses for testing controller methods without the need to start a server. It's a crucial tool for integration testing in Spring Boot.
Which of the following annotations is used to handle exceptions globally across the whole application in Spring Boot?
- @ControllerAdvice
- @ExceptionHandler
- @ResponseBodyAdvice
- @GlobalExceptionHandler
The correct annotation to handle exceptions globally across the entire Spring Boot application is @ControllerAdvice. This annotation allows you to define global exception handlers that can be applied to multiple controllers. It's a powerful tool for managing exceptions consistently throughout your application. The other options are not used for this purpose.
What is the primary role of the UserDetailsService in Spring Security?
- Authenticating users based on their roles.
- Loading user details from a data store.
- Encrypting user passwords.
- Handling access control policies.
The primary role of the UserDetailsService in Spring Security is to load user details (including username, password, and roles) from a data store, typically a database. It's a fundamental component used for authentication and authorization, as it provides the necessary user information for the security framework to make access control decisions. The other options describe tasks related to authentication and authorization but are not the primary role of UserDetailsService.
What is the main responsibility of an OAuth2 Authorization Server in a Spring Boot application?
- Authenticating users and granting access tokens.
- Controlling database access.
- Managing user profiles and preferences.
- Storing user passwords and credentials.
The primary responsibility of an OAuth2 Authorization Server in a Spring Boot application is to authenticate users and grant access tokens to authorized clients. It does not store user passwords but rather validates user credentials and authorizes access to protected resources. It also does not manage user profiles and preferences, nor does it control database access; these are typically the tasks of the application's authentication system and database itself.
To optimize the performance of Spring Data JPA when dealing with large datasets, using _____ is recommended to read the datasets in chunks.
- @ChunkedData
- @OptimizePerformance
- JpaRepository
- PagingAndSortingRepository
To optimize the performance of Spring Data JPA when dealing with large datasets, using PagingAndSortingRepository is recommended to read the datasets in chunks. This repository interface extends CrudRepository and provides methods for pagination and sorting, making it suitable for efficiently fetching and processing large datasets by breaking them into manageable chunks.
How can you customize the access-denied behavior in Spring Security for methods secured with annotations?
- Access-denied behavior is not customizable in Spring Security.
- By implementing a custom AccessDeniedHandler and registering it with Spring Security.
- By modifying the application.yml file.
- By using the @AccessDeniedHandler annotation on methods that need custom access-denied handling.
To customize access-denied behavior, you should implement a custom AccessDeniedHandler, which allows you to define how to handle access-denied situations. You then register this handler with Spring Security to apply it to secured methods.