回顾一下采用SSM开发项目时,项目中会存在多个配置文件,比如web.xml,配置Spring相关的applicationContext-springmvc.xml, applicationContext-dao.xml等,对于应用自身的配置,甚至还需要编写专门的代码去读取这些配置文件中的参数。在Spring Boot中,简化了Spring相关配置的管理和读取,只需要一个application.properties文件,SpringBoot提供了多种读取配置文件的方式。

配置Spring Boot

配置服务器端口号

Spring Boot默认启动端口是8080端口,可以通过在application.properties中重新配置来修改默认端口号,需要添加配置属性server.port:

server.port=8088

也可以再命令行中指定启动端口号,只需要一条命令:

java -jar xxx.jar --server.port=8088

即可将xxx.jar应用的启动端口号修改为为8088,尝试通过http://localhost:8088/demo 访问应用.

日志配置

在SpringBoot中,默认情况下不需要对日志做额外的配置已经可以使用自带的日志,Spring Boot默认使用LogBack来打印日志。

默认日志格式如上,日志每行内容格式为:

  1. 日期和时间: 格式yyyy-mm-dd hh:mm:ss.SSS

  2. 日志级别:按级别从高到低依次为: fatal,error,warn,info,debug,trace

  3. 进程id:Spring Boot应用的进程Id

  4. --- :分隔符 分隔具体的日志消息

  5. [xxx]:线程名称

  6. 类名:

  7. 消息体:

默认情况下,只要Info级别以上的日志信息才会打印到控制台,也可以自己设置日志输出级别,需要在application.properties配置文件中配置logging.level.root属性,如:

logging.level.root=trace

同样也可以通过命令中执行,开发中可通过参数—debug将日志界别调整为debug级别:

java -jar xxx.jar –debug

Spring Boot默认并没有将日志输出到文件(指定输出文件名),可以在application.properties中指定日志输出:

logging.file= log        //日志输出到应用运行的根目录下log文件中

logging.file=d:/logs/log //指定日主输入到d盘logs文件夹下log文件中

或者通过logging.path属性设置(指定输出目录)

logging.path=d:/logs     //日志输出到d盘logs文件夹下spring.log文件中(默认文件名spring.log)

logging.file和logging.path属性不能同时使用,如果同时使用,只有logging.file生效

无论采用上面那种方式记录日志文件,当日志文件到达10MB的时候,会自动重新生成一个新日志文件

SpringBoot也支持对控制台日志输出和文件输出进行格式空直,application.properties配置代码如下:

logging.pattern.console= %level %date{HH:mm:ss} %logger{20}.%M %L :%m%n
logging.pattern.file = %level %date{ISO8601} [%thread] %logger{20}.%M %L :%m%n

  1. %level :表示输出日志级别

  2. %date :表示日志产生时间,%date{ISO8601}表示标准日期格式

  3. %logger:用于输出Logger名称,包括报名+类名,{n}:限制长度

  4. %thread:当前线程

  5. %M: 产生日志所在的方法名

  6. %L:日志调用所在额代码行,(获取代码行对性能有消耗,生产环境不建议使用此参数)

  7. %m:日志消息具体类容

  8. %n:日志换行

Spring Boot支持多种日志框架,如果需要自定义日志配置,可以通过在resources目录下新建logback-spring.xml来对Logback进行更详细的配置,其他日志框架也一样。

读取应用配置

  可以在应用中读取application.properties文件中的配置,Spring Boot提供了三种方式,通过通用的Enviroment类、通过key-value方式获取到application.properties中的值、也可以通过@Value注解自动注入属性值。

通过Environment类读取

Environment是一个通用的读取应用程序运行时的环境变量的类,能够读取application.properties、命令行输入参数、系统属性、操作系统环境变量等。可以通过Spring容器自动注入。

@Autowired
private Environment env; @RequestMapping("/demo")
public String demo() {
//读取application.properties配置中端口号
System.out.print(env.getProperty("server.port",Integer.class));
return "Spring Boot Demo";
}

