SpringBoot开发目的是为了简化Spring应用的创建、运行、调试和部署等。使用Spring Boot可以做到专注于Spring应用的开发,而无需过多关注XML的配置。简单来说,它提供了一堆依赖打包,并已经按照使用习惯解决了依赖问题。使用Spring Boot可以不用或者只需要很少的Spring配置就可以让企业项目快速运行起来。
SpringBoot Web组件默认集成SpringMVC框架,SpringMVC3.0以后支持注解方式使用java代码启动SpringMVC。
在使用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>
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注解注入进来即可使用,非常方便。
在使用 Spring 时,项目部署时需要我们在服务器上部署 tomcat,然后把项目打成 war 包扔到 tomcat里,在使用 SpringBoot 后,我们不需要在服务器上去部署 tomcat,因为 SpringBoot 内嵌了 tomcat,我们只需要将项目打成 jar 包,使用 java -jar xxx.jar一键式启动项目。
@SpringBootApplication
SpringBoot的核心注解,使用在SpringBoot主类上,用于启动SpringBoot各个组件
@EnableAutoConfiguration
SpringBoot自动配置注解,使用该注解后SpringBoot 就能根据当前类路径下的包或者类来配置 SpringBean。@EnableAutoConfiguration
实现的关键在于引入AutoConfigurationImportSelector,核心逻辑为selectImports方法
@Configuration
定义配置类,指出该类是Bean配置信息来源,一般加在主类上。如果有些第三方库需要用到xml文件,建议仍然通过@Configuration类作为项目的配置主类——可以使用@ImportResource注解加载xml配置文件。
@ComponentScan
组件扫描。让springBoot扫描到Configuration类并把它加入到程序上下文。@ComponentScan注解默认就会装配标识了@Controller,@Service,@Repository,@Component注解的类到spring容器中。
@Repository
标注数据访问组件及DAO组件。使用@Repository注解可以确保DAO或repositories提供异常转译,这个注解修饰的DAO或者repositories类会被ComponetScan发现并配置,同时也不需要为它们提供XML配置项。
@Service
一般用于修饰service层的组件
@RestController
用于标注控制层组件,表示为控制器Bean,并将函数的返回值直接写入HTTP响应体中,是REST风格控制器。它是@Controller和@ResponseBody的合集。
@RequestBody
表示该方法的返回值直接写入HTTP response body中。一般在异步获取数据时使用,在使用@RequestMapping后,返回值通常解析为跳转路径,加上@responsebody后返回结果不会被解析为跳转路径,而是直接写入HTTP response body中。比如异步获取json数据,加上@responsebody后,会直接返回json数据。
@Component
泛指组件,当组件不好归类的时候,我们可以使用这个注解进行标注。
@Bean
相当于XML中的,放在方法的上面,而不是类,意思是产生一个bean,并交给spring管理。
@Autowired
byType方式。把配置好的Bean拿来用,完成属性、方法的组装,它可以对类成员变量、方法及构造函数进行标注,完成自动装配的工作。当加上(required=false)时,就算找不到bean也不报错。
@RequestMapping
@RequestParam
在方法的参数前面。例:
@RequestParam String a =request.getParameter(“a”)。
@PathVariable
路径变量。参数与大括号里的名字一样要相同。
RequestMapping("user/get/mac/{macAddress}")
public String getByMacAddress(@PathVariable String macAddress){
//do something;
}