手记

Springboot资料入门详解

概述

本文提供了关于Spring Boot框架的全面介绍,包括其基本概念、优势特点、安装配置以及项目实战等详细内容。文章还涵盖了Spring Boot应用的开发流程,从环境搭建到项目创建、运行和打包部署的完整步骤。此外,文章中还提供了丰富的Spring Boot资料,帮助开发者快速上手并掌握Spring Boot的核心功能。

Spring Boot简介

Spring Boot 是一个基于 Spring 框架的全面解决方案,用于简化新 Spring 应用的初始搭建以及开发过程。Spring Boot 在 Spring 的核心特性上提供了一整套功能,使得开发者无需配置大量的 XML 文件或繁琐的代码,即可快速搭建 Spring 应用程序。

Spring Boot是什么

Spring Boot 是由 Pivotal 团队开发的一个框架,它旨在简化新 Spring 应用的初始搭建以及开发过程。它通过约定优于配置的原则,帮助开发者快速搭建独立运行的 Spring 应用。Spring Boot 通过提供默认配置,使得开发者可以专注于业务逻辑的实现,而不是繁杂的配置文件设置。例如,Spring Boot 可自动配置数据库连接和模板引擎,大大减少了配置工作量。

Spring Boot的优势和特点
  1. 简化配置:Spring Boot 通过约定优于配置的原则,自动配置了大量的默认设置,使得开发过程更加简洁。
  2. 自动配置:Spring Boot 可以自动配置数据库连接、模板引擎等,减少手动配置的工作量。
  3. 独立运行:Spring Boot 应用可以打包成独立的可执行 jar 或 war 文件,支持嵌入式 Web 服务器(如 Tomcat、Jetty 等),使得应用可以直接运行,无需部署到单独的 Web 服务器上。
  4. 嵌入式容器:Spring Boot 支持多种 Web 服务器,如 Tomcat、Jetty 和 Undertow,开发者可以选择自己熟悉的 Web 服务器来运行应用。
  5. 插件支持:Spring Boot 提供了一系列插件,如 Spring Data、Spring Security 等,方便开发者快速集成。
  6. 云部署:Spring Boot 应用支持云部署,如 Docker、Kubernetes 等。
  7. 监控和健康检查:Spring Boot 提供了内置的健康检查和监控功能,使得应用更容易进行监控和管理。
  8. 快速构建:Spring Boot 提供了快速构建应用的能力,开发者可以快速验证想法和概念。
安装与配置Spring Boot
安装Java开发环境

开发 Spring Boot 应用首先需要安装 Java 开发环境。Java 8 或更高版本是 Spring Boot 的最低要求。以下是安装 Java 的基本步骤:

  1. 访问 Oracle 官方网站 或其他提供 Java 安装包的网站。
  2. 下载并安装适合操作系统的 Java 开发工具包(JDK),注意选择与系统匹配的版本。
  3. 安装完成后,可以通过命令行检查 Java 是否安装成功:
    java -version

    如果成功安装,该命令会打印出 Java 的版本信息,例如:

    java version "1.8.0_261"
    Java(TM) SE Runtime Environment (build 1.8.0_261-b12)
    Java HotSpot(TM) 64-Bit Server VM (build 25.261-b12, mixed mode)
安装Spring Boot开发工具

Spring Boot 应用开发通常使用 IDE(集成开发环境)如 IntelliJ IDEA 或 Eclipse。这里以 IntelliJ IDEA 为例进行说明。

  1. 访问 IntelliJ IDEA 官网 并下载最新版本。
  2. 安装 IntelliJ IDEA。
  3. 在 IDE 中安装 Spring Boot 插件。可以通过 IDE 的插件市场搜索 "Spring Boot" 并安装。
  4. 安装完成后,IDE 会提示插件安装成功,用户可以在菜单栏中看到 Spring Boot 相关的功能选项。
创建Spring Boot项目
  1. 打开 IntelliJ IDEA,选择“File” -> “New” -> “Project”。
  2. 在弹出的窗口中选择“Spring Initializr”,然后点击“Next”。
  3. 在“POM”或“Gradle”选项中选择一个你喜欢的构建工具(这里以 Maven 为例)。
  4. 填写项目信息,如:Group、Artifact、Name、Version、Package,然后点击“Next”。
  5. 在“Dependencies”选项中选择需要的依赖,如 Spring Boot Starter Web。
  6. 点击“Finish”,IDE 会自动创建项目并下载所需依赖。
第一个Spring Boot应用
创建Hello World项目

