【Spring Boot】024-使用配置文件内属性值的三种方式
一、@Value 注解
参考文章
【Spring Boot】004-给属性赋值的几种方式
https://blog.csdn.net/qq_29689343/article/details/108547843
【Spring】006-Spring注解开发
https://blog.csdn.net/qq_29689343/article/details/108396899
二、松散绑定
参考文章
【Spring Boot】004-给属性赋值的几种方式
https://blog.csdn.net/qq_29689343/article/details/108547843
【Spring Boot】005-yaml松散绑定和JSR303数据校验
https://blog.csdn.net/qq_29689343/article/details/108548160
三、使用 EnvironmentAware 接口
1、前言
凡注册到 Spring容器内 的bean,实现了 EnvironmentAware
接口重写 setEnvironment
方法后,在工程启动时可以获得application.properties
的 配置文件 配置的属性值。
2、代码演示
application.properties 配置文件
zibo.name=訾博
EnvironmentAwareImpl 类
实现 EnvironmentAware 接口,重写 setEnvironment 方法
package com.zibo.api.study;
import org.springframework.context.EnvironmentAware;
import org.springframework.context.annotation.Configuration;
import org.springframework.core.env.Environment;
@Configuration
public class EnvironmentAwareImpl implements EnvironmentAware {
@Override
public void setEnvironment(Environment environment) {
String ziboName = environment.getProperty("zibo.name");
System.out.println("ziboName is " + ziboName);
}
}
3、启动项目
4、解决中文乱码问题
说明
此问题网上的解决方案很多,都没有什么用!我把中文改成英文之后运行,就能正常显示出英文!再把英文改成中文之后运行,中文也能正常显示了!真是奇哉怪也!
运行结果
5、具体应用
MySQL数据源配置
datasource.driverClassName=com.mysql.cj.jdbc.Driver
datasource.url=jdbc:mysql://XXX:3306/api?useUnicode=true&characterEncoding=utf8&useSSL=false&useLegacyDatetimeCode=false&serverTimezone=Asia/Shanghai
datasource.username=root
datasource.password=123456
配置类代码示例
下面代码摘取自https://blog.csdn.net/bazhuayu_1203/article/details/78658196,未真正演示,仅作参考!
@Configuration
public class MyBatisConfig implements EnvironmentAware {
private Environment environment;
@Override
public void setEnvironment(Environment environment) {
this.environment = environment;
}
/**
* 创建数据源(数据源的名称:方法名可以取为XXXDataSource(),XXX为数据库名称,该名称也就是数据源的名称)
*/
@Bean
public DataSource druidDataSource() throws Exception {
Properties props = new Properties();
props.put("driverClassName", environment.getProperty("datasource.driverClassName"));
props.put("url", environment.getProperty("datasource.url"));
props.put("username", environment.getProperty("datasource.username"));
props.put("password", environment.getProperty("datasource.password"));
return DruidDataSourceFactory.createDataSource(props);
}
/**
* 根据数据源创建SqlSessionFactory
*/
@Bean
public SqlSessionFactory sqlSessionFactory() throws Exception {
PathMatchingResourcePatternResolver resolver = new PathMatchingResourcePatternResolver();
SqlSessionFactoryBean fb = new SqlSessionFactoryBean();
// 指定数据源(这个必须有,否则报错)
fb.setDataSource(druidDataSource());
fb.setTypeAliasesPackage("com.tf56.pushService.dal.domain");
// 指定mapper文件 fb.setMapperLocations(resolver.getResources("classpath:mapper/*.xml"));
return fb.getObject();
}
}
四、其他
参考文章:
https://blog.csdn.net/wuchen_net/article/details/108783778