Spring Boot-properties使用(二)
自定义属性
@value注入
在application.properties新增配置
student.name=小明
student.age=12
student.info=${student.name}${student.age}
package com.liqiang.contorller; import org.springframework.beans.factory.annotation.Value;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RestController; @RestController
public class HelloWordContorller {
@Value("${student.name}")
private String name;
@Value("${student.age}")
private int age; @Value("${student.info}")
private String info;
@RequestMapping("/helloword")
public String helloWord(){
return "姓名:"+name+",年龄:"+age+" 全部信息:"+info;
}
}
如果输出乱码

在properties加上
#返回页面、数据中文乱码问题
spring.http.encoding.force=true
spring.http.encoding.charset=UTF-8
spring.http.encoding.enabled=true
server.tomcat.uri-encoding = UTF-8
#解决程序读配置文件乱码问题
spring.message.encodiang = UTF-8
student.name=小明
student.age=12
student.info=${student.name}${student.age}
如果加上之后还是乱码 修改idea文件编码格式


java bean形式注入
需要引入依赖
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-configuration-processor</artifactId>
<optional>true</optional>
</dependency>
如果自定义属性很多 10几个字段 需要一个一个注入太麻烦了,可以使用java bean的形式
@Component
@ConfigurationProperties(prefix = "student")//会找配置文件student前缀 后缀为属性名
public class StudentConfig { private String name;
private int age; public String getName() {
return name;
} public void setName(String name) {
this.name = name;
} public int getAge() {
return age;
} public void setAge(int age) {
this.age = age;
}
}
@RestController
public class HelloWordContorller {
@Autowired
private StudentConfig studentConfig; @RequestMapping("/helloword")
public String helloWord(){
return "姓名:"+studentConfig.getName()+",年龄:"+studentConfig.getAge();
}
}
所有配置都配置在appliction.properties 显得太乱了。
我们可以新建studentConfig.properties
然后指定加载的文件
@Component
@ConfigurationProperties(prefix = "student")
@PropertySource("classpath:studentconfig.properties")
public class StudentConfig
内置Random配置
${random.value}
${random.int}
${random.long}
${random.uuid}
${random.int(10)}
${random.int[1024,65536]}
多环境配置
properties形式
比如正式环境 测试环境 开发环境 不同环境的 数据库不一样 redis mq等不一样 当我们开发时使用开发环境 测试使用测试环境
如
application-dev.properties 开发(配置了 开发数据库 mq redis等信息)
application-online.properties 线上(配置了 线上数据库 mq redis等信息)
application-test-propertie 测试环境(配置了测试数据库 mq redis等信息)
在appliction.properties使用spring.profiles.active切换对应的环境
如需要使用开发环境
spring.profiles.active=dev
发布到线上
spring.profiles.active=online
也可用通过
spring.profiles.include=datasource,prodmq 来进行不同配置的叠加
javaconfig形式
比如模拟正式与开发的数据源切换
1.创建一个数据源接口
public interface DataSource {
public String getConnection();
}
2.oracle数据源实现类
public class OracleDataSource implements DataSource {
@Override
public String getConnection() {
return "oracle数据源";
}
}
3.创建mysql数据源
public class MysqlDataSource implements DataSource {
@Override
public String getConnection() {
return "mysql数据源";
}
}
4.创建DataSourceConfig
@Configuration
public class DataSourceConfig {
@Bean
@Profile("online")
public DataSource createMysqlDataSource(){
return new MysqlDataSource();
}
@Bean
@Profile("dev")
public DataSource createOracleDataSource(){
return new OracleDataSource();
}
}
5.contorller
@RestController
public class HelloWordContorller {
@Autowired
private DataSource dataSource; @RequestMapping("/helloword")
public String helloWord(){
return dataSource.getConnection();
}
}
当我们配置
spring.profiles.active=dev
页面输出

改成
spring.profiles.active=online
页面输出

