继续浏览精彩内容
慕课网APP
程序员的梦工厂
打开
继续
感谢您的支持,我会继续努力的
赞赏金额会直接到老师账户
将二维码发送给自己后长按识别
微信支付
支付宝支付

Springboot框架教程:初学者必看指南

jeck猫
关注TA
已关注
手记 460
粉丝 75
获赞 402
概述

本文详细介绍了Spring Boot框架的基本概念、优势和特点,帮助开发者快速上手并理解如何通过少量配置启动一个独立的Spring应用。文章还提供了从安装Java和Maven到创建和运行第一个Spring Boot项目的完整步骤,涵盖了Spring Boot的核心配置、常用组件集成和实战案例。

Spring Boot简介

什么是Spring Boot

Spring Boot是由Pivotal团队提供的全新框架,其设计目的是用来简化Spring应用的初始搭建以及开发过程。通过Spring Boot,开发者无需编写大量配置代码,只需通过少量的配置即可快速构建一个独立运行的Spring应用。Spring Boot在开发工具和项目框架方面提供了诸多便利,使得开发者可以专注于业务逻辑的实现。

Spring Boot的核心概念是约定优于配置,这意味着它提供了大量默认配置,从而减少了开发者需要手动配置的代码量。Spring Boot通过这种方式来降低学习曲线,使得开发者可以快速上手。

Spring Boot的优势和特点

  1. 快速启动: Spring Boot提供了快速的集成和开发体验,减少了繁琐的配置。
  2. 自动配置: Spring Boot根据类路径中的jar依赖自动配置应用程序。这使得开发者可以快速启动项目,而无需编写大量样板代码。
  3. 独立运行: Spring Boot应用程序可以独立运行,并且能够打包为可执行的jar文件,从而简化了部署过程。
  4. 无代码生成: Spring Boot不需要任何XML配置,所有的配置都可以通过注解和属性文件来完成。
  5. 嵌入式服务器: Spring Boot支持内嵌的Tomcat、Jetty和Undertow服务器,简化了部署过程。
  6. 外部化配置: Spring Boot支持配置的外部化,通过配置文件或环境变量来设置配置值。
  7. 健康检查: Spring Boot提供了健康检查的功能,可以帮助开发者监控应用程序的状态。

Spring Boot与传统Spring的区别

Spring Boot简化了Spring的配置过程,提供了许多默认配置,使得开发者能够更加专注于业务逻辑的实现。以下是Spring Boot与传统Spring的主要区别:

  1. 配置方式:

    • 传统Spring: 需要大量的XML配置文件或Java配置类。
    • Spring Boot: 使用注解和属性文件来替代大量的配置代码,提供自动配置。
  2. 嵌入式服务器:

    • 传统Spring: 需要一个独立的服务器(如Tomcat)来运行Spring应用。
    • Spring Boot: 内嵌了Tomcat、Jetty和Undertow等服务器,可以独立启动和运行。
  3. 打包方式:

    • 传统Spring: 通常打包为一个WAR文件,部署在独立的服务器上。
    • Spring Boot: 打包为一个独立的可执行jar文件,具有内嵌的服务器。
  4. 依赖管理:

    • 传统Spring: 手动管理依赖,需要在项目中添加各种依赖库。
    • Spring Boot: 通过Maven或Gradle的依赖管理来自动管理这些依赖。
  5. 快速开发:
    • 传统Spring: 需要编写大量的样板代码和配置文件。
    • Spring Boot: 提供了快速开发特性,减少了大量样板代码,简化了开发过程。
快速入门

安装Java和Maven

在开始之前,你需要确保已经安装了Java和Maven。Java是Spring Boot运行时所需的环境,而Maven则是构建工具。

安装Java

  1. 访问Oracle官网下载Java SE JDK。
  2. 安装Java后,设置环境变量。
    • Windows:
      set JAVA_HOME=C:\Program Files\Java\jdk1.8.0_221
      set PATH=%JAVA_HOME%\bin;%PATH%
    • Linux/Mac:
      export JAVA_HOME=/usr/lib/jvm/java-1.8.0-openjdk
      export PATH=$JAVA_HOME/bin:$PATH
  3. 验证安装:
    java -version

