首页 > 编程语言 >【Java】Spring Boot 教程

【Java】Spring Boot 教程

时间:2024-08-23 13:23:20浏览次数:19  
标签:依赖 Java Spring Boot 应用程序 spring org

Spring Boot 入门教程

Spring Boot 介绍

Spring Boot是一个开源的Java框架,旨在简化Spring应用的创建和部署过程。它提供了一种快速和简便的方式来设置、配置和运行新的Spring应用程序,通过“约定优于配置”的原则,减少了传统Spring应用中大量的XML配置,使得开发者能够更加专注于业务逻辑的实现,从而加速开发周期,并轻松创建独立运行的、生产级别的基于Spring的应用程序。

项目创建与配置

  • 使用 Spring Initializr 创建项目
  • 国内可以使用阿里云的 Spring Initializr 创建项目,选择依赖项(如Web、JPA、Security)和 Spring Boot 版本
  • 添加所需的依赖项到 pom.xml(Maven) 或 build.gradle(Gradle) 文件中
  • src/main/resources 目录下创建 application.propertiesapplication.yml 文件,配置应用程序属性,例如数据库连接信息、端口号等

配置

配置文件说明

在Spring Boot应用程序中,通常使用YAML格式(.yml文件)来配置应用程序的属性和设置。相比于传统的.properties文件,YAML格式更加清晰易读,并且支持层级结构和列表等复杂数据类型。以下是一些常用的Spring Boot YAML配置字段及其说明:

  • server.port: 配置应用程序的端口号。
  • spring.application.name: 配置应用程序的名称。
  • spring.datasource.url: 配置数据库连接的URL。
  • spring.datasource.username: 配置数据库连接的用户名。
  • spring.datasource.password: 配置数据库连接的密码。
  • logging.level: 配置日志记录的级别,如DEBUGINFOWARNERROR等。
  • management.endpoints.web.exposure.include: 配置哪些管理端点(如healthinfo)可以通过Web访问。
  • spring.jpa.hibernate.ddl-auto: 配置Hibernate的DDL模式,如updatecreatecreate-drop等。

1. 应用程序配置

spring:
  application:
    name: my-application

spring.application.name: 应用程序的名称。在集成服务发现和配置管理时特别有用,也会影响Actuator端点的路径。

2. 服务器端口配置

server:
  port: 8080

server.port: 应用程序监听的HTTP端口号。默认为8080,可以根据需要进行配置。

3. 数据源配置

spring:
  datasource:
    url: jdbc:mysql://localhost:3306/mydatabase
    username: root
    password: password
    driver-class-name: com.mysql.cj.jdbc.Driver
说明
  • spring.datasource.url: 数据库连接URL。
  • spring.datasource.usernamespring.datasource.password: 数据库的用户名和密码。
  • spring.datasource.driver-class-name: 数据库驱动类名。

4. JPA 配置

spring:
  jpa:
    show-sql: true
    hibernate:
      ddl-auto: update
说明
  • spring.jpa.show-sql: 是否在控制台显示SQL语句。
  • spring.jpa.hibernate.ddl-auto: Hibernate自动建表策略,如updatecreatevalidate等。

5. 日志配置

logging:
  level:
    org.springframework: INFO
    com.example: DEBUG
说明
  • logging.level: 日志级别配置,可以针对不同的包或类设置不同的日志级别。

6. Spring Security 配置

spring:
  security:
    user:
      name: user
      password: password
    basic:
      enabled: true
说明
  • spring.security.user.namespring.security.user.password: 基本认证的用户名和密码。
  • spring.security.basic.enabled: 是否启用基本认证。

7. Actuator 配置

management:
  endpoints:
    web:
      exposure:
        include: health, info
说明
  • management.endpoints.web.exposure.include: 暴露给外部的Actuator端点,可以设置为*来暴露所有端点。

8. 多环境配置

spring:
  profiles:
    active: dev
说明
  • spring.profiles.active: 指定当前激活的环境配置文件,可以根据需要选择devprod等不同的配置文件。

9. 自定义属性配置

myapp:
  custom:
    property: value
说明
  • 自定义应用程序属性,可以在应用程序中通过@Value注解或Environment对象访问。

依赖管理

