您的当前位置:首页正文

SpringBoot基础 -- 框架介绍

2024-10-23 来源:个人技术集锦

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

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;

}
显示全文