Spring Boot 2.0 配置屬性自定義轉換的方法
引言
當我們通過@ConfigurationProperties注解實現(xiàn)配置 bean的時候,如果默認的配置屬性轉換無法滿足我們的需求的時候,我們可以根據(jù)自己的需求通過以下擴展方式對配置屬性進行轉換
PropertyEditorSupport實現(xiàn)
下面的例子是把屬性中定義的字符串轉換成Movie,并且把name的值大寫
繼承PropertyEditorSupport并且實現(xiàn)PropertyEditorRegistrar接口
package com.paderlol.spring.practice.properties.editor;
import com.paderlol.spring.practice.properties.pojo.Movie;
import java.beans.PropertyEditorSupport;
import lombok.extern.slf4j.Slf4j;
import org.springframework.beans.PropertyEditorRegistrar;
import org.springframework.beans.PropertyEditorRegistry;
/**
* @author pader PropertyEditor 在不同的包下面
*/
@Slf4j
public class CustomMovieEditor extends PropertyEditorSupport
implements PropertyEditorRegistrar {
@Override
public String getAsText() {
Movie movie = (Movie) getValue();
return movie == null ? "" : movie.getName();
}
@Override
public void setAsText(String text) throws IllegalArgumentException {
log.info("繼承[PropertyEditorSupport]類,轉換數(shù)據(jù)={}", text);
String[] data = text.split("-");
Movie movie = Movie.builder().name(data[0]
.toUpperCase()).seat(Integer.parseInt(data[1]))
.build();
setValue(movie);
}
@Override
public void registerCustomEditors(PropertyEditorRegistry registry) {
registry.registerCustomEditor(Movie.class,this);
}
}
注冊自定義的PropertyEditor
@Bean
public CustomEditorConfigurer customEditorConfigurer() {
CustomEditorConfigurer customEditorConfigurer = new CustomEditorConfigurer();
// 有兩種注冊方式 這是第一種
customEditorConfigurer.setPropertyEditorRegistrars(
new PropertyEditorRegistrar[]{ new CustomMovieEditor() });
// 第二 種
Map<Class<?>,Class<? extends PropertyEditor>> maps = new HashMap<>();
maps.put(Movie.class,CustomMovieEditor.class);
return customEditorConfigurer;
}
Converter接口+@ConfigurationPropertiesBinding注解
//注意
@Component
@ConfigurationPropertiesBinding
public class StringToPersonConverter implements Converter<String, Person> {
@Override
public Person convert(String from) {
log.info("使用[Converter]接口,轉換數(shù)據(jù)={}", from);
String[] data = from.split(",");
return Person.builder().name(data[0]).age(Integer.parseInt(data[1])).build();
}
}
總結
- 以上兩種實現(xiàn)方式結果,但是Converter接口相比PropertyEditor接口更加靈活一些,PropertyEditor接口僅限于String轉換,Converter可以自定義別的,并且PropertyEditor接口通常用于Controller中的接收參數(shù)的轉換。
- @ConfigurationPropertiesBinding是限定符注解@Qualifier的派生類而已,參考org.springframework.boot.context.properties.ConversionServiceDeducer,以下是源代碼片段
@Autowired(required = false)
@ConfigurationPropertiesBinding
public void setConverters(List<Converter<?, ?>> converters) {
this.converters = converters;
}
/**
* A list of custom converters (in addition to the defaults) to use when
* converting properties for binding.
* @param converters the converters to set
*/
@Autowired(required = false)
@ConfigurationPropertiesBinding
public void setGenericConverters(List<GenericConverter> converters) {
this.genericConverters = converters;
}
- Formatter接口是不能對屬性完成轉換的,因為ConversionServiceDeducer初始化的時候只獲取GenericConverter和Converter接口
- 官方文檔上還介紹了可以使用實現(xiàn)org.springframework.core.convert.ConversionService并且Bean名稱也必須叫conversionService,不過大部分情況不推薦自己通過這種方式去實現(xiàn)這個接口,因為自己實現(xiàn)的ConversionService會替代默認的。具體參考ConversionServiceDeducer源碼:
public ConversionService getConversionService() {
try {
//默認首先尋找Bean名稱叫conversionService的ConversionService的Bean類
return this.applicationContext.getBean(
ConfigurableApplicationContext.CONVERSION_SERVICE_BEAN_NAME,
ConversionService.class);
}
catch (NoSuchBeanDefinitionException ex) {
//找不到就默認生成ApplicationConversionService類
return this.applicationContext.getAutowireCapableBeanFactory()
.createBean(Factory.class).create();
}
}
以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持腳本之家。
相關文章
Spring事件發(fā)布監(jiān)聽,順序監(jiān)聽,異步監(jiān)聽方式
這篇文章主要介紹了Spring事件發(fā)布監(jiān)聽,順序監(jiān)聽,異步監(jiān)聽方式,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2021-12-12
SpringBoot項目啟動時增加自定義Banner的簡單方法
最近看到springboot可以自定義啟動時的banner,然后自己試了一下,下面這篇文章主要給大家介紹了SpringBoot項目啟動時增加自定義Banner的簡單方法,需要的朋友可以參考下2022-01-01