依赖管理介绍

  • 在 Spring Boot 中,依赖管理是非常重要的一部分。
  • 它通过简化依赖项的引入和版本管理,大大简化了项目的构建和维护过程。
  • Spring Boot采用了 Starter 依赖项的概念,通过提供预配置的依赖项集合来简化项目的初始化和配置。

Starter 依赖项

Spring Boot 的 Starter 依赖项是预先配置的一组依赖项集合,它们以 spring-boot-starter-* 的命名格式提供。这些 Starter 依赖项可以按照功能领域进行分类,例如:

  • spring-boot-starter-web: 支持构建Web应用程序,包括Spring MVC和内嵌的Servlet容器(如Tomcat)。
  • spring-boot-starter-data-jpa: 支持使用Spring Data JPA访问数据库,包括Hibernate和JPA实现。
  • spring-boot-starter-security: 支持Spring Security,用于身份验证和授权。
  • spring-boot-starter-test: 支持单元测试和集成测试,包括JUnit、Mockito等。
  • spring-boot-starter-actuator: 支持集成Actuator,用于监控和管理应用程序。

引入Starter依赖项可以快速添加特定功能,Spring Boot会自动配置所需的组件和设置,减少手动配置工作量。

自动依赖解析和版本管理

Spring Boot的BOM(Bill of Materials)集中管理各个 Starter 依赖项的版本,通过在pom.xml(Maven)或 build.gradle(Gradle)中引入 BOM,可以简化依赖项版本管理。例如,在 Maven 项目中:

<dependencyManagement>
  <dependencies>
    <dependency>
      <groupId>org.springframework.boot</groupId>
      <artifactId>spring-boot-dependencies</artifactId>
      <version>2.6.0</version>
      <type>pom</type>
      <scope>import</scope>
    </dependency>
  </dependencies>
</dependencyManagement>

这样一来,当你在项目中引入 Spring Boot 的 Starter 依赖项时,不需要显式声明版本号,Maven 会自动使用 BOM 中指定的版本。

自定义依赖管理

尽管Spring Boot提供了丰富的Starter依赖项和依赖管理功能,但有时你可能需要自定义特定的依赖项或版本。在这种情况下,你可以在pom.xmlbuild.gradle中显式声明所需的依赖项,而不使用Starter依赖项。

例如,在Maven项目中,你可以这样声明一个依赖项:

<dependency>
  <groupId>org.springframework.boot</groupId>
  <artifactId>spring-boot-starter-web</artifactId>
  <version>2.6.0</version>
</dependency>

这样做可以覆盖Spring Boot BOM中指定的版本,允许你使用特定版本的依赖项。

排除和冲突解决

在实际项目中,可能会遇到依赖项之间的冲突或不兼容性问题。Spring Boot允许你通过<exclusions>标签来排除Starter依赖项中的某些传递性依赖,以解决冲突问题。

例如,在Maven项目中排除传递性依赖:

<dependency>
  <groupId>org.springframework.boot</groupId>
  <artifactId>spring-boot-starter-web</artifactId>
  <exclusions>
    <exclusion>
      <groupId>org.springframework.boot</groupId>
      <artifactId>spring-boot-starter-tomcat</artifactId>
    </exclusion>
  </exclusions>
</dependency>

这种排除机制使得你可以更精确地控制项目中依赖项的版本和组合,以避免不必要的冲突。

Spring Boot 核心功能

依赖注入(Dependency Injection)

依赖注入是Spring框架的核心概念之一,它通过控制反转(IoC,Inversion of Control)的方式管理对象之间的依赖关系,从而实现松耦合、可测试和可维护的代码结构。Spring Boot通过自动配置的方式支持依赖注入,以下是一些关键点:

自动装配(Auto-configuration)

Spring Boot根据类路径中的依赖项自动配置应用程序上下文。这包括自动扫描和注册带有特定注解(如@Component@Service@Repository等)的Bean,以及自动解析和注入这些Bean之间的依赖关系。

Bean的声明和管理

开发者可以使用@Autowired注解在需要依赖注入的地方注入其他Bean,Spring Boot会自动解析和注入所需的依赖。例如:

@RestController
public class MyContr {
  private final MyService myService;
  
  @Autowired
  public MyContr(MyService myService) {
      this.myService = myService;
  }
  
