2、SpringBoot2.x配置文件講解
簡介:SpringBoot2.x常見的配置文件 xml、yml、properties的區別和使用
xml、properties、json、yaml
1、常見的配置文件 xx.yml, xx.properties,
1)YAML(Yet Another Markup Language)
寫 YAML 要比寫 XML 快得多(無需關注標簽或引號)
使用空格 Space 縮進表示分層,不同層次之間的縮進可以使用不同的空格數目
注意:key后面的冒號,后面一定要跟一個空格,樹狀結構
application.properties示例
server.port=8090
server.session-timeout=30
server.tomcat.max-threads=0
server.tomcat.uri-encoding=UTF-8
application.yml示例
server:
port: 8090
session-timeout: 30
tomcat.max-threads: 0
tomcat.uri-encoding: UTF-8
2、默認示例文件僅作為指導。 不要將整個內容復制並粘貼到您的應用程序中,只挑選您需要的屬性。
3、參考:https://docs.spring.io/spring-boot/docs/2.1.0.BUILD-SNAPSHOT/reference/htmlsingle/#common-application-properties
如果需要修改,直接復制對應的配置文件,加到application.properties里面
3、SpringBoot注解把配置文件自動映射到屬性和實體類實戰
簡介:講解使用@value注解配置文件自動映射到屬性和實體類
1、配置文件加載
方式一
1、Controller上面配置
@PropertySource({"classpath:resource.properties"})
2、增加屬性
@Value("${test.name}")
private String name;
方式二:實體類配置文件
步驟:
1、添加 @Component 注解;
2、使用 @PropertySource 注解指定配置文件位置;
3、使用 @ConfigurationProperties 注解,設置相關屬性;
4、必須 通過注入IOC對象Resource 進來 , 才能在類中使用獲取的配置文件值。
@Autowired
private ServerSettings serverSettings;
例子:
@Configuration
@ConfigurationProperties(prefix="test")
@PropertySource(value="classpath:resource.properties")
public class ServerConstant {
常見問題:
1、配置文件注入失敗,Could not resolve placeholder
解決:根據springboot啟動流程,會有自動掃描包沒有掃描到相關注解,
默認Spring框架實現會從聲明@ComponentScan所在的類的package進行掃描,來自動注入,
因此啟動類最好放在根路徑下面,或者指定掃描包范圍
spring-boot掃描啟動類對應的目錄和子目錄
2、注入bean的方式,屬性名稱和配置文件里面的key一一對應,就用加@Value 這個注解
如果不一樣,就要加@value("${XXX}")