为了账号安全,请及时绑定邮箱和手机立即绑定

Springboot项目开发学习:新手入门指南

标签:
SpringBoot
概述

Spring Boot是一个简化Spring应用开发的框架,它提供了自动配置和开箱即用的功能,极大地提高了开发效率。本文将详细介绍如何进行Springboot项目开发学习,包括项目搭建、配置、控制器开发、服务层开发以及测试和部署等各个环节。Spring Boot通过其强大的功能和简便的配置,使得开发者能够快速构建独立的、生产级别的应用。

Spring Boot简介

Spring Boot是什么

Spring Boot是一个旨在简化Spring应用开发的框架,它最大限度地减少了配置的需要,使开发者可以快速构建独立的、生产级别的基于Spring的应用程序。Spring Boot提供了一系列的默认配置,使得开发者可以“约定优于配置”(Convention over Configuration)来开发应用,提升了开发效率,减少了代码量和配置文件的编写。

Spring Boot的优点

  1. 快速开发:Spring Boot简化了项目搭建的过程,提供了许多开箱即用的功能,如自动配置、内嵌服务器、热部署等,使得开发人员能更专注于业务逻辑的实现。
  2. 无需配置:Spring Boot提供默认配置,同时也支持自定义配置,减少了大量XML配置文件的编写工作。
  3. 无需容器:Spring Boot包括一个内嵌的Tomcat服务器,并且提供了自动配置的功能,不需要单独的容器支持,方便部署。
  4. 依赖管理:Spring Boot通过Spring Initializr简化了依赖的管理,只需要简单的注解就可以引入所需的依赖。
  5. 云集成:Spring Boot支持云平台(如:Spring Cloud),提供了对云服务的集成,可以方便地部署到云环境中。
  6. 生产就绪:Spring Boot内置了许多实用的生产特性,如健康检查、Metrics、外部化配置等功能。
  7. 无需重启:Spring Boot支持热部署,即不需要重启应用就能更新类文件或者配置文件。

快速开始一个Spring Boot项目

  1. 创建Spring Boot项目

    使用Spring Initializr(一个在线的项目生成工具)或者IDE中的插件来快速搭建Spring Boot项目。

  2. 添加依赖

    当创建完项目后,可以通过Spring Initializr向项目中添加需要的依赖,例如Web、JPA等。

  3. 编写应用

    下面是一个简单的Spring Boot应用示例,它包括一个启动类和一个控制器类。启动类中使用注解@SpringBootApplication来启动应用,并定义了一个简单的控制器类来处理HTTP请求。

    // 启动类
    @SpringBootApplication
    public class Application {
       public static void main(String[] args) {
           SpringApplication.run(Application.class, args);
       }
    }
    
    // 控制器类
    @RestController
    public class HelloWorldController {
    
       @GetMapping("/hello")
       public String hello() {
           return "Hello, World!";
       }
    }
  4. 运行应用

    运行Application类中的main方法即可启动应用。默认情况下,应用程序会在端口8080运行。使用浏览器或curl工具访问http://localhost:8080/hello,可以看到返回的”Hello, World!”信息。

  5. 测试应用

    src/test/java目录下创建一个测试类,用JUnit 5编写测试用例来验证应用是否按预期工作。

    import static org.springframework.test.web.servlet.request.MockMvcRequestBuilders.get;
    import static org.springframework.test.web.servlet.result.MockMvcResultMatchers.content;
    import static org.springframework.test.web.servlet.result.MockMvcResultMatchers.status;
    
    @SpringBootTest
    class ApplicationTests {
    
       @Autowired
       private MockMvc mockMvc;
    
       @Test
       void getHello() throws Exception {
           mockMvc.perform(get("/hello"))
               .andExpect(status().isOk())
               .andExpect(content().string("Hello, World!"));
       }
    }
  6. 打包并运行

    使用mvn clean packagegradle build命令打包项目,然后使用java -jar target/my-project-0.0.1-SNAPSHOT.jar命令启动应用。