安装Maven

  1. 访问Maven官网下载Maven。
  2. 解压下载的Maven压缩包。
  3. 设置环境变量。
    • Windows:
      set MAVEN_HOME=C:\path\to\apache-maven-3.6.3
      set PATH=%MAVEN_HOME%\bin;%PATH%
    • Linux/Mac:
      export MAVEN_HOME=/path/to/apache-maven-3.6.3
      export PATH=$MAVEN_HOME/bin:$PATH
  4. 验证安装:
    mvn -version

创建第一个Spring Boot项目

现在你已经安装好了Java和Maven,接下来我们将创建第一个Spring Boot项目。

  1. 创建一个新的目录作为项目的根目录。
  2. 初始化一个新的Maven项目。
    mvn archetype:generate -DgroupId=com.example -DartifactId=spring-boot-app -DarchetypeArtifactId=maven-archetype-quickstart -DinteractiveMode=false
  3. 切换到项目目录。
    cd spring-boot-app
  4. 修改pom.xml文件,添加Spring Boot依赖。

    <project xmlns="http://maven.apache.org/POM/4.0.0"
            xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
            xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
       <modelVersion>4.0.0</modelVersion>
       <groupId>com.example</groupId>
       <artifactId>spring-boot-app</artifactId>
       <version>0.0.1-SNAPSHOT</version>
       <parent>
           <groupId>org.springframework.boot</groupId>
           <artifactId>spring-boot-starter-parent</artifactId>
           <version>2.4.2</version>
       </parent>
       <dependencies>
           <dependency>
               <groupId>org.springframework.boot</groupId>
               <artifactId>spring-boot-starter-web</artifactId>
           </dependency>
       </dependencies>
       <build>
           <plugins>
               <plugin>
                   <groupId>org.springframework.boot</groupId>
                   <artifactId>spring-boot-maven-plugin</artifactId>
               </plugin>
           </plugins>
       </build>
    </project>

运行第一个Spring Boot应用

为了运行第一个Spring Boot应用,你需要编写一个简单的控制器类。

  1. 创建一个名为HelloController.java的文件在src/main/java/com/example/springbootapp路径下,内容如下:

    package com.example.springbootapp;
    
    import org.springframework.boot.SpringApplication;
    import org.springframework.boot.autoconfigure.SpringBootApplication;
    import org.springframework.web.bind.annotation.GetMapping;
    import org.springframework.web.bind.annotation.RestController;
    
    @SpringBootApplication
    @RestController
    public class HelloController {
    
       @GetMapping("/")
       public String hello() {
           return "Hello Spring Boot!";
       }
    
       public static void main(String[] args) {
           SpringApplication.run(HelloController.class, args);
       }
    }
  2. 运行应用程序:

    mvn spring-boot:run
  3. 打开浏览器,访问http://localhost:8080/,你应该能看到页面上输出了“Hello Spring Boot!”。
核心配置

Spring Boot配置文件详解

Spring Boot提供了多种配置文件,常见的配置文件有application.propertiesapplication.yml。这些文件用于配置应用程序的各种属性,如端口、数据库连接信息、日志级别等。

application.properties

以下是一些常用的属性配置示例:

# 端口号
server.port=8080

# 控制台日志级别
logging.level.root=INFO

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

application.yml

以下是一些常用的YAML属性配置示例:

server:
  port: 8080

logging:
  level:
    root: INFO

spring:
  datasource:
    url: jdbc:mysql://localhost:3306/mydb
    username: root
    password: secret
    driver-class-name: com.mysql.cj.jdbc.Driver

使用注解简化配置

Spring Boot提供了许多注解来简化配置过程。以下是一些常用的注解:

  • @SpringBootApplication: 组合注解,包含了@Configuration@EnableAutoConfiguration@ComponentScan
  • @Configuration: 标识一个配置类。
  • @EnableAutoConfiguration: 启用自动配置。
  • @ComponentScan: 指定Spring扫描组件的包。