  // Controller methods
}

在上面的例子中,MyController中的MyService依赖通过构造函数注入。

条件化注入

Spring Boot支持根据条件选择性地注入Bean。例如,可以使用 @Conditional 注解或 @ConditionalOnProperty 注解根据特定的条件决定是否创建和注入Bean。

面向切面编程(Aspect-Oriented Programming)

面向切面编程是一种软件开发方法,用于分离横切关注点(cross-cutting concerns),例如日志、事务管理、安全性等,以便更好地模块化和管理应用程序。Spring Boot通过整合Spring AOP框架支持面向切面编程,以下是相关的说明:

切面(Aspect)

切面是一个模块化的类,它包含了横切关注点的逻辑。在Spring Boot中,可以使用@Aspect注解标记一个类作为切面,并通过@Before@After@Around等注解定义切面的具体行为。

切点(Pointcut)

切点定义了在应用程序中哪些位置应用切面逻辑。切点表达式使用execution关键字指定要拦截的方法调用。例如:

@Aspect
@Component
public class LoggingAspect {
    
    @Before("execution(* com.example.service.*.*(..))")
    public void beforeServiceMethods(JoinPoint joinPoint) {
        // Advice logic before service method execution
    }
    
    // Other advices (e.g., @After, @Around) can be defined similarly
}
通知(Advice)

通知是在切点处执行的具体逻辑,包括@Before@AfterReturning@AfterThrowing@Around等。例如,在上面的例子中,beforeServiceMethods方法就是一个@Before通知,它在目标方法执行之前执行。

配置和启用

Spring Boot通过自动配置和注解扫描使得使用AOP变得非常简单。通常情况下,只需在切面类上加上@Aspect注解,并确保它被Spring Boot的组件扫描机制扫描到即可。

Web 开发

1. 创建一个新的 Spring Boot 项目

你可以使用 Spring Initializr 创建一个新的 Spring Boot 项目。访问 start.spring.io 并按照以下配置创建项目:

  • Project: Maven 或 Gradle(选择你的构建工具)
  • Language: Java
  • Spring Boot: 选择最新的稳定版本
  • Project Metadata:
    • Group: com.example(或者你喜欢的 Group ID)
    • Artifact: helloworld(或者你喜欢的 Artifact ID)
    • Dependencies: 选择 "Spring Web"

点击 "Generate" 下载项目的 zip 文件。

2. 将项目导入到你的 IDE 中

解压下载的文件并导入到你喜欢的 IDE 中(如 IntelliJ IDEA、Eclipse 等)。

3. 实现 Hello World Controller

在 IDE 中打开你的项目,导航到 src/main/java/com/example/helloworld。你会看到一个名为 HelloworldApplication.java 的类文件,这是 Spring Boot 应用程序的入口类。

在这个类的同级目录下创建一个新的 Java 类文件,例如 HelloController.java,并添加以下内容:

package com.example.helloworld;

import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.RestController;

@RestController
public class HelloController {

    @GetMapping("/")
    public String hello() {
        return "Hello, World!";
    }
}

4. 运行应用程序

使用 Maven 或 Gradle 构建项目并启动应用程序。可以通过 IDE 的运行功能或者命令行执行以下命令:

mvn spring-boot:run

或者

./gradlew bootRun

5. 访问 Hello World 页面

在浏览器中访问 http://localhost:8080/,你应该能够看到显示 "Hello, World!" 的页面。

这样,你就成功创建了一个简单的 Spring Boot Web 应用程序,并实现了一个基本的 "Hello, World!" 示例。

数据访问

1.创建过程和 web 项目示例一样

注意:需要选择 jpa 和对应数据库的驱动

2. 配置数据库连接

默认情况下,Spring Boot 使用 H2 Database 作为内嵌数据库。如果你想使用其他数据库,可以在 application.properties(或 application.yml)文件中配置数据库连接信息。

例如,使用 H2 Database 的默认配置:

# application.properties

spring.datasource.url=jdbc:h2:mem:testdb
spring.datasource.driverClassName=org.h2.Driver
spring.datasource.username=username
spring.datasource.password=password
spring.jpa.database-platform=org.hibernate.dialect.H2Dialect