创建一个简单的 Spring Boot 项目,实现一个简单的 RESTful API,返回 "Hello World"。

  1. 在创建项目时,选择“Spring Initializr” -> “Maven”或“Gradle” -> “Java” -> “Web”依赖。
  2. 项目创建成功后,会在 src/main/java 目录下生成一个包,包的名称就是你在创建项目时设置的 Package
  3. 在该包下创建一个控制器类 HelloController,代码如下:

    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";
       }
    }
运行项目
  1. 右键点击项目根目录下的 ApplicationDemoApplication 类,选择“Run 'Application.main()'”或“Run 'DemoApplication.main()’”。
  2. 打开浏览器,访问 http://localhost:8080/hello,看到返回 "Hello World" 即表示项目运行成功。
项目结构介绍

Spring Boot 项目的典型目录结构如下:

  • src/main/java:存放应用的所有 Java 源代码,包括控制器、服务、实体类等。
  • src/main/resources:存放应用的所有资源文件,包括配置文件、模板文件等。
  • src/test/java:存放测试代码。
  • pom.xmlbuild.gradle:项目构建配置文件。
Spring Boot常用配置
配置文件介绍

Spring Boot 项目中常用的配置文件有 application.propertiesapplication.yml。这些文件位于 src/main/resources 目录下。配置文件中的键值对用于定义应用程序的配置项,如数据库连接信息、端口号设置等。

示例:application.properties 文件内容如下:

spring.datasource.url=jdbc:mysql://localhost:3306/mydb
spring.datasource.username=root
spring.datasource.password=root
spring.datasource.driver-class-name=com.mysql.cj.jdbc.Driver
数据库连接配置

Spring Boot 支持多种数据库,如 MySQL、PostgreSQL、H2 等。下面以 MySQL 为例,介绍如何配置数据库连接。

  1. pom.xml 中添加 MySQL 的依赖:

    <dependency>
       <groupId>mysql</groupId>
       <artifactId>mysql-connector-java</artifactId>
    </dependency>
  2. application.properties 文件中配置数据库连接信息:

    spring.datasource.url=jdbc:mysql://localhost:3306/mydb
    spring.datasource.username=root
    spring.datasource.password=root
    spring.datasource.driver-class-name=com.mysql.cj.jdbc.Driver
  3. 在应用中注入数据源并使用:

    import org.springframework.beans.factory.annotation.Autowired;
    import org.springframework.boot.CommandLineRunner;
    import org.springframework.jdbc.core.JdbcTemplate;
    import org.springframework.stereotype.Component;
    
    @Component
    public class DatabaseInit implements CommandLineRunner {
    
       private JdbcTemplate jdbcTemplate;
    
       @Autowired
       public DatabaseInit(JdbcTemplate jdbcTemplate) {
           this.jdbcTemplate = jdbcTemplate;
       }
    
       @Override
       public void run(String... args) throws Exception {
           jdbcTemplate.execute("CREATE TABLE IF NOT EXISTS users (id INT, name VARCHAR(255))");
       }
    }
  4. 创建一个简单的数据库表:
    CREATE TABLE IF NOT EXISTS users (id INT AUTO_INCREMENT PRIMARY KEY, name VARCHAR(255));
日志配置

Spring Boot 使用 Logback 作为默认的日志框架,配置文件 logback-spring.xml 位于 src/main/resources 目录下。

示例:logback-spring.xml 文件内容如下:

<configuration>
    <appender name="STDOUT" class="ch.qos.logback.core.ConsoleAppender">
        <encoder>
            <pattern>%d{HH:mm:ss.SSS} [%thread] %-5level %logger{36} - %msg%n</pattern>
        </encoder>
    </appender>

    <root level="info">
        <appender-ref ref="STDOUT" />
    </root>
</configuration>
Spring Boot常用注解
常用注解简介

Spring Boot 中常用的注解包括:

  • @Controller:用于定义控制器类,处理 HTTP 请求。
  • @Service:用于定义业务逻辑层,处理具体业务逻辑。
  • @Repository:用于定义数据访问层,处理数据库操作。
  • @Component:通用注解,表示一个组件。
  • @Autowired:用于自动装配。
  • @RequestMapping:用于映射 HTTP 请求到方法。
  • @RestController:用于定义 RESTful API 控制器。
@Controller, @Service, @Repository, @Component说明

这些注解用于定义不同类型的应用组件,Spring Boot 会自动扫描并注册这些组件。

  • @Controller:用于定义控制器类,处理 HTTP 请求。

    @Controller
    public class WebController {
      @GetMapping("/web")
      public String web() {
          return "web";
      }
    }
  • @Service:用于定义业务逻辑层,处理具体业务逻辑。

    @Service
    public class UserService {
      public void addUser(User user) {
          // 添加用户逻辑
      }
    }
  • @Repository:用于定义数据访问层,处理数据库操作。

    @Repository
    public class UserRepository {
      public User getUserById(int id) {
          // 查询用户逻辑
          return new User();
      }
    }
  • @Component:通用注解,表示一个组件。
    @Component
    public class CommonService {
      public void commonMethod() {
          // 公共方法逻辑
      }
    }