示例代码

package com.example.springbootapp;

import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;

@SpringBootApplication
public class Application {
    public static void main(String[] args) {
        SpringApplication.run(Application.class, args);
    }
}

环境变量和外部配置文件

Spring Boot支持使用环境变量和外部配置文件来覆盖默认配置。环境变量的名称需要符合SPRING_前缀命名规则。

使用环境变量

通过环境变量覆盖配置文件中的属性值。

export SPRING_DATASOURCE_URL=jdbc:mysql://otherdb:3306/mydb

使用外部配置文件

外部配置文件可以放在src/main/resources目录下,或者放在resources目录下。

# external-config.yml
server:
  port: 9090

spring:
  datasource:
    url: jdbc:mysql://localhost:3306/mydb2

application.properties中引用外部配置文件:

spring.config.location=classpath:/external-config.yml
常用组件介绍

Spring Boot集成数据库

Spring Boot可以很方便地集成各种数据库,比如MySQL、PostgreSQL、H2等。

配置MySQL

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

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

    spring.datasource.url=jdbc:mysql://localhost:3306/mydb
    spring.datasource.username=root
    spring.datasource.password=secret
    spring.datasource.driver-class-name=com.mysql.cj.jdbc.Driver
  3. 创建数据源配置类:

    package com.example.springbootapp.config;
    
    import org.springframework.boot.jdbc.DataSourceBuilder;
    import org.springframework.context.annotation.Bean;
    import org.springframework.context.annotation.Configuration;
    
    import javax.sql.DataSource;
    
    @Configuration
    public class DataSourceConfig {
    
       @Bean
       public DataSource dataSource() {
           return DataSourceBuilder.create()
                   .driverClassName("com.mysql.cj.jdbc.Driver")
                   .url("jdbc:mysql://localhost:3306/mydb")
                   .username("root")
                   .password("secret")
                   .build();
       }
    }

连接测试

为了验证数据库连接是否成功,可以在HelloController中添加一个测试方法:

import javax.sql.DataSource;

@RestController
public class HelloController {

    private final DataSource dataSource;

    public HelloController(DataSource dataSource) {
        this.dataSource = dataSource;
    }

    @GetMapping("/test-db")
    public String testDb() {
        try (var connection = dataSource.getConnection()) {
            return "Database connection successful!";
        } catch (Exception e) {
            return "Database connection failed!";
        }
    }
}

Spring Boot集成Web开发

Spring Boot提供了多种集成Web开发的功能,包括Spring MVC、Thymeleaf模板引擎等。

配置Spring MVC

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

    <dependency>
       <groupId>org.springframework.boot</groupId>
       <artifactId>spring-boot-starter-web</artifactId>
    </dependency>
  2. 创建控制器类:

    package com.example.springbootapp;
    
    import org.springframework.web.bind.annotation.GetMapping;
    import org.springframework.web.bind.annotation.RequestMapping;
    import org.springframework.web.bind.annotation.ResponseBody;
    
    @RestController
    @RequestMapping("/api")
    public class MyController {
    
       @GetMapping("/hello")
       @ResponseBody
       public String hello() {
           return "Hello, Spring Boot Web!";
       }
    }

测试Web服务

为了验证Web服务是否运行正常,可以访问http://localhost:8080/api/hello,应返回Hello, Spring Boot Web!

Spring Boot集成缓存和消息队列