# Hibernate ddl auto (create, create-drop, validate, update)
spring.jpa.hibernate.ddl-auto=update

5. 创建一个简单的控制器来测试

创建一个简单的控制器 UserController,用来处理 HTTP 请求,并操作 UserRepository 来访问数据库。

package com.example.userdemo;

import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.web.bind.annotation.*;

import java.util.List;

@RestController
@RequestMapping("/users")
public class UserController {

    @Autowired
    private UserRepository userRepository;

    //  获取所有用户
    @GetMapping("/")
    public List<User> getAllUsers() {
        return userRepository.findAll();
    }

    // 通过 id 获取用户
    @GetMapping("/{id}")
    public User getUserById(@PathVariable("id") Long id) {
        return userRepository.findById(id).orElse(null);
    }

    // POST 创建新用户
    @PostMapping("/")
    public User addUser(@RequestBody User user) {
        return userRepository.save(user);
    }

    // PUT 更新用户
    @PutMapping("/{id}")
    public User updateUser(@PathVariable("id") Long id, @RequestBody User userDetails) {
        User user = userRepository.findById(id).orElse(null);
        if (user != null) {
            user.setUsername(userDetails.getUsername());
            user.setAge(userDetails.getAge());
            user.setSex(userDetails.getSex());
            return userRepository.save(user);
        }
        return null;
    }

    // DELETE 删除用户 
    @DeleteMapping("/{id}")
    public void deleteUser(@PathVariable("id") Long id) {
        userRepository.deleteById(id);
    }
}

4. 创建 UserRepository 接口

在同样的目录下创建一个接口 UserRepository,继承自 JpaRepository<User, Long>,这样 Spring Data JPA 将会自动实现一些基本的数据库操作方法。

package com.example.userdemo;
import org.springframework.data.jpa.repository.JpaRepository;
public interface UserRepository extends JpaRepository<User, Long> {
}

3. 创建实体类 User

src/main/java/com/example/userdemo 目录下创建一个名为 User 的实体类:

package com.example.userdemo;

import javax.persistence.Entity;
import javax.persistence.GeneratedValue;
import javax.persistence.GenerationType;
import javax.persistence.Id;

@Entity
public class User {

    @Id
    @GeneratedValue(strategy = GenerationType.IDENTITY)
    private Long userId;
    private String username;
    private Integer age;
    private String sex;
    // Constructors, getters, and setters 省略
}

6. 运行应用程序并测试

使用 Maven 或 Gradle 构建并运行你的应用程序。然后,可以使用 Postman 或浏览器访问以下 API 来测试你的应用程序:

  • GET http://localhost:8080/users/ 获取所有用户
  • GET http://localhost:8080/users/{id}
    根据用户ID获取用户信息
  • POST http://localhost:8080/users/
    添加新用户(Body 中包含 JSON 数据)
  • PUT http://localhost:8080/users/{id}
    更新用户信息(Body 中包含 JSON 数据)
  • DELETE http://localhost:8080/users/{id}
    删除用户

测试

1. 创建一个简单的项目

src/main/java/com/example/demo 目录下创建一个名为 HelloController.java 的类:

package com.example.demo;

import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.RestController;

@RestController
public class HelloController {
  @GetMapping("/hello")
  public String hello() {
      return "Hello, World!";
  }
}

创建过程同 web 项目创建

2. 编写测试类

src/test/java/com/example/demo 目录下创建一个名为 HelloControllerTest.java 的测试类:

package com.example.demo;

import org.junit.jupiter.api.Test;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.boot.test.autoconfigure.web.servlet.AutoConfigureMockMvc;
import org.springframework.boot.test.context.SpringBootTest;
import org.springframework.test.context.junit.jupiter.web.SpringJUnitWebConfig;
import org.springframework.test.web.servlet.MockMvc;
import org.springframework.test.web.servlet.request.MockMvcRequestBuilders;
import org.springframework.test.web.servlet.result.MockMvcResultMatchers;

import static org.springframework.test.web.servlet.result.MockMvcResultHandlers.print;

@SpringBootTest
@AutoConfigureMockMvc
public class HelloControllerTest {

    @Autowired
    private MockMvc mockMvc;