Spring Boot项目搭建

使用IDEA创建Spring Boot项目

在IDEA中,可以通过欢迎界面或者现有项目创建新项目来创建Spring Boot项目。

  1. 在欢迎界面中创建新项目

    选择Spring Initializr,输入项目的基本信息(如:项目名称、语言、Spring Boot版本等),然后选择所需的依赖(如:Web、JPA等)。点击Finish按钮,等待项目创建完成。

  2. 在现有项目中创建Spring Boot项目

    打开IDEA,选择File -> New -> Project,选择Spring Initializr并填写项目的基本信息,选择所需的依赖,点击Finish按钮创建项目。

Maven和Gradle支持

Spring Boot支持使用Maven或Gradle进行依赖管理和构建。在Spring Boot项目中,Maven和Gradle的配置文件分别是pom.xmlbuild.gradle

  1. Maven配置

    pom.xml文件中,可以配置项目的依赖、插件和其他元数据。

    <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>demo</artifactId>
       <version>0.0.1-SNAPSHOT</version>
       <packaging>jar</packaging>
       <name>demo</name>
       <description>demo project for Spring Boot</description>
       <parent>
           <groupId>org.springframework.boot</groupId>
           <artifactId>spring-boot-starter-parent</artifactId>
           <version>2.7.1</version>
       </parent>
       <dependencies>
           <dependency>
               <groupId>org.springframework.boot</groupId>
               <artifactId>spring-boot-starter-web</artifactId>
           </dependency>
           <dependency>
               <groupId>org.springframework.boot</groupId>
               <artifactId>spring-boot-starter-data-jpa</artifactId>
           </dependency>
           <dependency>
               <groupId>com.h2database</groupId>
               <artifactId>h2</artifactId>
               <scope>runtime</scope>
           </dependency>
           <dependency>
               <groupId>org.springframework.boot</groupId>
               <artifactId>spring-boot-starter-test</artifactId>
               <scope>test</scope>
           </dependency>
       </dependencies>
       <build>
           <plugins>
               <plugin>
                   <groupId>org.springframework.boot</groupId>
                   <artifactId>spring-boot-maven-plugin</artifactId>
               </plugin>
           </plugins>
       </build>
    </project>
  2. Gradle配置

    build.gradle文件中,可以配置项目的依赖、插件和其他元数据。

    plugins {
       id 'org.springframework.boot' version '2.7.1'
       id 'io.spring.dependency-management' version '1.0.11.RELEASE'
       id 'java'
    }
    
    group = 'com.example'
    version = '0.0.1-SNAPSHOT'
    sourceCompatibility = '11'
    
    repositories {
       mavenCentral()
    }
    
    dependencies {
       implementation 'org.springframework.boot:spring-boot-starter-web'
       implementation 'org.springframework.boot:spring-boot-starter-data-jpa'
       runtimeOnly 'com.h2database:h2'
       testImplementation 'org.springframework.boot:spring-boot-starter-test'
    }

配置文件介绍

Spring Boot项目中最常用的配置文件是application.propertiesapplication.yml,用于配置应用的属性设置。

  1. 常见的配置项

    • 应用信息

      # application.properties
      spring.application.name=demo
    • 服务器配置

      # application.properties
      server.port=8080
      server.tomcat.max-threads=100
    • 数据源配置

      # application.properties
      spring.datasource.url=jdbc:mysql://localhost:3306/testdb
      spring.datasource.username=root
      spring.datasource.password=root
      spring.datasource.driver-class-name=com.mysql.cj.jdbc.Driver
    • JPA配置

      # application.properties
      spring.jpa.hibernate.ddl-auto=update
      spring.jpa.show-sql=true
      spring.jpa.properties.hibernate.dialect=org.hibernate.dialect.MySQL5InnoDBDialect
  2. 配置文件的加载顺序

    Spring Boot会按照以下顺序加载配置文件:

    1. @TestPropertySource 注解中的属性
    2. SpringBootTest#properties 属性中的值
    3. @SpringBootTest 注解中的properties 属性
    4. System.getProperties() 中的属性
    5. System.getenv() 环境变量中的属性
    6. application.propertiesapplication.yml 文件中的属性
