1. SpringBoot
产生原因
-
spring, springmvc框架使用上的一些缺点:
-
需要使用的大量的配置文件
-
还需要配置各种对象
-
需要把使用的对象放入到spring容器中才能使用对象
-
需要了解其他框架配置规则
-
springboot的一些直观优点:
-
SpringBoot就相当于简化了配置文件的Spring+SpringMVC(但springboot的核心还是IOC容器)
-
常用的框架和第三方库都已经配置好了, 只需要引入使用即可
特点
- Create stand-alone Spring applications
可以创建spring应用
- Embed Tomcat, Jetty or Undertow directly (no need to deploy WAR files)
内嵌的tomcat, jetty, Undertow
- Provide opinionated 'starter' dependencies to simplify your build configuration
提供了starter起步依赖, 简化应用的配置:
比如使用MyBatis框架, 需要在Spring项目中, 需要配置MyBatis的对象, SqlSessionFactory以及Dao的代理对象
但在SpringBoot项目中, 只要在pom.xml里面加入一个mybatis-spring-boot-starter依赖
- Automatically configure Spring and 3rd party libraries whenever possible
尽可能去自动配置spring和第三方库, 叫做自动配置(就是把spring中的,第三方库中的对象都创建好,放到容器中,开发人员可以直接使用)
- Provide production-ready features such as metrics, health checks, and externalized configuration
提供了健康检查, 统计, 外部化配置
- Absolutely no code generation and no requirement for XML configuration
不用生成代码,不需要使用xml文件做配置
2. SpringBoot项目
地址
-
创建springboot项目时,可能用到的地址
-
国外地址: https://start.spring.io
@SpringBootApplication注解
- 位于项目启动类上面,是复合注解, 包含以下注解
@SpringBootConfiguration
@EnableAutoConfiguration
@ComponentScan
- 而@SpringBootConfiguration又是包含@Configuration的符合注解
@Configuration
public @interface SpringBootConfiguration {
@AliasFor(
annotation = Configuration.class
)
boolean proxyBeanMethods() default true;
}
//说明使用了@SpringBootConfiguration注解标注的类,可以作为配置文件使用的,可以使用Bean声明对象,注入到容器
- @EnableAutoConfiguration
启用自动配置,把java对象配置好,注入到spring容器中。例如可以把mybatis的对象创建好,放入到容器中
- @ComponentScan
扫描器,找到注解,根据注解的功能创建对象,给属性赋值等等。默认扫描的包:@ComponentScan所在的类,以及其所在类所在的包和子包。
SpringBoot的配置文件
- 名称:application
- 后缀:property(key=value) 或 yml(key:value)
- 配置文件示例:
- 例1:application.properties设置端口和上下文
#设置端口号
server.port=9090
#设置访问应用上下文路径,contextpath
server.servlet.context-path=/myboot
- 例2:application.yml,配置文件的结构更加清晰,推荐使用
server:
port: 9090
servlet:
context-path:/myboot
多环境配置文件
-
实际场景中,项目的配置会有开发环境,测试环境,上线的环境
-
每个环境有不同的配置信息,例如端口,上下文,数据库url,用户名,密码等等
-
使用多环境配置文件,可以方便的切换不同的配置
-
使用方式:创建多个配置文件,名称规则:application-环境名称.properties(或者后缀未yml格式)
-
多环境配置文件的示例如下:
-
创建开发环境的配置文件:application-dev.properties(或者application-dev.yml )
-
创建测试者使用的配置:application-test.properties
-
springboot默认读取application.properties文件,故需在该文件中配置实际需要读取的核心配置文件
#以激活配置文件 application-dev.properties为例
spring.profiles.active=dev
@ConfigurationProperties
- 设计思想:把配置文件的数据映射到java对象的属性上,将配置文件中某些开头和prefix指定的值相同的对应配置文件中的值赋给对应属性
- 例如:application.properties
#自定义key=value
school.name=橘子
school.website=www.test.com
school.address=黑龙江哈尔滨
- 则对应的实体类应该如下,其中name会被注入配置文件中的school.name的值,其他属性类似
@Component
@ConfigurationProperties(prefix = "school")
public class SchoolInfo {
private String name;
private String website;
private String address;
public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
}
public String getWebsite() {
return website;
}
public void setWebsite(String website) {
this.website = website;
}
public String getAddress() {
return address;
}
public void setAddress(String address) {
this.address = address;
}
@Override
public String toString() {
return "SchoolInfo{" +
"name='" + name + '\'' +
", website='" + website + '\'' +
", address='" + address + '\'' +
'}';
}
}
使用jsp
- SpringBoot不推荐使用jsp, 而是使用模板技术代替jsp
- 如果要使用jsp, 需要添加如下依赖,负责编译jsp文件
<dependency>
<groupId>org.apache.tomcat.embed</groupId>
<artifactId>tomcat-embed-jasper</artifactId>
</dependency>
- 如果需要使用servlet, jsp, jstl的功能, 需要添加如下依赖
<dependency>
<groupId>javax.servlet</groupId>
<artifactId>jstl</artifactId>
</dependency>
<dependency>
<groupId>javax.servlet</groupId>
<artifactId>javax.servlet-api</artifactId>
</dependency>
<dependency>
<groupId>javax.servlet.jsp</groupId>
<artifactId>javax.servlet.jsp-api</artifactId>
<version>2.3.1</version>
</dependency>
- 创建一个存放jsp的目录, 一般为src/main/webapp目录,记得设置webapp的目录属性
- 需要在pom.xml指定jsp文件编译后的存放目录:META-INF/resources
<resource>
<directory>src/main/webapp</directory>
<targetPath>META-INF/resources</targetPath>
<includes>
<include>**/*.*</include>
</includes>
</resource>
- 创建Controller, 访问jsp
- 在application.propertis文件中配置视图解析器
#配置视图解析器
spring.mvc.view.prefix=/
spring.mvc.view.suffix=.jsp
手动使用SpringBoot容器获取对象
- 关注SpringBoot工程的主启动类的run方法
@SpringBootApplication
public class Application {
public static void main(String[] args) {
SpringApplication.run(Application.class, args);
}
}
- 关注上述run方法的返回值
public static ConfigurableApplicationContext run(Class<?> primarySource, String... args) {
return run(new Class[]{primarySource}, args);
}
- 而ConfigurableApplicationContext是ApplicationContext的子接口
public interface ConfigurableApplicationContext extends ApplicationContext, Lifecycle, Closeable {
}
- 所以接收SpringBoot主启动类的run方法的返回值就可以获取到SpringBoot容器
- 之后便可以按照需求调用SpringBoot容器的方法获取已经注册到容器中的对象
CommandLineRunner接口 与 ApplcationRunner接口
- 两个接口
@FunctionalInterface
public interface CommandLineRunner {
void run(String... args) throws Exception;
}
@FunctionalInterface
public interface ApplicationRunner {
void run(ApplicationArguments args) throws Exception;
}
- 两个接口都有一个run方法
- SpringBoot项目的主启动类实现上述接口,重写run方法,在容器对象创建好后自动执行run()方法
- 可以在容器对象创建好后完成一些自定义的操作