【Spring Boot】024-使用配置文件内属性值的三种方式

【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、启动项目

image-20210816115659465

4、解决中文乱码问题

说明

此问题网上的解决方案很多,都没有什么用!我把中文改成英文之后运行,就能正常显示出英文!再把英文改成中文之后运行,中文也能正常显示了!真是奇哉怪也!

运行结果

image-20210816134342861

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

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值