    @Test
    public void helloTest() throws Exception {
        mockMvc.perform(MockMvcRequestBuilders.get("/hello"))
                .andExpect(MockMvcResultMatchers.status().isOk())
                .andExpect(MockMvcResultMatchers.content().string("Hello, World!"))
                .andDo(print());
    }
}

3. 解释测试类的关键点

  • @SpringBootTest: 这个注解告诉 Spring Boot 在测试时启动整个 Spring 应用程序上下文。
  • @AutoConfigureMockMvc: 这个注解确保在测试中自动配置 MockMvc 实例,用于模拟 HTTP 请求。
  • @Autowired private MockMvc mockMvc: 注入 MockMvc 实例,用于执行 HTTP 请求并验证响应。
  • @Test public void helloTest(): 这是一个 JUnit 测试方法,用来测试 HelloController 中的 hello() 方法。
  • mockMvc.perform(...): 执行一个 GET 请求到 /hello 接口。
  • andExpect(MockMvcResultMatchers.status().isOk()): 预期响应的状态码是 200 OK。
  • andExpect(MockMvcResultMatchers.content().string("Hello, World!")): 预期响应的内容是 "Hello, World!"。
  • andDo(print()): 打印请求和响应的详细信息,方便调试。

4. 运行测试

运行测试,确保程序正确.

部署与扩展

1. 打包方式

Spring Boot 应用程序可以打包为以下几种方式之一:

可执行 JAR 文件
  • 最常见的方式是将 Spring Boot 应用程序打包成一个可执行的 JAR 文件(Java Archive)。
  • JAR 文件中包含了所有的依赖项,可以通过 java -jar 命令来运行。
WAR 文件
  • 如果你需要将 Spring Boot 应用程序部署到外部的 Servlet 容器(如 Tomcat、Jetty 等),你可以将应用程序打包成一个 WAR 文件(Web Application Archive)。
  • WAR 文件适合传统的 Java Web 应用程序部署方式。

3. 打包过程概述

当你运行 Maven 的构建命令时,它们会执行以下几个主要步骤来打包你的应用程序:

  • 依赖项解析和下载:构建工具会检查你项目中的依赖项,下载缺失的依赖并构建整个依赖树。
  • 编译代码:构建工具会编译你的 Java 代码、资源文件等。
  • 运行测试:通常会执行单元测试和集成测试,确保代码质量和功能正确性。
  • 打包应用程序
    • 对于可执行 JAR 文件:构建工具会将编译后的类文件、资源文件和依赖项打包到一个 JAR 文件中。同时,它会生成一个 MANIFEST.MF 文件,指定应用程序的入口点(main class)。
    • 对于 WAR 文件:构建工具会将编译后的类文件、资源文件和依赖项打包成一个 WAR 文件,包括 WEB-INF 目录和其他必要的内容。
  • 输出结果:构建工具会在指定的目录下生成打包好的 JAR 或 WAR 文件,通常位于 target 目录下(Maven)。

在你的 Spring Boot 项目中,通常有一个入口类(如 Application.java 或者根据你的项目命名)。这个类使用 @SpringBootApplication 注解标记,它包含了 main 方法用来启动应用程序。

2. 打包工具

通常使用以下两种构建工具来打包 Spring Boot 应用程序:

Maven
  • 使用 Maven 的 mvn package 命令可以将应用程序打包为 JAR 或 WAR 文件。
  • pom.xml 文件中,Spring Boot 应用程序通常会依赖于 spring-boot-starter-parent 父项目,这简化了 Maven 配置和依赖管理。

4. 示例

假设你有一个简单的 Spring Boot 应用程序,并且已经配置好了 Maven 或 Gradle。运行以下命令即可进行打包:

  • Mavenmvn clean package

构建工具会执行以上步骤,生成可执行的 JAR 文件或 WAR 文件,你可以根据需要进行部署和运行。

标签:依赖,Java,Spring,Boot,应用程序,spring,org
From: https://blog.csdn.net/Young_Pro/article/details/141433417