集成Redis缓存

  1. pom.xml中添加Redis依赖:

    <dependency>
       <groupId>org.springframework.boot</groupId>
       <artifactId>spring-boot-starter-data-redis</artifactId>
    </dependency>
  2. 配置Redis连接信息:

    spring.redis.host=localhost
    spring.redis.port=6379
  3. 创建缓存配置类:

    package com.example.springbootapp.config;
    
    import org.springframework.cache.annotation.EnableCaching;
    import org.springframework.context.annotation.Bean;
    import org.springframework.context.annotation.Configuration;
    import org.springframework.data.redis.connection.RedisConnectionFactory;
    import org.springframework.data.redis.connection.jedis.JedisConnectionFactory;
    import org.springframework.data.redis.core.RedisTemplate;
    import org.springframework.data.redis.serializer.StringRedisSerializer;
    
    @Configuration
    @EnableCaching
    public class RedisConfig {
    
       @Bean
       public JedisConnectionFactory jedisConnectionFactory() {
           return new JedisConnectionFactory();
       }
    
       @Bean
       public RedisTemplate<String, Object> redisTemplate(RedisConnectionFactory factory) {
           RedisTemplate<String, Object> template = new RedisTemplate<>();
           template.setConnectionFactory(factory);
           template.setKeySerializer(new StringRedisSerializer());
           template.setValueSerializer(new StringRedisSerializer());
           return template;
       }
    }

缓存使用示例

为了验证缓存是否生效,可以在HelloController中添加一个缓存示例:

import org.springframework.cache.annotation.Cacheable;
import org.springframework.web.bind.annotation.GetMapping;

@RestController
public class HelloController {

    @GetMapping("/hello-cache")
    @Cacheable(value = "helloCache", key = "#name")
    public String hello(String name) {
        // 模拟耗时操作
        Thread.sleep(2000);
        return "Hello " + name + "!";
    }
}

集成RabbitMQ消息队列

  1. pom.xml中添加RabbitMQ依赖:

    <dependency>
       <groupId>org.springframework.boot</groupId>
       <artifactId>spring-boot-starter-amqp</artifactId>
    </dependency>
  2. 配置RabbitMQ连接信息:

    spring.rabbitmq.host=localhost
    spring.rabbitmq.port=5672
    spring.rabbitmq.username=guest
    spring.rabbitmq.password=guest
  3. 创建消息发送者:

    package com.example.springbootapp;
    
    import org.springframework.amqp.rabbit.core.RabbitTemplate;
    import org.springframework.beans.factory.annotation.Autowired;
    import org.springframework.stereotype.Component;
    
    @Component
    public class MessagePublisher {
    
       @Autowired
       private RabbitTemplate rabbitTemplate;
    
       public void sendMessage(String message) {
           rabbitTemplate.convertAndSend("helloQueue", message);
       }
    }
  4. 创建消息接收者:

    package com.example.springbootapp;
    
    import org.springframework.amqp.rabbit.annotation.RabbitListener;
    import org.springframework.stereotype.Component;
    
    @Component
    public class MessageReceiver {
    
       @RabbitListener(queues = "helloQueue")
       public void receive(String message) {
           System.out.println("Received message: " + message);
       }
    }
实战案例

创建一个简单的RESTful API

使用Spring Boot创建RESTful API

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

    <dependency>
       <groupId>org.springframework.boot</groupId>
       <artifactId>spring-boot-starter-web</artifactId>
    </dependency>
  2. 创建一个简单的RESTful API控制器:

    package com.example.springbootapp;
    
    import org.springframework.http.HttpStatus;
    import org.springframework.http.ResponseEntity;
    import org.springframework.web.bind.annotation.GetMapping;
    import org.springframework.web.bind.annotation.RestController;
    
    @RestController
    public class SimpleApi {
    
       @GetMapping("/api/hello")
       public ResponseEntity<String> hello() {
           return new ResponseEntity<>("Hello, RESTful API!", HttpStatus.OK);
       }
    }
  3. 修改application.properties添加API路径:

    server.port=8080
  4. 启动应用程序:

    mvn spring-boot:run
  5. 访问http://localhost:8080/api/hello,返回结果:

    Hello, RESTful API!

实现用户认证和授权