通过@Value注解读取

可以通过@Value注解,直接将配置信息注入到Spring管理的Bean中:

@Value("${server.port}")
private String port;

@RequestMapping("/demo2")
public String demo2() {
System.out.print("端口号:"+port);
return "Spring Boot Demo 修改";
}

@Value注解并不能在任何Spring管理的Bean中使用,因为@Value本身是通过AutowiredAnnotationBeanPostProcrssor实现的,是BeanPostPrcessor接口的实现类,因此任何BeanPostProcessor和BeanFactoryPostProcessor的子类中都不能使用@Value来注入属性,因为这个时候@Value还没有被处理。

@Value注解还支持SpEL表达式,如果属性不存在,可以赋值默认值:

@Value("${server.title:默认值}")
private String title;

通过@ConfigurationProperties注解

使用@ConfigurationProperties注解可将一些列配置属性映射到一个自定义类中,方便开发中按分类读取,比如在application.properties中添加一下配置

com.sl.name=test
com.sl.password=1111

实现步骤

1.自定义配置类

@Component
//@PropertySource(value="classpath:/application.properties") //指定绑定哪个资源文件,这里的application.properties文件是springboot默认的资源文件,是可以不用指定的,如果是自定义的资源文件,需要绑定
@ConfigurationProperties(prefix = "com.sl") //需要映射的属性浅醉
public class PropertiesConfig {
private String name;
private String password; public String getName() {
return name;
} public void setName(String name) {
this.name = name;
} public String getPassword() {
return password;
} public void setPassword(String password) {
this.password = password;
}
}

2.pomxml添加依赖项

<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-configuration-processor</artifactId>
<optional>true</optional>
</dependency>
@Autowired
private PropertiesConfig config;

@RequestMapping("/demo3")
public String demo3() {
System.out.print(config.getName());
System.out.print(config.getPassword());
return "Spring Boot Demo";
}

@ConfigurationProperties注解的类,会自动将“-”、“_”去掉,转化成java命名规范,比如讲context-path配置映射到属性contextPath上。

@ConfigurationProperties和@Value功能相似,ConfigurationProperties可以将一组属性统一管理,@Value的优是支持SpEL表达式。

Spring Boot(二)配置分析的更多相关文章

  1. Spring Boot 自动配置 源码分析

    Spring Boot 最大的特点(亮点)就是自动配置 AutoConfiguration 下面,先说一下 @EnableAutoConfiguration ,然后再看源代码,到底自动配置是怎么配置的 ...

  2. 精尽Spring Boot源码分析 - 配置加载

    该系列文章是笔者在学习 Spring Boot 过程中总结下来的,里面涉及到相关源码,可能对读者不太友好,请结合我的源码注释 Spring Boot 源码分析 GitHub 地址 进行阅读 Sprin ...

  3. Spring Boot自动配置原理与实践(二)

    前言 在之前的博文(Spring Boot自动配置原理与实践(一))中,已经介绍了Spring boot的自动配置的相关原理与概念,本篇主要是对自动配置的实践,即自定义Starter,对原理与概念加深 ...

  4. Spring Boot自动配置SpringMVC(二)

    Spring Boot自动配置SpringMVC(一) - 池塘里洗澡的鸭子 - 博客园 (cnblogs.com)讲述了关于DispatcherServlet注册到诸如tomcat容器中的自动配置过 ...

  5. Spring Boot自动配置原理与实践(一)

    前言 Spring Boot众所周知是为了简化Spring的配置,省去XML的复杂化配置(虽然Spring官方推荐也使用Java配置)采用Java+Annotation方式配置.如下几个问题是我刚开始 ...

  6. 【Spring Boot源码分析】@EnableAutoConfiguration注解(一)@AutoConfigurationImportSelector注解的处理

    Java及Spring Boot新手,首次尝试源码分析,欢迎指正! 一.概述 @EnableAutoConfiguration注解是Spring Boot中配置自动装载的总开关.本文将从@Enable ...

  7. Spring Boot源码分析-配置文件加载原理

    在Spring Boot源码分析-启动过程中我们进行了启动源码的分析,大致了解了整个Spring Boot的启动过程,具体细节这里不再赘述,感兴趣的同学可以自行阅读.今天让我们继续阅读源码,了解配置文 ...

  8. 精尽Spring Boot源码分析 - SpringApplication 启动类的启动过程

    该系列文章是笔者在学习 Spring Boot 过程中总结下来的,里面涉及到相关源码,可能对读者不太友好,请结合我的源码注释 Spring Boot 源码分析 GitHub 地址 进行阅读 Sprin ...

  9. Spring Boot自动配置SpringMVC(一)

    实际上在关于Spring Boot自动配置原理实战的文章Spring Boot自动配置实战 - 池塘里洗澡的鸭子 - 博客园 (cnblogs.com)中,可以看到我们使用到了@ReqeusMappi ...

  10. 玩转spring boot——properties配置

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