相关文章

  • 构建Spring Boot应用的微服务服务链路追踪
    构建SpringBoot应用的微服务服务链路追踪大家好,我是微赚淘客返利系统3.0的小编,是个冬天不穿秋裤,天冷也要风度的程序猿!在微服务架构中,服务链路追踪是确保服务调用流程透明化和问题定位的关键技术。SpringBoot结合SpringCloudSleuth和Zipkin等工具,可以轻松实现服务链路追踪。......
  • 实战:软件架构系列之【早期微服务架构Spring Cloud Netflix中的5大组件示例】
    概叙科普文:万字细说微服务及其框架Netflix,SpringCloud,SpringCloudAlibaba梳理_微服务netflixalibaba-CSDN博客科普文:微服务之技术选型SpringCloudAlibaba_微服务架构图阿里巴巴-CSDN博客SpringCloudNetflix是SpringCloud生态系统中最早期的一个子项目,它为Spr......
  • springboot+vue高校招生管理系统【程序+论文+开题】-计算机毕业设计
    系统程序文件列表开题报告内容研究背景随着高等教育普及化进程的加速,高校招生工作面临着前所未有的挑战与机遇。传统的招生管理模式依赖于人工操作,不仅效率低下,而且容易出错,难以适应大规模、高效率、高准确性的现代招生需求。同时,考生信息的安全与隐私保护、招生流程的透明......
  • springboot+vue高校疫情防控系统的设计与实现【程序+论文+开题】-计算机毕业设计
    系统程序文件列表开题报告内容研究背景近年来,全球公共卫生安全面临着前所未有的挑战,尤其是新冠疫情的爆发,对各行各业,尤其是教育领域产生了深远影响。高校作为人员密集、流动性大的场所,其疫情防控工作尤为重要且复杂。传统的人工管理方式已难以满足当前高效、精准、全面的疫......
  • springboot+vue高校疫情防控系统【程序+论文+开题】-计算机毕业设计
    系统程序文件列表开题报告内容研究背景在全球新冠疫情持续蔓延的背景下,高校作为人员密集、流动性强的特殊场所,其疫情防控工作显得尤为重要。随着疫情形势的不断变化,传统的人工管理方式已难以满足高效、精准、全面的防控需求。因此,构建一套智能化、集成化的高校疫情防控系统......
  • java+vue计算机毕设流浪动物救助系统的设计与实现【源码+开题+论文】
    本系统(程序+源码)带文档lw万字以上文末可获取一份本项目的java源码和数据库参考。系统程序文件列表开题报告内容研究背景:随着城市化进程的加速,流浪动物问题日益凸显,成为社会各界关注的焦点。大量流浪动物不仅在城市中四处游荡,影响市容市貌,还可能携带病菌,对公共卫生安全构......
  • java+vue计算机毕设基于智能匹配的体育场馆预约系统APP【源码+开题+论文】
    本系统(程序+源码)带文档lw万字以上文末可获取一份本项目的java源码和数据库参考。系统程序文件列表开题报告内容研究背景随着全民健身意识的不断提升和体育产业的蓬勃发展,体育场馆作为承载各类体育活动的重要场所,其供需矛盾日益凸显。传统的人工预约方式不仅效率低下,且难......
  • java+vue计算机毕设辽宁财贸学院选课系统【源码+开题+论文】
    本系统(程序+源码)带文档lw万字以上文末可获取一份本项目的java源码和数据库参考。系统程序文件列表开题报告内容研究背景随着信息技术的飞速发展和高等教育改革的不断深入,高校教学管理系统面临着前所未有的挑战与机遇。辽宁财贸学院作为一所培养财经、贸易类人才的学府,其......
  • Java计算机毕业设计至诚驾校管理系统(开题+源码+论文)
    本系统(程序+源码)带文档lw万字以上 文末可获取一份本项目的java源码和数据库参考。系统程序文件列表开题报告内容研究背景随着汽车保有量的持续增长与驾驶需求的日益增加,驾校行业迎来了前所未有的发展机遇与挑战。传统的手工管理模式已难以满足驾校高效、精准、便捷的管理......
  • java计算机毕业设计幼儿园管理系统(开题+程序+论文)
    本系统(程序+源码)带文档lw万字以上 文末可获取一份本项目的java源码和数据库参考。系统程序文件列表开题报告内容研究背景:随着教育信息化步伐的加快,传统的手工管理模式已难以满足现代幼儿园高效、精准、透明的运营管理需求。当前,幼儿园面临着学生信息管理复杂、家园沟通不......