控制器开发

创建控制器类

控制器类用于处理HTTP请求,并通过注解的形式将这些请求映射到方法上。在Spring Boot中,可以使用@RestController注解将类标记为控制器类。

@RestController
public class UserController {
    // 控制器方法
}

使用注解处理HTTP请求

Spring Boot提供了多个注解来处理HTTP请求。

  1. @GetMapping

    用于处理GET请求。

    @GetMapping("/users")
    public List<User> getUsers() {
       return userService.findAll();
    }
  2. @PostMapping

    用于处理POST请求。

    @PostMapping("/users")
    public User createUser(@RequestBody User user) {
       return userService.save(user);
    }
  3. @PutMapping

    用于处理PUT请求。

    @PutMapping("/users/{id}")
    public User updateUser(@PathVariable Long id, @RequestBody User user) {
       return userService.update(id, user);
    }
  4. @DeleteMapping

    用于处理DELETE请求。

    @DeleteMapping("/users/{id}")
    public void deleteUser(@PathVariable Long id) {
       userService.delete(id);
    }

返回JSON数据

Spring Boot会自动将Java对象转换为JSON格式来返回给客户端。

@GetMapping("/users")
public List<User> getUsers() {
    return userService.findAll();
}

如果需要自定义序列化和反序列化,可以使用@JsonFormat注解或自定义序列化器。

import com.fasterxml.jackson.annotation.JsonFormat;

@JsonFormat(shape = JsonFormat.Shape.STRING, pattern = "yyyy-MM-dd")
private Date birthdate;
模型层开发

定义实体类

实体类是模型层的核心,它们通常对应于数据库中的表。

@Entity
public class User {
    @Id
    @GeneratedValue(strategy = GenerationType.IDENTITY)
    private Long id;
    private String name;
    private String email;
    private Date birthdate;

    // 构造函数、getters和setters
}

使用JPA进行数据操作

Spring Boot与JPA紧密集成,提供了简单易用的数据操作功能。

  1. 查询

    @Repository
    public interface UserRepository extends JpaRepository<User, Long> {
       List<User> findByName(String name);
    }
  2. 存储

    @Service
    public class UserService {
       private final UserRepository userRepository;
    
       public UserService(UserRepository userRepository) {
           this.userRepository = userRepository;
       }
    
       public User save(User user) {
           return userRepository.save(user);
       }
    }
  3. 删除

    public void delete(User user) {
       userRepository.delete(user);
    }

数据库连接配置

默认情况下,Spring Boot使用H2内存数据库。可以通过更改配置文件来连接其他数据库,如MySQL或PostgreSQL。

# application.properties
spring.datasource.url=jdbc:mysql://localhost:3306/testdb
spring.datasource.username=root
spring.datasource.password=root
spring.datasource.driver-class-name=com.mysql.cj.jdbc.Driver
服务层开发

创建服务接口和实现类

服务层用于处理业务逻辑。

  1. 服务接口

    @Service
    public interface UserService {
       User save(User user);
       User findById(Long id);
       List<User> findAll();
       void delete(User user);
    }
  2. 服务实现类

    @Service
    public class UserServiceImpl implements UserService {
       private final UserRepository userRepository;
    
       public UserServiceImpl(UserRepository userRepository) {
           this.userRepository = userRepository;
       }
    
       @Override
       public User save(User user) {
           return userRepository.save(user);
       }
    
       @Override
       public User findById(Long id) {
           return userRepository.findById(id).orElse(null);
       }
    
       @Override
       public List<User> findAll() {
           return userRepository.findAll();
       }
    
       @Override
       public void delete(User user) {
           userRepository.delete(user);
       }
    }

