色综合图-色综合图片-色综合图片二区150p-色综合图区-玖玖国产精品视频-玖玖香蕉视频

您的位置:首頁技術(shù)文章
文章詳情頁

詳解Spring中的@PropertySource注解使用

瀏覽:5日期:2023-12-13 15:32:02

@PropertySource注解是Spring用于加載配置文件,默認(rèn)支持.properties與.xml兩種配置文件。@PropertySource屬性如下:

name:默認(rèn)為空,不指定Spring自動生成 value:配置文件 ignoreResourceNotFound:沒有找到配置文件是否忽略,默認(rèn)false,4.0版本加入 encoding:配置文件編碼格式,默認(rèn)UTF-8 4.3版本才加入 factory:配置文件解析工廠,默認(rèn):PropertySourceFactory.class 4.3版本才加入,如果是之前的版本就需要手動注入配置文件解析Bean

接下來就使用@PropertySource來加載.properties與.xml配置文件。這里模擬連接MySQL數(shù)據(jù)庫。首先添加依賴:

<dependency> <groupId>org.springframework</groupId> <artifactId>spring-context</artifactId> <version>5.1.6.RELEASE</version></dependency><dependency> <groupId>org.springframework</groupId> <artifactId>spring-jdbc</artifactId> <version>5.1.6.RELEASE</version></dependency><dependency> <groupId>mysql</groupId> <artifactId>mysql-connector-java</artifactId> <version>8.0.26</version></dependency><dependency> <groupId>org.projectlombok</groupId> <artifactId>lombok</artifactId> <version>1.18.20</version></dependency>

準(zhǔn)備屬性配置文件jdbc.properties

jdbc.driver=com.mysql.cj.jdbc.Driverjdbc.url=jdbc:mysql://127.0.0.1:3306jdbc.userName=rootjdbc.password=xiaohu

創(chuàng)建屬性實體類來加載配置文件JdbcProperties

@Data@Repository@PropertySource(value = 'classpath:jdbc.properties')public class JdbcProperties { @Value('${jdbc.driver}') private String driver; @Value('${jdbc.url}') private String url; @Value('${jdbc.userName}') private String userName; @Value('${jdbc.password}') private String password;}

創(chuàng)建JDBC配置類JdbcConfig

@Componentpublic class JdbcConfig { @Bean public DataSource dataSource(JdbcProperties jdbcProperties){System.out.println('打印獲取到的配置信息:'+jdbcProperties);DriverManagerDataSource dataSource = new DriverManagerDataSource();dataSource.setDriverClassName(jdbcProperties.getDriver());dataSource.setUrl(jdbcProperties.getUrl());dataSource.setUsername(jdbcProperties.getUserName());dataSource.setPassword(jdbcProperties.getPassword());return dataSource; }}

創(chuàng)建Spring配置類SpringConfiguration

@Configurationpublic class SpringConfiguration {}

創(chuàng)建測試類測試讀取配置文件

public class PropertySourceTest { public static void main(String[] args) {AnnotationConfigApplicationContext context = new AnnotationConfigApplicationContext('config');DataSource dataSource = context.getBean('dataSource',DataSource.class);System.out.println(dataSource); }}

查看輸出結(jié)果:

