约定大于配置,就是说系统,类库,框架应该假定合理的默认值,而非要求提供不必要的配置。在使用spring和springmvc的时候,会有好多东西需要配置,这样工作量增加,并且跨平台部署的时候容易出现问题。由于这些问题,Spring boot应运而生。
SpringBoot最大的特性就是可以把应用打包成一个jar包或war包,直接启动,不需要另外配置一个 Web Server。 另外,SpringBoot 喜欢把配置都写到代码里,有时候会带来混乱,一些本可以用xml来完成的配置,可能会变得难读和凌乱。
他的核心功能:
1、独立的运行Spring项目。Spring Boot可以以jar包的形式来运行,运行一个Spring Boot项目我们只需要通过java -jar xx.jar类运行。非常方便。
2、内嵌Servlet容器 ,Spring Boot可以内嵌Tomcat,这样我们无需以war包的形式部署项目。
3、提供starter简化maven 配置,使用Spring或者SpringMVC我们需要大量的配置依赖,而这些依赖有很多都是固定的,因此他能简化配置:
4、 自动配置Spring;
5、准生产的应用监控;
6、无代码生成和xml配置。
7、极大的提高了开发和部署效率。
接下里看下:
就是这个DemoSpringBootApplication.java 类,这是整个项目的入口类,这个类有个@SpringBootApplication 注解,这是整个核心注解,它的目的就是开启Spring Boot的自动配置。在类上添加一个 @RestController 注解,使之变为一个controller,然后提供一个地址转换方法,如下:
然后点项目启动按钮。大家会想到为什么项目会运行起来,分析下
入口类和@SpringBootApplication注解
我们新建一个Project系统都会帮我们创建一个名为artifactId+Application的入口类,这个类中有一个main方法,这个main方法就是一个标准的Java应用程序的入口方法。这里的@SpringBootApplication则是一个组合注解,源码:
我们可以看到它组合了@SpringBootConfiguration、@EnableAutoConfiguration以及@ComponentScan,我们在开发的过程中如果不使用@SpringBootApplication,则可以组合使用这三个注解。这三个注解中,@SpringBootConfiguration实际上就是我们前面几篇博客提到的@Configuration注解,表明这个类是一个配置类,@EnableAutoConfiguration则表示让Spring Boot根据类路径中的jar包依赖为当前项目进行自动配置,最后一个@ComponentScan的作用我也不赘述了,唯一要注意的是如果我们使用了@SpringBootApplication注解的话,系统会去入口类的同级包以及下级包中去扫描实体类,因此我们建议入口类的位置在groupId+arctifactID组合的包名下。
关闭特定的自动配置
在上面一小节中我们看到@ComponentScan注解是有一个过滤器的,如果我们只想要@SpringBootApplication去扫描特定的类而不是全部类,那么就可以关闭自动配置,如下:
SpringBoot的配置文件
Spring Boot使用一个全局的配置文件application.properties或者application.yml,配置文件放在src/main/resources目录下。properties是我们常见的一种配置文件,Spring Boot不仅支持properties这种类型的配置文件,也支持yaml语言的配置文件,这里以properties类型的配置文件为例来看几个案例。
a、修改Tomcat默认端口和默认访问路径
如下
server.context-path=/helloboot
server.port=8081
只需要在properties文件中添加。
常规属性配置
使用Spring容器框架下注入properties文件里的值是很繁琐的,这里就会变得异常简单。
我们只需要在application.properties中定义属性,然后在代码中直接使用@Value注入即可。
如下
book.author=罗贯中
book.name=三国演义
book.pinyin=sanguoyanyi
在这里设置了中文,因为中文不做特殊处理会乱码,处理方式为在priperties文件中添加:
server.tomcat.uri-encoding=UTF-8
spring.http.encoding.charset=UTF-8
spring.http.encoding.enabled=true
spring.http.encoding.force=true
spring.messages.encoding=UTF-8 然后在变量中通过@Value直接注入就行了,如下:
@Value(value = "${book.author}")
private String bookAuthor;
@Value("${book.name}")
private String bookName;
@Value("${book.pinyin}")
private String bookPinYin;
修改index方法,使之返回这些值:
类型安全配置
刚刚说的这种方式我们在实际项目中使用的时候工作量略大,因为每个项目要注入的变量
的值太多了,这种时候我们可以使用基于类型安全的配置方式,就是将properties属性和
一个Bean关联在一起,这样使用起来会更加方便。我么来看看这种方式怎么实现。
1、在.resouses 文件夹中 创建book.properties文件,写好属性名和属性值
2、创建book.bean 并注入properties文件。
prefix是指前缀,location指定要注入文件的位置。
在Controller中添加如下代码注入Bean:
@Autowiredprivate BookBean bookBean;
日志配置
默认情况下Spring Boot使用Logback作为日志框架,也就是我们前面几篇博客中用到的打
印日志方式,当然如果有需要我们可以手动配置日志级别以及日志输出位置,相比于我们
在Spring容器中写的日志输出代码,这里的配置简直就是小儿科了,只需要在
application.properties中添加如下代码:
logging.file=/home/sang/workspace/log.log 日志输出位置
logging.level.org.springframework.web=debug 日志级别
Profile 配置问题
在Spring Boot 中系统提供了更为简洁的方式。全局Profile配置我们使用application-{profile}.properties来定义,然后在application.properties中通过spring.profiles.active来指定使用哪个Profile。OK,那么接下来我们来看一个简单的案例。
1.在src/main/resources文件夹下定义不同环境下的Profile配置文件,文件名分别为application-prod.properties和application-dev.properties,这两个前者表示生产环境下的配置,后者表示开发环境下的配置,如下:
application-prod.properties:
server.port=80811
application-dev.properties:
server.port=80801
然后在application.properties中进行简单配置,如下:
spring.profiles.active=dev
如果想换为生产环境,只需要把spring.profiles.active=dev改为spring.profiles.active=prod即可,当然访问端口这是也变为8081了。