事务管理

Spring Boot默认使用Spring的事务管理机制,可以通过注解@Transactional来定义事务边界。

@Transactional
public User save(User user) {
    return userRepository.save(user);
}

异常处理

可以使用@ControllerAdvice注解来定义全局异常处理。

@ControllerAdvice
public class GlobalExceptionHandler {

    @ExceptionHandler(ResourceNotFoundException.class)
    @ResponseStatus(HttpStatus.NOT_FOUND)
    public Map<String, String> handleResourceNotFoundException(ResourceNotFoundException ex) {
        return Collections.singletonMap("message", ex.getMessage());
    }
}
测试与部署

单元测试

src/test/java目录下创建测试类,使用JUnit 5进行单元测试。

import static org.springframework.test.web.servlet.request.MockMvcRequestBuilders.post;
import static org.springframework.test.web.servlet.result.MockMvcResultMatchers.content;
import static org.springframework.test.web.servlet.result.MockMvcResultMatchers.status;

@SpringBootTest
class UserServiceTests {

    @Autowired
    private MockMvc mockMvc;

    @Test
    void testSaveUser() throws Exception {
        User user = new User();
        user.setName("John Doe");

        String json = "{\"name\": \"John Doe\"}";
        this.mockMvc.perform(post("/users")
                .contentType(MediaType.APPLICATION_JSON)
                .content(json))
                .andExpect(status().isOk());
    }
}

集成测试

集成测试可以验证多个组件之间的交互。Spring Boot支持集成测试,可以通过@SpringBootTest注解来模拟HTTP请求。

import static org.springframework.test.web.servlet.request.MockMvcRequestBuilders.post;
import static org.springframework.test.web.servlet.result.MockMvcResultMatchers.status;

@SpringBootTest
class UserControllerTests {

    @Autowired
    private MockMvc mockMvc;

    @Test
    void testCreateUser() throws Exception {
        User user = new User();
        user.setName("John Doe");

        String json = "{\"name\": \"John Doe\"}";
        this.mockMvc.perform(post("/users")
                .contentType(MediaType.APPLICATION_JSON)
                .content(json))
                .andExpect(status().isOk());
    }
}

应用打包与部署

  1. 打包应用

    使用Maven或Gradle命令打包应用。

    mvn clean package
    # 或者
    gradle build
  2. 部署应用

    打包完成后,会在目标目录下生成一个.jar文件,可以直接使用java -jar命令启动应用。

    java -jar target/my-project-0.0.1-SNAPSHOT.jar
  3. 部署到云平台

    如果需要部署到云平台,可以使用Docker镜像或者直接将.jar文件部署到云服务器上。例如,使用Docker:

    FROM openjdk:11-jre-slim
    COPY target/my-project-0.0.1-SNAPSHOT.jar /app.jar
    ENTRYPOINT ["java", "-jar", "/app.jar"]

    构建并运行Docker镜像:

    docker build -t my-project .
    docker run -p 8080:8080 my-project

通过以上步骤,可以完成一个Spring Boot项目的开发、测试和部署。Spring Boot的强大之处在于简化了开发流程,使得开发者能够更加专注于业务逻辑的实现。

点击查看更多内容
TA 点赞

若觉得本文不错,就分享一下吧!

评论

作者其他优质文章

正在加载中
  • 推荐
  • 评论
  • 收藏
  • 共同学习,写下你的评论
感谢您的支持,我会继续努力的~
扫码打赏,你说多少就多少
赞赏金额会直接到老师账户
支付方式
打开微信扫一扫,即可进行扫码打赏哦
今天注册有机会得

100积分直接送

付费专栏免费学

大额优惠券免费领

立即参与 放弃机会
意见反馈 帮助中心 APP下载
官方微信

举报

0/150
提交
取消