打印獲取到的配置信息:JdbcProperties(driver=com.mysql.cj.jdbc.Driver, url=jdbc:mysql://127.0.0.1:3306, userName=root, password=xiaohu)org.springframework.jdbc.datasource.DriverManagerDataSource@58695725

從結(jié)果可以看出,我們的properties中的配置已經(jīng)成功讀取到,并且DataSource也從Spring容器中獲取到。上面介紹注解的屬性時,factory是4.3版本才加入的,那么如果4.3版本之前要解析配置文件又應(yīng)該怎么處理呢?,這個時候就需要手動將解析配置文件的Bean注入到Spring容器中了,用法很簡單,在SpringConfiguration類中添加如下代碼即可:

@Beanpublic PropertySourcesPlaceholderConfigurer propertySourcesPlaceholderConfigurer(){ return new PropertySourcesPlaceholderConfigurer();}

具體測試結(jié)果,就自行測試了。上面例子介紹了properties的使用,下面我們將配置文件換成xml文件。配置如下:

<?xml version='1.0' encoding='utf-8' ?><!DOCTYPE properties SYSTEM 'http://java.sun.com/dtd/properties.dtd'><properties> <entry key='jdbc.driver'>com.mysql.cj.jdbc.Driver</entry> <entry key='jdbc.url'>jdbc:mysql://127.0.0.1:3306/test</entry> <entry key='jdbc.userName'>root</entry> <entry key='jdbc.password'>xiaohu</entry></properties>

然后將JdbcProperties類上的注解的配置文件換成xml文件。

@PropertySource(value = 'classpath:jdbc.properties')

其他不用調(diào)整,執(zhí)行測試類,輸出的結(jié)果一樣。因為上面介紹到@PropertySource默認(rèn)支持properties與xml的配置文件。我們可以查看PropertySourceFactory的默認(rèn)實現(xiàn)DefaultPropertySourceFactory源碼

public class DefaultPropertySourceFactory implements PropertySourceFactory {@Overridepublic PropertySource<?> createPropertySource(@Nullable String name, EncodedResource resource) throws IOException {return (name != null ? new ResourcePropertySource(name, resource) : new ResourcePropertySource(resource));}}

然后進入ResourcePropertySource類,源碼這里使用了一個三元運算符,如果name為空,就使用默認(rèn)Spring默認(rèn)生成的name。

public ResourcePropertySource(String name, EncodedResource resource) throws IOException {super(name, PropertiesLoaderUtils.loadProperties(resource));this.resourceName = getNameForResource(resource.getResource());}public ResourcePropertySource(EncodedResource resource) throws IOException {super(getNameForResource(resource.getResource()), PropertiesLoaderUtils.loadProperties(resource));this.resourceName = null;}

這里可以看到調(diào)用了PropertiesLoaderUtils.loadProperties方法,進入到源碼

public static Properties loadProperties(EncodedResource resource) throws IOException {Properties props = new Properties();fillProperties(props, resource);return props;}

會調(diào)用fillProperties的方法,一直跟到調(diào)用最低的fillProperties方法。

static void fillProperties(Properties props, EncodedResource resource, PropertiesPersister persister)throws IOException {InputStream stream = null;Reader reader = null;try {String filename = resource.getResource().getFilename();if (filename != null && filename.endsWith(XML_FILE_EXTENSION)) {stream = resource.getInputStream();persister.loadFromXml(props, stream);}else if (resource.requiresReader()) {reader = resource.getReader();persister.load(props, reader);}else {stream = resource.getInputStream();persister.load(props, stream);}}finally {if (stream != null) {stream.close();}if (reader != null) {reader.close();}}}

第一個if判斷文件后綴是否是xml結(jié)尾,常量XML_FILE_EXTENSION如下:

private static final String XML_FILE_EXTENSION = '.xml';

除了支持properties與xml的配置文件方式,也支持yml配置文件的方式,不過需要自定義解析工廠,下面來實現(xiàn)怎么解析yml配置文件。引入可以解析yml文件的第三方庫

<dependency> <groupId>org.yaml</groupId> <artifactId>snakeyaml</artifactId> <version>1.28</version></dependency>

創(chuàng)建yml解析工廠YamlPropertySourceFactory實現(xiàn)PropertySourceFactory

public class YamlPropertySourceFactory implements PropertySourceFactory { @Override public PropertySource<?> createPropertySource(String name, EncodedResource resource) throws IOException {YamlPropertiesFactoryBean factoryBean = new YamlPropertiesFactoryBean();factoryBean.setResources(resource.getResource());Properties properties = factoryBean.getObject();return name != null ? new PropertiesPropertySource(name, properties) : new PropertiesPropertySource(resource.getResource().getFilename(), properties); }}

然后將JdbcProperties類的@PropertySource換成如下寫法:

@PropertySource(value = 'classpath:jdbc.yml',factory = YamlPropertySourceFactory.class)

執(zhí)行測試類,輸出結(jié)果與上面結(jié)果一樣

打印獲取到的配置信息:JdbcProperties(driver=com.mysql.cj.jdbc.Driver, url=jdbc:mysql://127.0.0.1:3306, userName=root, password=xiaohu)org.springframework.jdbc.datasource.DriverManagerDataSource@58695725

證明我們自定義的解析yml配置文件就成功了。

到此這篇關(guān)于Spring的@PropertySource注解使用的文章就介紹到這了,更多相關(guān)Spring的@PropertySource注解使用內(nèi)容請搜索好吧啦網(wǎng)以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持好吧啦網(wǎng)!

標(biāo)簽: Spring
相關(guān)文章:
主站蜘蛛池模板: 精品视频在线视频 | 国产韩国精品一区二区三区久久 | 成人精品一区二区久久 | 一级在线 | 欧洲 | 欧美综合视频在线观看 | 久热香蕉精品视频在线播放 | 久久成年片色大黄全免费网站 | 亚洲欧美视频 | 99久久亚洲国产高清观看 | 日韩亚洲一区二区三区 | 国产亚洲网站 | 正在播放国产乱子伦视频 | 国产精品二区三区 | 国产一区二区三区四区在线 | 亚洲www色| 精品国产一区二区三区成人 | 97视频免费公开成人福利 | 9丨精品国产高清自在线看 ⅹxx中国xxx人妖 | 国产视频97 | 久久久久久一级毛片免费野外 | 国产精品爱久久久久久久 | 精品一区二区三区18 | 久久精品成人欧美大片免费 | 日韩免费一区二区三区在线 | 国产精品高清在线观看93 | 国产成人在线看 | 国产片91人成在线观看 | 精品在线视频免费观看 | 欧美一区二区精品 | 人人爽人人香蕉 | 毛片com| 成人亚洲网站 | 久久久久久久综合色一本 | 久久不见久久见免费影院 | 毛片激情永久免费 | 可以免费看黄的网址 | 99精品在线看 | 成人看的午夜免费毛片 | 久久久久久国产精品免费免费 | 欧美成人全部费免网站 | 欧美午夜在线 |