使用Spring Security实现认证和授权

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

    <dependency>
       <groupId>org.springframework.boot</groupId>
       <artifactId>spring-boot-starter-security</artifactId>
    </dependency>
  2. 创建一个简单的用户认证配置类:

    package com.example.springbootapp.config;
    
    import org.springframework.context.annotation.Bean;
    import org.springframework.context.annotation.Configuration;
    import org.springframework.security.config.annotation.web.builders.HttpSecurity;
    import org.springframework.security.config.annotation.web.configuration.EnableWebSecurity;
    import org.springframework.security.config.annotation.web.configuration.WebSecurityConfigurerAdapter;
    import org.springframework.security.core.userdetails.User;
    import org.springframework.security.core.userdetails.UserDetailsService;
    import org.springframework.security.provisioning.InMemoryUserDetailsManager;
    
    @Configuration
    @EnableWebSecurity
    public class SecurityConfig extends WebSecurityConfigurerAdapter {
    
       @Override
       protected void configure(HttpSecurity http) throws Exception {
           http
               .authorizeRequests()
                   .antMatchers("/api/hello").permitAll()
                   .antMatchers("/admin/**").hasRole("ADMIN")
                   .anyRequest().authenticated()
               .and()
                   .formLogin()
                   .loginPage("/login")
                   .permitAll()
               .and()
                   .logout()
                   .permitAll();
       }
    
       @Override
       @Bean
       public UserDetailsService userDetailsService() {
           InMemoryUserDetailsManager manager = new InMemoryUserDetailsManager();
           manager.createUser(User.withDefaultPasswordEncoder()
               .username("user")
               .password("password")
               .roles("USER")
               .build());
           manager.createUser(User.withDefaultPasswordEncoder()
               .username("admin")
               .password("admin")
               .roles("ADMIN")
               .build());
           return manager;
       }
    }
  3. 创建登录页面:

    <!DOCTYPE html>
    <html>
    <head>
       <title>Login Page</title>
    </head>
    <body>
       <form action="/login" method="post">
           <label>Email:</label>
           <input type="text" name="username" />
           <label>Password:</label>
           <input type="password" name="password" />
           <input type="submit" value="Login" />
       </form>
    </body>
    </html>
  4. 启动应用程序并访问http://localhost:8080/login,进行登录。

部署Spring Boot应用到服务器

使用Docker部署Spring Boot应用

  1. 创建Dockerfile

    FROM openjdk:8-jre-alpine
    VOLUME /tmp
    ARG JAR_FILE=target/*.jar
    COPY ${JAR_FILE} app.jar
    EXPOSE 8080
    ENTRYPOINT ["java","-Djava.security.egd=file:/dev/./urandom","-jar","/app.jar"]
  2. 构建Docker镜像:

    mvn clean package
    docker build -t spring-boot-app .
  3. 运行Docker容器:

    docker run -d -p 8080:8080 --name spring-boot-app spring-boot-app
  4. 访问http://localhost:8080,检查应用是否正常运行。
常见问题与解决方案

常见异常处理

程序找不到数据库连接

当程序无法连接到数据库时,确保数据库服务已经启动,并且配置文件中的连接信息正确无误。

程序找不到资源文件

检查资源文件路径是否正确,确保资源文件被包含在项目中,并且路径配置正确。

性能优化技巧

使用连接池

使用数据库连接池(如HikariCP)来管理数据库连接,避免频繁创建和销毁连接。

配置合理的线程池

配置合理的线程池大小,避免线程池过小或过大。

启用异步处理

对于耗时的操作,使用异步处理来提高响应速度。

版本管理和依赖冲突解决

使用spring-boot-starter-parent

使用spring-boot-starter-parent作为父POM,它已经包含了版本管理。

使用<dependencyManagement>

通过<dependencyManagement>标签来管理依赖版本。

使用mvn versions:display-dependency-conflicts

使用Maven插件versions:display-dependency-conflicts来显示依赖冲突。

<build>
    <plugins>
        <plugin>
            <groupId>org.codehaus.mojo</groupId>
            <artifactId>versions-maven-plugin</artifactId>
            <version>2.7</version>
        </plugin>
    </plugins>
</build>
mvn versions:display-dependency-conflicts

以上步骤可以帮助你更好地管理和解决Spring Boot项目中的依赖冲突问题。

打开App,阅读手记
0人推荐
发表评论
随时随地看视频慕课网APP