SpringBoot基础 -- 框架介绍
1.SpringBoot介绍
1.1 概述
SpringBoot开发目的是为了简化Spring应用的创建、运行、调试和部署等。使用Spring Boot可以做到专注于Spring应用的开发,而无需过多关注XML的配置。简单来说,它提供了一堆依赖打包,并已经按照使用习惯解决了依赖问题。使用Spring Boot可以不用或者只需要很少的Spring配置就可以让企业项目快速运行起来。
1.2 核心功能
- 独立运行Spring项目:SpringBoot可以以独立的JAR包运行。
- 内嵌Servlet:SpringBoot可以选择使用Tomcat、Jetty或者Undertow,无须以war包形式部署项目。
- 简化配置:Spring提供推荐的基础 POM 文件来简化Maven 配置。
- 自动配置Spring:SpringBoot会根据项目依赖来自动配置Spring 框架,极大地减少项目要使用的配置。
- 提供生产就绪型功能:提供可以直接在生产环境中使用的功能,如性能指标、应用信息和应用健康检查。
- 无代码生成和XML配置:SpringBoot不生成代码。完全不需要任何xml配置即可实现Spring的所有配置。
2.框架区别
2.1 SpringBoot与Spring
SpringBoot Web组件默认集成SpringMVC框架,SpringMVC3.0以后支持注解方式使用java代码启动SpringMVC。
2.2 SpringBoot与SpringCloud
- SpringBoot快速整合第三方框架(Maven依赖关系###Maven继承),完全采用注解化,简化XML配置,最终以java应用程序进行执行。
- SpringCloud一套目前完整的微服务解决框架,功能非常强大,注册中心,客户端调用工具,服务治理(负载均衡,断路器,分布式配置中心,网管,消息总线等)。
- 关系:微服务通讯技术Http+json(restfull)轻量级,SpringBoot Web组件默认集成SpringMVC,SpringCloud依赖于SpringBoot实现微服务,使用SpringMVC编写微服务接口。
3.框架详解
3.1 简化项目创建
在使用Spring过程中,需要用户手动在pom中添加项目依赖,而在SpringBoot中starter-web组件就已经包含多个依赖,因此能大幅简化项目的创建流程。
<!-- .....省略其他依赖 -->
<dependency>
<groupId>org.springframework</groupId>
<artifactId>spring-web</artifactId>
<version>5.0.7.RELEASE</version>
<scope>compile</scope>
</dependency>
<dependency>
<groupId>org.springframework</groupId>
<artifactId>spring-webmvc</artifactId>
<version>5.0.7.RELEASE</version>
<scope>compile</scope>
</dependency>
3.2 简化配置
SpringBoot更多的是采用 Java Config 的方式,对 Spring 进行配置。以下演示如何让SpringBoot管理一个类和方法
public class TestService {
public String sayHello () {
return "Hello Spring Boot!";
}
}
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;
@Configuration
public class JavaConfig {
@Bean
public TestService getTestService() {
return new TestService();
}
}
@Configuration表示该类是个配置类,@Bean表示该方法返回一个 Bean。这样就把TestService作为 Bean 让 Spring 去管理了,在其他地方,我们如果需要使用该 Bean,和原来一样,直接使用@Resource注解注入进来即可使用,非常方便。
3.3 简化部署
在使用 Spring 时,项目部署时需要我们在服务器上部署 tomcat,然后把项目打成 war 包扔到 tomcat里,在使用 SpringBoot 后,我们不需要在服务器上去部署 tomcat,因为 SpringBoot 内嵌了 tomcat,我们只需要将项目打成 jar 包,使用 java -jar xxx.jar一键式启动项目。
4.SpringBoot常用注解
4.1 @SpringBootApplication
SpringBoot的核心注解,使用在SpringBoot主类上,用于启动SpringBoot各个组件
4.2 @EnableAutoConfiguration
SpringBoot自动配置注解,使用该注解后SpringBoot 就能根据当前类路径下的包或者类来配置 SpringBean。@EnableAutoConfiguration
实现的关键在于引入AutoConfigurationImportSelector,核心逻辑为selectImports方法
- 从配置文件META-INF/spring.factories加载所有可能用到的自动配置类。
- 去重,并将exclude和excludeName属性携带的类排除。
- 过滤,将满足条件(@Conditional)的自动配置类返回
4.3 @Configuration
定义配置类,指出该类是Bean配置信息来源,一般加在主类上。如果有些第三方库需要用到xml文件,建议仍然通过@Configuration类作为项目的配置主类------可以使用@ImportResource注解加载xml配置文件。
4.4 @ComponentScan
组件扫描。让springBoot扫描到Configuration类并把它加入到程序上下文。@ComponentScan注解默认就会装配标识了@Controller,@Service,@Repository,@Component注解的类到spring容器中。
4.5 @Repository
标注数据访问组件及DAO组件。使用@Repository注解可以确保DAO或repositories提供异常转译,这个注解修饰的DAO或者repositories类会被ComponetScan发现并配置,同时也不需要为它们提供XML配置项。
4.6 @Service
一般用于修饰service层的组件
4.7 @RestController
用于标注控制层组件,表示为控制器Bean,并将函数的返回值直接写入HTTP响应体中,是REST风格控制器。它是@Controller和@ResponseBody的合集。
4.8 @RequestBody
表示该方法的返回值直接写入HTTP response body中。一般在异步获取数据时使用,在使用@RequestMapping后,返回值通常解析为跳转路径,加上@responsebody后返回结果不会被解析为跳转路径,而是直接写入HTTP response body中。比如异步获取json数据,加上@responsebody后,会直接返回json数据。
4.9 @Component
泛指组件,当组件不好归类的时候,我们可以使用这个注解进行标注。
4.10 @Bean
相当于XML中的,放在方法的上面,而不是类,意思是产生一个bean,并交给spring管理。
4.11 @Autowired
byType方式。把配置好的Bean拿来用,完成属性、方法的组装,它可以对类成员变量、方法及构造函数进行标注,完成自动装配的工作。当加上(required=false)时,就算找不到bean也不报错。
4.12 @RequestMapping
RequestMapping是一个用于处理请求地址映射的注解。提供路由信息,负责URL至Controller中具体函数映射,可用于类或方法上。注解在类上表示类中的所有响应请求的方法都是以该地址作为父路径。
4.13 @RequestParam
在方法的参数前面。例:
@RequestParam String a =request.getParameter("a")。
4.14 @PathVariable
路径变量。参数与大括号里的名字一样要相同。
RequestMapping("user/get/mac/{macAddress}")
public String getByMacAddress(@PathVariable String macAddress){
//do something;
}