@Autowired, @RequestMapping, @RestController使用
  • @Autowired:表示自动装配,用于注入依赖。

    @Autowired
    private UserService userService;
  • @RequestMapping:用于映射 HTTP 请求到方法。

    @RequestMapping("/users")
    public String users() {
      return "users";
    }
  • @RestController:用于定义 RESTful API 控制器。

    @RestController
    public class UserController {
      @Autowired
      private UserService userService;
    
      @GetMapping("/users")
      public List<User> getUsers() {
          return userService.getAllUsers();
      }
    }
Spring Boot项目实战
创建RESTful API接口

创建一个简单的 RESTful API 接口,提供用户管理功能。

  1. pom.xml 中添加 Spring Web 依赖:

    <dependency>
       <groupId>org.springframework.boot</groupId>
       <artifactId>spring-boot-starter-web</artifactId>
    </dependency>
  2. 创建 UserController 类,定义 RESTful API 接口。

    import org.springframework.web.bind.annotation.GetMapping;
    import org.springframework.web.bind.annotation.RestController;
    import java.util.ArrayList;
    import java.util.List;
    
    @RestController
    public class UserController {
    
       @GetMapping("/users")
       public List<User> getUsers() {
           List<User> users = new ArrayList<>();
           // 假设从数据库中获取用户列表
           return users;
       }
    }
实战案例解析

创建一个简单的用户管理系统,包括增删改查功能。

  1. 创建 User 实体类。

    public class User {
       private int id;
       private String name;
       private String email;
    
       // 构造函数、getter 和 setter 方法
    }
  2. 创建 UserService 业务逻辑层。

    import org.springframework.stereotype.Service;
    import java.util.ArrayList;
    import java.util.List;
    
    @Service
    public class UserService {
       private List<User> users = new ArrayList<>();
    
       public User addUser(User user) {
           users.add(user);
           return user;
       }
    
       public User getUserById(int id) {
           for (User user : users) {
               if (user.getId() == id) {
                   return user;
               }
           }
           return null;
       }
    
       public List<User> getAllUsers() {
           return users;
       }
    
       public User updateUser(User user) {
           int index = users.indexOf(user);
           if (index != -1) {
               users.set(index, user);
               return user;
           }
           return null;
       }
    
       public void deleteUser(int id) {
           users.removeIf(user -> user.getId() == id);
       }
    }
  3. 创建 UserController 控制器。

    import org.springframework.web.bind.annotation.*;
    
    @RestController
    public class UserController {
    
       @Autowired
       private UserService userService;
    
       @GetMapping("/users")
       public List<User> getUsers() {
           return userService.getAllUsers();
       }
    
       @PostMapping("/users")
       public User addUser(@RequestBody User user) {
           return userService.addUser(user);
       }
    
       @GetMapping("/users/{id}")
       public User getUserById(@PathVariable int id) {
           return userService.getUserById(id);
       }
    
       @PutMapping("/users")
       public User updateUser(@RequestBody User user) {
           return userService.updateUser(user);
       }
    
       @DeleteMapping("/users/{id}")
       public void deleteUser(@PathVariable int id) {
           userService.deleteUser(id);
       }
    }
项目打包与部署

Spring Boot 应用可以通过 Maven 或 Gradle 进行打包,生成独立的可执行 jar 或 war 文件。

  1. 打包 jar 文件:

    • 使用 Maven:
      mvn clean package
    • 使用 Gradle:
      gradle clean bootJar
  2. 运行打包后的 jar 文件:

    java -jar target/your-project.jar
  3. 部署到云环境:
    • 使用 Docker:
      FROM openjdk:8-jdk-alpine
      VOLUME /tmp
      COPY target/your-project.jar your-project.jar
      EXPOSE 8080
      ENTRYPOINT ["java","-Djava.security.egd=file:/dev/./urandom","-jar","/your-project.jar"]
    • 使用 Kubernetes:
      apiVersion: apps/v1
      kind: Deployment
      metadata:
      name: your-deployment
      spec:
      replicas: 1
      selector:
       matchLabels:
         app: your-app
      template:
       metadata:
         labels:
           app: your-app
       spec:
         containers:
         - name: your-app
           image: your-image:tag
           ports:
           - containerPort: 8080
0人推荐
随时随地看视频
慕课网APP