詳解SpringMVC加載配置Properties文件的幾種方式
最近開(kāi)發(fā)的項(xiàng)目使用了SpringMVC的框架,用下來(lái)感覺(jué)SpringMVC的代碼實(shí)現(xiàn)的非常優(yōu)雅,功能也非常強(qiáng)大,
網(wǎng)上介紹Controller參數(shù)綁定、URL映射的文章都很多了,寫這篇博客主要總結(jié)一下SpringMVC加載配置Properties文件的幾種方式
1.通過(guò)context:property-placeholde實(shí)現(xiàn)配置文件加載
1.1、在spring.xml中加入context相關(guān)引用
<?xml version="1.0" encoding="UTF-8"?> <beans xmlns="http://www.springframework.org/schema/beans" xmlns:context="http://www.springframework.org/schema/context" xsi:schemaLocation="http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans-4.0.xsd http://www.springframework.org/schema/context http://www.springframework.org/schema/context/spring-context.xsd">
1.2、引入jdbc配置文件
<context:property-placeholder location="classpath:jdbc.properties"/>
1.3、jdbc.properties的配置如下
jdbc_driverClassName=com.mysql.jdbc.Driver jdbc_url=jdbc:mysql://localhost/testdb?useUnicode=true&characterEncoding=utf8 jdbc_username=root jdbc_password=123456
1.4、在spring-mybatis.xml中引用jdbc中的配置
<bean id="dataSource" class="com.alibaba.druid.pool.DruidDataSource" init-method="init"
destroy-method="close" >
<property name="driverClassName">
<value>${jdbc_driverClassName}</value>
</property>
<property name="url">
<value>${jdbc_url}</value>
</property>
<property name="username">
<value>${jdbc_username}</value>
</property>
<property name="password">
<value>${jdbc_password}</value>
</property>
<!-- 連接池最大使用連接數(shù) -->
<property name="maxActive">
<value>20</value>
</property>
<!-- 初始化連接大小 -->
<property name="initialSize">
<value>1</value>
</property>
<!-- 獲取連接最大等待時(shí)間 -->
<property name="maxWait">
<value>60000</value>
</property>
<!-- 連接池最大空閑 -->
<property name="maxIdle">
<value>20</value>
</property>
<!-- 連接池最小空閑 -->
<property name="minIdle">
<value>3</value>
</property>
<!-- 自動(dòng)清除無(wú)用連接 -->
<property name="removeAbandoned">
<value>true</value>
</property>
<!-- 清除無(wú)用連接的等待時(shí)間 -->
<property name="removeAbandonedTimeout">
<value>180</value>
</property>
<!-- 連接屬性 -->
<property name="connectionProperties">
<value>clientEncoding=UTF-8</value>
</property>
</bean>
1.5、在Java類中引用jdbc.properties中的配置
import org.springframework.beans.factory.annotation.Value;
import org.springframework.context.annotation.Configuration;
@Configuration
public class JdbcConfig{
@Value("${jdbc_url}")
public String jdbcUrl; //這里變量不能定義成static
@Value("${jdbc_username}")
public String username;
@Value("${jdbc_password}")
public String password;
}
1.6、在controller中調(diào)用
@RequestMapping("/service/**")
@Controller
public class JdbcController{
@Autowired
private JdbcConfig Config; //引用統(tǒng)一的參數(shù)配置類
@Value("${jdbc_url}")
private String jdbcUrl; //直接在Controller引用
@RequestMapping(value={"/test"})
public ModelMap test(ModelMap modelMap) {
modelMap.put("jdbcUrl", Config.jdbcUrl);
return modelMap;
}
@RequestMapping(value={"/test2"})
public ModelMap test2(ModelMap modelMap) {
modelMap.put("jdbcUrl", this.jdbcUrl);
return modelMap;
}
}
1.7、測(cè)試
在ie中輸入http://localhost:8080/testWeb/service/test 或http://localhost:8080/testWeb/service/test2
返回如下結(jié)果:
{
jdbcUrl:"jdbc:mysql://localhost/testdb?useUnicode=true&characterEncoding=utf8"
}
注:通過(guò)context:property-placeholde加載多個(gè)配置文件
只需在第1.2步中將多個(gè)配置文件以逗號(hào)分隔即可
<context:property-placeholder location="classpath:jdbc.properties,classpath:XXX.properties"/>
2、通過(guò)util:properties實(shí)現(xiàn)配置文件加載
2.1、在spring.xml中加入util相關(guān)引用
<?xml version="1.0" encoding="UTF-8"?> <beans xmlns="http://www.springframework.org/schema/beans" xmlns:context="http://www.springframework.org/schema/context" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns:util="http://www.springframework.org/schema/util" xsi:schemaLocation="http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans-4.0.xsd http://www.springframework.org/schema/context http://www.springframework.org/schema/context/spring-context.xsd http://www.springframework.org/schema/util http://www.springframework.org/schema/util/spring-util-4.0.xsd">
2.2、 引入config配置文件
<util:properties id="settings" location="classpath:config.properties"/>
2.3、config.properties的配置如下
gnss.server.url=http://127.0.0.1:8080/gnss/services/data-world/rest
2.4、在java類中引用config中的配置
import org.springframework.beans.factory.annotation.Value;
import org.springframework.stereotype.Component;
@Component
public class Config {
@Value("#{settings['gnss.server.url']}")
public String GNSS_SERVER_URL;
}
2.5、在controller中調(diào)用
@RequestMapping("/service2/**")
@Controller
public class ConfigController{
@Autowired
private Config Config; //引用統(tǒng)一的參數(shù)配置類
@RequestMapping(value={"/test"})
public ModelMap test(ModelMap modelMap) {
modelMap.put("gnss.service.url",Config.GNSS_SERVER_URL);
return modelMap;
}
}
2.6、測(cè)試
在ie中輸入http://localhost:8080/testWeb/service2/test
返回如下結(jié)果:
{
"gnss.service.url":"http://127.0.0.1:8080/gnss/services/data-world/rest"
}
3.直接在Java類中通過(guò)注解實(shí)現(xiàn)配置文件加載
3.1、在java類中引入配置文件
import org.springframework.beans.factory.annotation.Value;
import org.springframework.context.annotation.Configuration;
import org.springframework.context.annotation.PropertySource;
@Configuration
@PropertySource(value="classpath:config.properties")
public class Config {
@Value("${gnss.server.url}")
public String GNSS_SERVER_URL;
@Value("${gnss.server.url}")
public String jdbcUrl;
}
3.2、在controller中調(diào)用
@RequestMapping("/service2/**")
@Controller
public class ConfigController{
@Autowired
private Config Config; //引用統(tǒng)一的參數(shù)配置類
@RequestMapping(value={"/test"})
public ModelMap test(ModelMap modelMap) {
modelMap.put("gnss.service.url", Config.GNSS_SERVER_URL);
return modelMap;
}
}
3.3、測(cè)試
在ie中輸入http://localhost:8080/testWeb/service2/test
返回如下結(jié)果:
{
"gnss.service.url":"http://127.0.0.1:8080/gnss/services/data-world/rest"
}
最后附上spring.xml的完整配置:
<?xml version="1.0" encoding="UTF-8"?>
<beans xmlns="http://www.springframework.org/schema/beans"
xmlns:context="http://www.springframework.org/schema/context"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xmlns:util="http://www.springframework.org/schema/util"
xsi:schemaLocation="http://www.springframework.org/schema/beans
http://www.springframework.org/schema/beans/spring-beans-4.0.xsd
http://www.springframework.org/schema/context
http://www.springframework.org/schema/context/spring-context.xsd
http://www.springframework.org/schema/util
http://www.springframework.org/schema/util/spring-util-4.0.xsd">
<!-- 引入jdbc配置文件 -->
<context:property-placeholder location="classpath:jdbc.properties"/>
<!-- 引入多配置文件 -->
<context:property-placeholder location="classpath:jdbc.properties,classpath:XXX.properties"/>
<!-- 通過(guò)util引入config配置文件 -->
<!-- <util:properties id="settings" location="classpath:config.properties" /> -->
<!-- 掃描文件(自動(dòng)將servicec層注入) -->
<context:component-scan base-package="修改成你的Config類所在的package"/></beans>
以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
SpringBoot EasyPoi動(dòng)態(tài)導(dǎo)入導(dǎo)出的兩種方式實(shí)現(xiàn)方法詳解
項(xiàng)目里使用的是EasyPoi來(lái)處理導(dǎo)入導(dǎo)出功能的。近日因業(yè)務(wù)需求調(diào)整,一些導(dǎo)出功能的導(dǎo)出列需要根據(jù)不同的條件動(dòng)態(tài)導(dǎo)出2022-09-09
火遍全網(wǎng)的Hutool使用Builder模式創(chuàng)建線程池的方法
這篇文章主要介紹了火遍全網(wǎng)的Hutool使用Builder模式創(chuàng)建線程池的方法,本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2021-03-03
解決spring-integration-mqtt頻繁報(bào)Lost connection錯(cuò)誤問(wèn)題
這篇文章主要介紹了解決spring-integration-mqtt頻繁報(bào)Lost connection錯(cuò)誤問(wèn)題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2023-03-03
Springboot實(shí)現(xiàn)人臉識(shí)別與WebSocket長(zhǎng)連接的實(shí)現(xiàn)代碼
這篇文章主要介紹了Springboot實(shí)現(xiàn)人臉識(shí)別與WebSocket長(zhǎng)連接的實(shí)現(xiàn),本文通過(guò)示例代碼給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友參考下吧2023-11-11
Java使用BigDecimal解決小數(shù)計(jì)算問(wèn)題
Java中的BigDecimal是一個(gè)內(nèi)置類,用于精確表示任意大小的十進(jìn)制數(shù),它提供了一種處理浮點(diǎn)運(yùn)算精度問(wèn)題的方法,特別適合金融、貨幣交易等需要高精度計(jì)算的場(chǎng)景,本文給大家介紹了java中如何使用BigDecimal解決小數(shù)計(jì)算問(wèn)題,需要的朋友可以參考下2024-08-08
Springboot實(shí)現(xiàn)密碼的加密解密
這篇文章主要為大家詳細(xì)介紹了Springboot實(shí)現(xiàn)密碼的加密解密,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2017-11-11
Spring定時(shí)任務(wù)注解@Scheduled詳解
這篇文章主要介紹了Spring定時(shí)任務(wù)注解@Scheduled詳解,@Scheduled注解是包org.springframework.scheduling.annotation中的一個(gè)注解,主要是用來(lái)開(kāi)啟定時(shí)任務(wù),本文提供了部分實(shí)現(xiàn)代碼與思路,需要的朋友可以參考下2023-09-09