我们这里只是模拟并不是真正的创建数据源。
注意:不要认为这个功能是springboot提供的。而是spring提供的
spring提供几种装配模式
一种是xml形式 就是我们以前传统用的 配置数据源
<bean id="dataSource" class="com.alibaba.druid.pool.DruidDataSource"
destroy-method="close">
<property name="driverClassName" value="com.mysql.jdbc.Driver" />
<property name="url" value="${url}" />
<property name="username" value="${username}" />
<property name="password" value="${password}" />
<property name="initialSize" value="5" />
</bean>
通过配置spring扫描到xml会根据配置内容初始化com.alibaba.druid.pool.DruidDataSource类的对象 装载到容器里面
还有就是javaconfig模式(也是springboot推荐的)
@Configuration
public class DataSourceConfig {
@Beanpublic DataSource createMysqlDataSource(){
DruidDataSource druidDataSource=new DruidDataSource();
druidDataSource.setUrl("");
druidDataSource.setUsername("");
druidDataSource.setPassword("");
return druidDataSource;
}
}
spring 会扫描包下面打了Configuration的类 调用打上了@Bean的方法 将返回值注入容器
@Profile("dev")注解也是spring提供。根据不同的环境初始化对应的@Bean的方法 实现不同环境配置的切换
Spring Boot-properties使用(二)的更多相关文章
- 玩转spring boot——properties配置
前言 在以往的java开发中,程序员最怕大量的配置,是因为配置一多就不好统一管理,经常出现找不到配置的情况.而项目中,从开发测试环境到生产环境,往往需要切换不同的配置,如测试数据库连接换成生产数据库连 ...
- spring boot高性能实现二维码扫码登录(上)——单服务器版
前言 目前网页的主流登录方式是通过手机扫码二维码登录.我看了网上很多关于扫码登录博客后,发现基本思路大致是:打开网页,生成uuid,然后长连接请求后端并等待登录认证相应结果,而后端每个几百毫秒会循环查 ...
- spring boot高性能实现二维码扫码登录(中)——Redis版
前言 本打算用CountDownLatch来实现,但有个问题我没有考虑,就是当用户APP没有扫二维码的时候,线程会阻塞5分钟,这反而造成性能的下降.好吧,现在回归传统方式:前端ajax每隔1秒或2秒发 ...
- spring boot高性能实现二维码扫码登录(下)——订阅与发布机制版
前言 基于之前两篇(<spring boot高性能实现二维码扫码登录(上)——单服务器版>和<spring boot高性能实现二维码扫码登录(中)——Redis版>)的基础, ...
- Spring Boot 启动(二) 配置详解
Spring Boot 启动(二) 配置详解 Spring 系列目录(https://www.cnblogs.com/binarylei/p/10198698.html) Spring Boot 配置 ...
- Spring Boot学习记录(二)--thymeleaf模板 - CSDN博客
==他的博客应该不错,没有细看 Spring Boot学习记录(二)--thymeleaf模板 - CSDN博客 http://blog.csdn.net/u012706811/article/det ...
- Spring Boot 启动(二) Environment 加载
Spring Boot 启动(二) Environment 加载 Spring 系列目录(https://www.cnblogs.com/binarylei/p/10198698.html) 上一节中 ...
- Spring Boot REST(二)源码分析
Spring Boot REST(二)源码分析 Spring 系列目录(https://www.cnblogs.com/binarylei/p/10117436.html) SpringBoot RE ...
- Spring Boot 2.X(二):集成 MyBatis 数据层开发
MyBatis 简介 概述 MyBatis 是一款优秀的持久层框架,支持定制化 SQL.存储过程以及高级映射.它采用面向对象编程的方式对数据库进行 CRUD 的操作,使程序中对关系数据库的操作更方便简 ...
- spring boot / cloud (十二) 异常统一处理进阶
spring boot / cloud (十二) 异常统一处理进阶 前言 在spring boot / cloud (二) 规范响应格式以及统一异常处理这篇博客中已经提到了使用@ExceptionHa ...
随机推荐
- BZOJ 1787: [Ahoi2008]Meet 紧急集合 LCA
1787: [Ahoi2008]Meet 紧急集合 Description Input Output Sample Input 6 4 1 2 2 3 2 4 4 5 5 6 4 5 6 6 3 1 ...
- 更改printk打印级别【转】
本文转载自:http://blog.csdn.net/weed_hz/article/details/8949140 1.查看当前控制台的打印级别 cat /proc/sys/kernel/print ...
- 深入浅出时序数据库之预处理篇——批处理和流处理,用户可定制,但目前流行influxdb没有做
时序数据是一个写多读少的场景,对时序数据库以及数据存储方面做了论述,数据查询和聚合运算同样是时序数据库必不可少的功能之一.如何支持在秒级对上亿数据的查询分组聚合运算成为了时序数据库产品必须要面对的挑战 ...
- 0420-mysql命令(数据库操作层级,建表,对表的操作)
注意事项: 符号必须为英文. 数据库操作层级: 建表大全: #新建表zuoye1:drop table if exists zuoye1;create table zuoye1( id int ...
- centos vi和vim用法
所有的 Unix Like 系统都会内建 vi 文书编辑器,其他的文书编辑器则不一定会存在. 但是目前我们使用比较多的是 vim 编辑器. vim 具有程序编辑的能力,可以主动的以字体颜色辨别语法的正 ...
- POJ 3253 STL优先队列
题目大意:FJ需要修补牧场的围栏,他需要 N 块长度为 Li 的木头(N planks of woods).开始时,FJ只有一块无限长的木板,因此他需要把无限长的木板锯成 N 块长度 为 Li 的木板 ...
- # secure_link_module模块
作用 制定并允许检查请求的链接的真实性以及保护资源免遭未经授权的访问 限制链接生效周期 首先检查nginx是否已安装模块 #nginx -V 输出nginx所有已安装模块,检查是否有ngx_http_ ...
- MemcachedClient 使用说明
上一篇介绍了Memcached基本使用方法<Memcached使用手册>,下面介绍java如何操作memcached.使用的是java_memcached-release_2.6.6. 一 ...
- word中选择嵌入式时图片被遮住,只显示小部分的解决方法
选中图片,点击如下 选择 行距选项 将行距改为单位行距即可.
- 菜鸟使用 centOS 安装 redis 并放入service 启动 记录
1.下载redis: wget http://download.redis.io/releases/redis-2.8.17.tar.gz 若wget 不可用,请先安装wget yum install ...