随机推荐

  1. python学习笔记(3)---cookie & session

    一.cookie & session 1.cookie: cookie 就是由服务器发送给客户端的特殊信息,而这些信息以文本的方式存放在客户端,然后客户端每次向服务器发送请求都会带上这些特殊信 ...

  2. Thinkphp5 对接百度云对象存储 BOS (上传、删除)

    首先下载SDK包可以在 官网下载,或者在项目根目录使用composer . composer require baidubce/bce-sdk-php 压缩包里面有五个文件,实际运用到只有两个,然后放 ...

  3. VUE通过索引值获取数据不渲染的问题

    问题:vue里面当通过索引值获取数据时,ajax数据成功返回,但是在火狐下不渲染 解决:

  4. day 12 生成器和生成器函数以及各种推导式

    一.生成器    本质就是迭代器. 我们可以直接执⾏__next__()来执⾏ 以下⽣成器 一个一个的创建对象 创建生成器的方式: 1.生成器函数 2.通过生成器 表达式来获取生成器 3.类型转换(看 ...

  5. python中函数参数的引用方式

    值传递和引用传递时C++中的概念,在python中函数参数的传递是变量指向的对象的物理内存地址!!! python不允许程序员选择采用传值还是传引用.Python参数传递采用的肯定是“传对象引用”的方 ...

  6. QEP之init()和dispatch()流程图

    抽象状态机类QFsm或QHsm有一个函数指针,用于在继承的具体状态机类中指向具体的状态函数,其有两个对外的接口函数init()和dispatch(),其工作原理是理解状态机处理事件过程的关键. 具体状 ...

  7. Python的scrapy之爬取链家网房价信息并保存到本地

    因为有在北京租房的打算,于是上网浏览了一下链家网站的房价,想将他们爬取下来,并保存到本地. 先看链家网的源码..房价信息 都保存在 ul 下的li 里面 ​ 爬虫结构: ​ 其中封装了一个数据库处理模 ...

  8. 论文翻译第二弹--用python(或Markdown)对论文复制文本进行处理

    图中这种论文你想进行文本复制放入翻译软件进行翻译时,会发现是这种形式: 句子之间是断开的,这时普遍的方法,也是我之前一直用的方法就是打开一个文档编辑器,复制上去后一行行地继续调整.昨天不想这样了,就打 ...

  9. 20145209 2016-2017-2 《Java程序设计》第4周学习总结

    20145209 2016-2017-2 <Java程序设计>第4周学习总结 教材学习内容总结 继承是面向对象最显著的一个特性.继承是从已有的类中派生出新的类,新的类能吸收已有类的数据属性 ...

  10. EL/JSTL-jsp页面更简单的输出方式

    1.EL(Expression Language):表达式语言,用于页面输出 格式:${表达式} EL支持四则运算,关系运算[常用eq来比较字符串或判断相等],逻辑运算 EL访问空间内对象,[类.对象 ...