Giriş
Şu satırı dahil ederiz.
Bu anotasyonun çalışması için eski SpringBoot ile @EnableConfigurationProperties tanımlı olmalıydı çünkü Spring class path scanning yaparken bu anotasyonu tanımıyordu. Yeni SpringBoot için açıklama şöyle. Yani artık @EnableConfigurationProperties anotasyonunu kullanmaya gerek yok.
Bu anotasyon normalde application.properties dosyasını okur. Eğer okunacak dosyayı belirtmek istersek @PropertySource kullanılabilir. Test yazıyorsak @TestPropertySource kullanılabilir.
@ConstructorBinding İle İlgisi
Şu satırı dahil ederiz.
import org.springframework.boot.context.properties.ConfigurationProperties;
@EnableConfigurationProperties İle İlgisiBu anotasyonun çalışması için eski SpringBoot ile @EnableConfigurationProperties tanımlı olmalıydı çünkü Spring class path scanning yaparken bu anotasyonu tanımıyordu. Yeni SpringBoot için açıklama şöyle. Yani artık @EnableConfigurationProperties anotasyonunu kullanmaya gerek yok.
As, of Spring Boot 2.2, Spring finds and registers @ConfigurationProperties classes via classpath scanning. Therefore, there is no need to annotate such classes with @Component (and other meta-annotations like @Configuration) or even use the @EnableConfigurationProperties@PropertySource İle İlgisi
Bu anotasyon normalde application.properties dosyasını okur. Eğer okunacak dosyayı belirtmek istersek @PropertySource kullanılabilir. Test yazıyorsak @TestPropertySource kullanılabilir.
@ConstructorBinding İle İlgisi
Bu anotasyon normalde kendi içindeki field'ları direkt doldurur. Eğer nesnemizin constructor metodunu kullanarak doldurmak istersek, bu anotasyonla birlikte @ConstructorBinding kullanılır
POJO okuma örneklerini @ConfigurationProperties Anotasyonu POJO Okuma yazısına taşıdım.
Neden Lazım
Açıklaması şöyle.
- Bu anotasyonu kullanırsak her alanı @Value olarak işaretlemeye gerek kalmaz.Using the @Value("${property}") annotation to inject configuration properties can sometimes be cumbersome, especially if you are working with multiple properties or your data is hierarchical in nature. Spring Boot provides an alternative method of working with properties that lets strongly typed beans govern and validate the configuration of your application
- Bu anotasyon ile işaretli sınıfın içinde başka bean'ler varsa @Configuration olarak ta işaretlenir.
locations Alanı
Bu alan artık yok. Eskiden şöyleydi.
@EnableConfigurationProperties
@SpringBootApplication
@ConfigurationProperties(locations = {"wtf.yml"}) //classpath:wtf.yml
public class SomeApp {
public static void main(final String[] args) {
SpringApplication.run(SomeApp.class, args);
}
@Value("${readTimeout}")
public int readTimeout;
}
prefix AlanıÜye alan ismiyle application.properties içindeki alan aynı olmalı.
Örnek - Basit string okuma
Elimizde şöyle bir kod olsun.
@ConfigurationProperties(prefix = "server")
public class ApplicationConfiguration {
private String port;
public String getPort() {
return port;
}
public void setPort(String port) {
this.port = port;
}
}
application.properties şöyle olsun.server.port = 8085
Şöyle yaparız.@Controller
public class TestController {
@Autowired
ApplicationConfiguration applicationConfiguration;
...
}
Örnek - Basit string okumaŞöyle yaparız.
@Configuration
@ConfigurationProperties(prefix = "animal")
public class Animal {
private Cat cat;
public Cat getCat() {
return cat;
}
public static class Cat {
@Value("${leg}")
private String leg;
public String getLeg() {
return leg;
}
}
}
Örnek - Map Okumaapplication.properties şöyle olsun
movies.names.M1001=SpiderMan
movies.names.M1002=Thor
movies.names.M1003=Logan
movies.names.M1004=Conjuring2
movies.names.M1005=StarWars
Şöyle yaparız.@EnableConfigurationProperties
@PropertySource(value ="application.properties")
@ConfigurationProperties(prefix="movies")
public class MovieCollections {
private Map<String, String> names;
...
}
value Alanı
prefix ile aynıdırÖrnek
Şöyle yaparız.
@ConfigurationProperties("threadPools")
internal class ThreadPoolsProperties {
...
}
Hiç yorum yok:
Yorum Gönder