自定义属性

@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使用(二)的更多相关文章

  1. 玩转spring boot——properties配置

    前言 在以往的java开发中,程序员最怕大量的配置,是因为配置一多就不好统一管理,经常出现找不到配置的情况.而项目中,从开发测试环境到生产环境,往往需要切换不同的配置,如测试数据库连接换成生产数据库连 ...

  2. spring boot高性能实现二维码扫码登录(上)——单服务器版

    前言 目前网页的主流登录方式是通过手机扫码二维码登录.我看了网上很多关于扫码登录博客后,发现基本思路大致是:打开网页,生成uuid,然后长连接请求后端并等待登录认证相应结果,而后端每个几百毫秒会循环查 ...

  3. spring boot高性能实现二维码扫码登录(中)——Redis版

    前言 本打算用CountDownLatch来实现,但有个问题我没有考虑,就是当用户APP没有扫二维码的时候,线程会阻塞5分钟,这反而造成性能的下降.好吧,现在回归传统方式:前端ajax每隔1秒或2秒发 ...

  4. spring boot高性能实现二维码扫码登录(下)——订阅与发布机制版

     前言 基于之前两篇(<spring boot高性能实现二维码扫码登录(上)——单服务器版>和<spring boot高性能实现二维码扫码登录(中)——Redis版>)的基础, ...

  5. Spring Boot 启动(二) 配置详解

    Spring Boot 启动(二) 配置详解 Spring 系列目录(https://www.cnblogs.com/binarylei/p/10198698.html) Spring Boot 配置 ...

  6. Spring Boot学习记录(二)--thymeleaf模板 - CSDN博客

    ==他的博客应该不错,没有细看 Spring Boot学习记录(二)--thymeleaf模板 - CSDN博客 http://blog.csdn.net/u012706811/article/det ...

  7. Spring Boot 启动(二) Environment 加载

    Spring Boot 启动(二) Environment 加载 Spring 系列目录(https://www.cnblogs.com/binarylei/p/10198698.html) 上一节中 ...

  8. Spring Boot REST(二)源码分析

    Spring Boot REST(二)源码分析 Spring 系列目录(https://www.cnblogs.com/binarylei/p/10117436.html) SpringBoot RE ...

  9. Spring Boot 2.X(二):集成 MyBatis 数据层开发

    MyBatis 简介 概述 MyBatis 是一款优秀的持久层框架,支持定制化 SQL.存储过程以及高级映射.它采用面向对象编程的方式对数据库进行 CRUD 的操作,使程序中对关系数据库的操作更方便简 ...

  10. spring boot / cloud (十二) 异常统一处理进阶

    spring boot / cloud (十二) 异常统一处理进阶 前言 在spring boot / cloud (二) 规范响应格式以及统一异常处理这篇博客中已经提到了使用@ExceptionHa ...

随机推荐

  1. Django网站管理--ModelAdmin

    class AuthorAdmin(admin.ModelAdmin): list_display=('name', 'age', 'sex') #指定要显示的字段 search_fields=('n ...

  2. luogu2278 [HNOI2003]操作系统

    题目大意 写一个程序来模拟操作系统的进程调度.假设该系统只有一个CPU,每一个进程的到达时间,执行时间和运行优先级都是已知的.其中运行优先级用自然数表示,数字越大,则优先级越高.如果一个进程到达的时候 ...

  3. Detach a Database

    https://msdn.microsoft.com/en-us/library/ms191491.aspx 方法一:Using SQL Server Management Studio To det ...

  4. local_response_normalization 和 batch_normalization

    Normalization   Normalization local_response_normalization local_response_normalization出现在论文”ImageNe ...

  5. 洛谷P2593 [ ZJOI 2006 ] 超级麻将 —— DP

    题目:https://www.luogu.org/problemnew/show/P2593 DP的话,考虑到当前这一位只跟前两位有关,所以记录一下这3位的状态就行: 于是一开始记录的第 i 位,i- ...

  6. 93.EXTJS Form之VTypes

    转自:http://blog.sina.com.cn/s/blog_7778950d0100y2pg.html 本文我们主要探讨一下EXTJS的Form中验证的问题,可能用过EXTJS的Form的人都 ...

  7. 《疯狂Python讲义》重要笔记——Python简介

    简介 Python是一种面向对象.解释型.弱类型的脚本语言,同时也是一种功能强大的通过语言,它提供了高效的高级数据结构,还有简单有效的面向对象编程. 在大数据.人工智能(AI)领域应用广泛,因此变得流 ...

  8. sql--Truncate Table

    Truncate Table(截断表) 有时候需要清除一个表中的所有资料.要达到者个目的,一种方式是DROP TABLE 指令.不过这样整个表格就消失,而无法再被用了. 另一种方式是Delete不带w ...

  9. CORS 和 JSONP

    跨域资源共享(CORS) 它允许浏览器向跨源服务器,发出XMLHttpRequest请求,从而克服了AJAX只能同源使用的限制. CORS(Cross-Origin Resource Sharing) ...

  10. 联想笋尖S90(S90-t 、S90-u)解锁BootLoader

    工具下载链接: http://pan.baidu.com/s/1eSgZuka 备用下载链接: http://pan.baidu.com/s/1dFKqSId 本篇教程,仅限于联想笋尖S90(S90- ...