当前位置: 首页 > news >正文

Spring Boot 项目开发流程全解析

目录

引言

一、开发环境准备

二、创建项目

三、项目结构

四、开发业务逻辑

1.创建实体类:

2.创建数据访问层(DAO):

3.创建服务层(Service):

4.创建控制器层(Controller):

五、配置文件

1.application.properties 或 application.yml:

2.日志配置:

六、测试

1.单元测试:

2.集成测试:

七、部署

1.打包项目:

2.部署方式:

总结:


引言

在当今的 Java 开发领域,Spring Boot 以其便捷、高效的特性成为了众多开发者的首选。本文将详细介绍 Spring Boot 完整的项目开发流程,并突出关键要点。

一、开发环境准备

  1. 1.安装 JDK:确保安装了合适版本的 Java Development Kit(JDK),Spring Boot 通常需要 JDK 8 及以上版本。

  2. 2.安装 IDE:如 IntelliJ IDEA 或 Eclipse,这些集成开发环境提供了丰富的功能,方便开发 Spring Boot 项目。

  3. 3.配置 Maven 或 Gradle:Spring Boot 项目可以使用 Maven 或 Gradle 进行构建管理。确保在开发环境中正确配置了构建工具,并了解其基本使用方法。

  4. 二、创建项目

    1. 使用 Spring Initializr:Spring Initializr 是一个快速创建 Spring Boot 项目的工具。可以通过访问Spring Initializr 官网或者在 IDE 中使用插件来创建项目。选择项目配置:在创建项目时,需要选择项目的基本信息,如项目名称、包名、依赖等。根据项目需求选择合适的依赖,例如 Web 开发可以选择 spring-boot-starter-web。

    2. 三、项目结构

      1.目录结构:

      src/main/java:存放 Java 源代码。

      src/main/resources:存放配置文件、静态资源等。

      src/test/java:存放测试代码。

      src/test/resources:存放测试资源文件。

      2.关键文件:

      application.properties 或 application.yml:项目的配置文件,可以配置数据库连接、日志级别等。

      pom.xml(Maven)或 build.gradle(Gradle):项目的构建文件,用于管理项目依赖。

    3. 四、开发业务逻辑

      1.创建实体类:

    4. 根据业务需求创建实体类,通常使用 Java 对象来表示数据库中的表。

    5. 例如:

    6. package com.example.demo.entity;

    7. import javax.persistence.Entity;

    8. import javax.persistence.GeneratedValue;

    import javax.persistence.GenerationType;import javax.persistence.Id;
    
    1. @Entity
    public class User {@Id@GeneratedValue(strategy = GenerationType.IDENTITY)private Long id;private String name;private String email;// 构造函数、getter 和 setter 方法}### 2.创建数据访问层(DAO):
    
    1. 使用 Spring Data JPA 或其他数据库访问技术创建数据访问层,实现对数据库的操作。

    2. 例如:

    package com.example.demo.repository;import com.example.demo.entity.User;import org.springframework.data.jpa.repository.JpaRepository;public interface UserRepository extends JpaRepository<User, Long> {}### 3.创建服务层(Service):
    
    1. 在服务层实现业务逻辑,调用数据访问层进行数据库操作。

    2. 例如:

    1.package com.example.demo.service;
    
    1. import com.example.demo.entity.User;
    import java.util.List;public interface UserService {User saveUser(User user);User getUserById(Long id);List<User> getAllUsers();void deleteUser(Long id);}
    
    1. 2.package com.example.demo.service.impl;
    import com.example.demo.entity.User;import com.example.demo.repository.UserRepository;import com.example.demo.service.UserService;import org.springframework.beans.factory.annotation.Autowired;import org.springframework.stereotype.Service;import java.util.List;@Servicepublic class UserServiceImpl implements UserService {@Autowiredprivate UserRepository userRepository;@Overridepublic User saveUser(User user) {return userRepository.save(user);}@Overridepublic User getUserById(Long id) {return userRepository.findById(id).orElse(null);}@Overridepublic List<User> getAllUsers() {return userRepository.findAll();}@Overridepublic void deleteUser(Long id) {userRepository.deleteById(id);}}### 4.创建控制器层(Controller):
    
    1. 创建控制器类,处理 HTTP 请求,调用服务层实现业务逻辑,并返回响应结果。

    2. 例如:

    package com.example.demo.controller;import com.example.demo.entity.User;import com.example.demo.service.UserService;import org.springframework.beans.factory.annotation.Autowired;import org.springframework.http.HttpStatus;import org.springframework.http.ResponseEntity;import org.springframework.web.bind.annotation.\*;import java.util.List;@RestController@RequestMapping("/users")public class UserController {@Autowiredprivate UserService userService;@PostMappingpublic ResponseEntity<User> saveUser(@RequestBody User user) {User savedUser = userService.saveUser(user);return new ResponseEntity<>(savedUser, HttpStatus.CREATED);}@GetMapping("/{id}")public ResponseEntity<User> getUserById(@PathVariable Long id) {User user = userService.getUserById(id);if (user!= null) {return new ResponseEntity<>(user, HttpStatus.OK);} else {return new ResponseEntity<>(HttpStatus.NOT\_FOUND);}}@GetMappingpublic ResponseEntity<List<User>> getAllUsers() {List<User> users = userService.getAllUsers();return new ResponseEntity<>(users, HttpStatus.OK);}@DeleteMapping("/{id}")public ResponseEntity<Void> deleteUser(@PathVariable Long id) {userService.deleteUser(id);return new ResponseEntity<>(HttpStatus.NO\_CONTENT);}}
    
    1. 五、配置文件
    ------### 1.application.properties 或 application.yml:
    
    1. 可以在配置文件中配置数据库连接、服务器端口、日志级别等。

    2. 例如:

    server.port=8080spring.datasource.url=jdbc:mysql://localhost:3306/mydbspring.datasource.username=rootspring.datasource.password=passwordspring.jpa.hibernate.ddl-auto=update### 2.日志配置:
    
    1. 可以配置日志级别、输出格式等,以便在开发和生产环境中更好地跟踪问题。

    2. 例如:

    logging.level.root=INFOlogging.pattern.console=%d{yyyy-MM-dd HH:mm:ss} \[%thread\] %-5level %logger{36} - %msg%n
    
    1. 六、测试

    ----### 1.单元测试:
    
    1. 使用 JUnit 和 Mockito 等测试框架编写单元测试,测试业务逻辑的各个部分。

    2. 例如:

    package com.example.demo.service.impl;import com.example.demo.entity.User;import com.example.demo.repository.UserRepository;import org.junit.jupiter.api.BeforeEach;import org.junit.jupiter.api.Test;import org.mockito.InjectMocks;import org.mockito.Mock;import org.mockito.MockitoAnnotations;import java.util.Optional;import static org.junit.jupiter.api.Assertions.assertEquals;import static org.mockito.Mockito.when;class UserServiceImplTest {@InjectMocksprivate UserServiceImpl userService;@Mockprivate UserRepository userRepository;@BeforeEachvoid setUp() {MockitoAnnotations.initMocks(this);}@Testvoid saveUser() {User user = new User();user.setName("John");user.setEmail("john@example.com");when(userRepository.save(user)).thenReturn(user);User savedUser = userService.saveUser(user);assertEquals(user.getName(), savedUser.getName());assertEquals(user.getEmail(), savedUser.getEmail());}@Testvoid getUserById() {Long id = 1L;User user = new User();user.setId(id);user.setName("John");user.setEmail("john@example.com");when(userRepository.findById(id)).thenReturn(Optional.of(user));User foundUser = userService.getUserById(id);assertEquals(user.getName(), foundUser.getName());assertEquals(user.getEmail(), foundUser.getEmail());}}### 2.集成测试:
    
    1. 编写集成测试,测试整个应用的功能。可以使用 Spring Boot 的测试框架,如 @SpringBootTest 注解。

    2. 例如:

    package com.example.demo;import com.example.demo.controller.UserController;import com.example.demo.entity.User;import com.example.demo.service.UserService;import org.junit.jupiter.api.BeforeEach;import org.junit.jupiter.api.Test;import org.springframework.beans.factory.annotation.Autowired;import org.springframework.boot.test.context.SpringBootTest;import org.springframework.boot.test.web.client.TestRestTemplate;import org.springframework.http.HttpEntity;import org.springframework.http.HttpMethod;import org.springframework.http.HttpStatus;import org.springframework.http.ResponseEntity;import java.util.List;import static org.junit.jupiter.api.Assertions.assertEquals;import static org.junit.jupiter.api.Assertions.assertNotNull;@SpringBootTest(webEnvironment = SpringBootTest.WebEnvironment.RANDOM\_PORT)class DemoApplicationTests {@Autowiredprivate UserController userController;@Autowiredprivate UserService userService;@Autowiredprivate TestRestTemplate restTemplate;@BeforeEachvoid setUp() {userService.deleteAll();}@Testvoid contextLoads() {}@Testvoid saveUser() {User user = new User();user.setName("John");user.setEmail("john@example.com");HttpEntity<User> request = new HttpEntity<>(user);ResponseEntity<User> response = restTemplate.postForEntity("/users", request, User.class);assertEquals(HttpStatus.CREATED, response.getStatusCode());assertNotNull(response.getBody());assertEquals(user.getName(), response.getBody().getName());assertEquals(user.getEmail(), response.getBody().getEmail());}@Testvoid getUserById() {User user = new User();user.setName("John");user.setEmail("john@example.com");User savedUser = userService.saveUser(user);ResponseEntity<User> response = restTemplate.getForEntity("/users/{id}", User.class, savedUser.getId());assertEquals(HttpStatus.OK, response.getStatusCode());assertNotNull(response.getBody());assertEquals(user.getName(), response.getBody().getName());assertEquals(user.getEmail(), response.getBody().getEmail());}@Testvoid getAllUsers() {User user1 = new User();user1.setName("John");user1.setEmail("john@example.com");User savedUser1 = userService.saveUser(user1);User user2 = new User();user2.setName("Jane");user2.setEmail("jane@example.com");User savedUser2 = userService.saveUser(user2);ResponseEntity<List> response = restTemplate.getForEntity("/users", List.class);assertEquals(HttpStatus.OK, response.getStatusCode());assertNotNull(response.getBody());assertEquals(2, response.getBody().size());}@Testvoid deleteUser() {User user = new User();user.setName("John");user.setEmail("john@example.com");User savedUser = userService.saveUser(user);restTemplate.delete("/users/{id}", savedUser.getId());ResponseEntity<User> response = restTemplate.getForEntity("/users/{id}", User.class, savedUser.getId());assertEquals(HttpStatus.NOT\_FOUND, response.getStatusCode());}}1.  七、部署----### 1.打包项目:2.  使用 Maven 或 Gradle 打包项目,生成可执行的 JAR 或 WAR 文件。### 2.部署方式:3.  可以将打包后的文件部署到服务器上,如 Tomcat、Jetty 等,或者使用容器化技术,如 Docker。4.  总结:---1.  Spring Boot 项目开发流程涵盖了从环境准备到部署的各个环节,通过合理的规划和实践,可以高效地开发出稳定、可靠的应用程序。在开发过程中,关键要点包括正确选择依赖、合理设计项目结构、编写高质量的测试代码以及灵活配置项目。希望本文对大家在 Spring Boot 项目开发中有所帮助
    

相关文章:

Spring Boot 项目开发流程全解析

目录 引言 一、开发环境准备 二、创建项目 三、项目结构 四、开发业务逻辑 1.创建实体类&#xff1a; 2.创建数据访问层&#xff08;DAO&#xff09;&#xff1a; 3.创建服务层&#xff08;Service&#xff09;&#xff1a; 4.创建控制器层&#xff08;Controller&…...

从Java到MySQL8源码:深入解析PreparedStatement参数绑定与执行机制

引言 在数据库开发中&#xff0c;PreparedStatement&#xff08;预处理语句&#xff09;是防止SQL注入、提升性能的重要工具。它通过分离SQL结构与参数值&#xff0c;不仅增强了安全性&#xff0c;还能利用预编译优化执行效率。本文将从Java JDBC驱动和MySQL 8源码的双重视角&…...

mysql的主从同步

1、异步复制&#xff1a;这是MySQL默认的复制模式。在这种模式下&#xff0c;主库在执行完客户端提交的事务后会立即将结果返回给客户端&#xff0c;并不关心从库是否已经接收并处理。这种模式的优点是实现简单&#xff0c;但缺点是如果主库崩溃&#xff0c;已经提交的事务可能…...

工程化与框架系列(10)--微前端架构

微前端架构 &#x1f3d7;️ 微前端是一种将前端应用分解成更小、更易管理的独立部分的架构模式。本文将详细介绍微前端的核心概念、实现方案和最佳实践。 微前端概述 &#x1f31f; &#x1f4a1; 小知识&#xff1a;微前端的核心理念是将前端应用分解成一系列独立部署、松耦…...

【3天快速入门WPF】11-附加属性

目录 1. 步骤1:定义附加属性2. 示例代码3. 步骤2:在XAML中使用附加属性3.1. 示例代码4. 步骤3:扩展使用场景4.1. 示例代码5. 总结上一篇讲到了依赖属性,本篇主要想说一下附加属性。 在WPF中,附加属性(Attached Property)是一种特殊的依赖属性,允许你在不属于某个类的控…...

MySQL并发知识(面试高频)

mysql并发事务解决 不同隔离级别下&#xff0c;mysql解决并发事务的方式不同。主要由锁机制和MVCC(多版本并发控制)机制来解决并发事务问题。 1. mysql中的锁有哪些&#xff1f; 表级锁&#xff1a; 场景&#xff1a;表级锁适用于需要对整个表进行操作的情况&#xff0c;例如…...

现存脑容知识库

Redis import queue import threading import asyncio 异步&#xff1a;在一个线程内&#xff0c;等待的时候可以切换到其他任务。 多线程&#xff1a;每个线程独立运行&#xff0c;同时处理多个任务。 回调函数 网络请求&#xff08;JavaScript&#xff09;在浏览器中&a…...

Mysql-如何理解事务?

一、事务是什么东西 有些场景中&#xff0c;某个操作需要多个sql配合完成&#xff1a; 例如&#xff1a; 李四这个月剩下的前不够交房租了&#xff0c;找张三借1000元急用&#xff1a; &#xff08;1&#xff09;给张三的账户余额 减去1000元 updata 账户表 set money money -…...

dify绑定飞书多维表格

dify 绑定飞书和绑定 notion 有差不多的过程&#xff0c;都需要套一层应用的壳子&#xff0c;而没有直接可以访问飞书文档的 API。本文记录如何在dify工具中使用新增多条记录工具。 创建飞书应用 在飞书开放平台创建一个应用&#xff0c;个人用户创建企业自建应用。 自定义应…...

QT播放视频保持视频宽高比消除黑边

QT播放视频保持视频宽高比消除黑边 1、问题 在播放视频的时候&#xff0c;由于框架的大小发生变化&#xff0c;导致视频出现黑边很不好看。 因此需要像一种方法消除黑边 2、处理 1、读取视频的宽高比 2、设置视频的Widget的大小固定&#xff0c;Widget的宽高比和视频宽高比…...

1. IO的基础知识

1.1 流 Java程序通过流执行IO。流是一种抽象&#xff0c;它要么生成信息&#xff0c;要么使用信息。流通过java的IO系统链接到物理设备。所有流的行为方式都是相同的&#xff0c;尽管它们链接的物理设备是不同的。 1.2 字节流和字符流 Java定义了两种类型的流 : 字节流和字符流…...

科普:ROC AUC与PR AUC

在评价二分类模型性能时&#xff0c;有许多评价指标&#xff0c;其中&#xff0c;有一对是用面积AUC&#xff08;Area Under the Curve&#xff09;做评价的&#xff1a;ROC AUC与PR AUC 本文我们对ROC AUC与PR AUC进行多维度对比分析&#xff1a; 一、定义与核心原理 维度RO…...

Vue3父组件访问子组件方法与属性完全指南

在Vue3的组件化开发中&#xff0c;父子组件间的通信是核心功能之一。本文将详细介绍五种父组件访问子组件属性/方法的实现方案&#xff0c;包含最新的<script setup>语法糖实践。&#xff08;综合1579&#xff09; 一、ref defineExpose&#xff08;推荐方案&#xff0…...

AI时代保护自己的隐私

人工智能最重要的就是数据&#xff0c;让我们面对现实&#xff0c;大多数人都不知道他们每天要向人工智能提供多少数据。你输入的每条聊天记录&#xff0c;你发出的每条语音命令&#xff0c;人工智能生成的每张图片、电子邮件和文本。我建设了一个网站(haptool.com)&#xff0c…...

Android APK组成编译打包流程详解

Android APK&#xff08;Android Package&#xff09;是 Android 应用的安装包文件&#xff0c;其组成和打包流程涉及多个步骤和文件结构。以下是详细的说明&#xff1a; 一、APK 的组成 APK 是一个 ZIP 格式的压缩包&#xff0c;包含应用运行所需的所有文件。解压后主要包含以…...

TCP长连接与短连接

TCP长连接与短连接 TCP&#xff08;传输控制协议&#xff09;中的长连接和短连接是两种不同的连接管理方式&#xff0c;各有优缺点&#xff1a; 短连接 短连接是指客户端与服务器完成一次数据交换后就断开连接。下次需要通信时&#xff0c;再重新建立连接。 特点&#xff1…...

C#委托(delegate)的常用方式

C# 中委托的常用方式&#xff0c;包括委托的定义、实例化、不同的赋值方式以及匿名委托的使用。 委托的定义 // 委托的核心是跟委托的函数结构一样 public delegate string SayHello(string c);public delegate string SayHello(string c);&#xff1a;定义了一个公共委托类型 …...

C#从入门到精通(35)—如何防止winform程序因为误操作被关闭

前言: 大家好,我是上位机马工,硕士毕业4年年入40万,目前在一家自动化公司担任软件经理,从事C#上位机软件开发8年以上!我们在开发的上位机软件运行起来以后,一般在右上角都有一个关闭按钮,正常情况下点击关闭按钮就能关闭软件,但是不排除我们不想关闭软件,但是因为不…...

docker本地镜像源搭建

最近Deepseek大火后&#xff0c;接到任务就是帮客户装Dify&#xff0c;每次都头大&#xff0c;因为docker源不能用&#xff0c;实在没办法&#xff0c;只好自己搭要给本地源。话不多说具体如下&#xff1a; 1、更改docker的配置文件&#xff0c;添加自己的私库地址&#xff0c…...

Sqlserver安全篇之_TLS的证书概念

证书的理解 参考Sqlserver的官方文档https://learn.microsoft.com/zh-cn/sql/database-engine/configure-windows/certificate-overview?viewsql-server-ver16 TLS(Transport Layer Security)传输层安全和SSL(Secure Sockets Layer)安全套接字层协议位于应用程序协议层和TCP/…...

内存分配函数malloc kmalloc vmalloc

内存分配函数malloc kmalloc vmalloc malloc实现步骤: 1)请求大小调整:首先,malloc 需要调整用户请求的大小,以适应内部数据结构(例如,可能需要存储额外的元数据)。通常,这包括对齐调整,确保分配的内存地址满足特定硬件要求(如对齐到8字节或16字节边界)。 2)空闲…...

label-studio的使用教程(导入本地路径)

文章目录 1. 准备环境2. 脚本启动2.1 Windows2.2 Linux 3. 安装label-studio机器学习后端3.1 pip安装(推荐)3.2 GitHub仓库安装 4. 后端配置4.1 yolo环境4.2 引入后端模型4.3 修改脚本4.4 启动后端 5. 标注工程5.1 创建工程5.2 配置图片路径5.3 配置工程类型标签5.4 配置模型5.…...

相机Camera日志实例分析之二:相机Camx【专业模式开启直方图拍照】单帧流程日志详解

【关注我&#xff0c;后续持续新增专题博文&#xff0c;谢谢&#xff01;&#xff01;&#xff01;】 上一篇我们讲了&#xff1a; 这一篇我们开始讲&#xff1a; 目录 一、场景操作步骤 二、日志基础关键字分级如下 三、场景日志如下&#xff1a; 一、场景操作步骤 操作步…...

3.3.1_1 检错编码(奇偶校验码)

从这节课开始&#xff0c;我们会探讨数据链路层的差错控制功能&#xff0c;差错控制功能的主要目标是要发现并且解决一个帧内部的位错误&#xff0c;我们需要使用特殊的编码技术去发现帧内部的位错误&#xff0c;当我们发现位错误之后&#xff0c;通常来说有两种解决方案。第一…...

Opencv中的addweighted函数

一.addweighted函数作用 addweighted&#xff08;&#xff09;是OpenCV库中用于图像处理的函数&#xff0c;主要功能是将两个输入图像&#xff08;尺寸和类型相同&#xff09;按照指定的权重进行加权叠加&#xff08;图像融合&#xff09;&#xff0c;并添加一个标量值&#x…...

Map相关知识

数据结构 二叉树 二叉树&#xff0c;顾名思义&#xff0c;每个节点最多有两个“叉”&#xff0c;也就是两个子节点&#xff0c;分别是左子 节点和右子节点。不过&#xff0c;二叉树并不要求每个节点都有两个子节点&#xff0c;有的节点只 有左子节点&#xff0c;有的节点只有…...

RabbitMQ入门4.1.0版本(基于java、SpringBoot操作)

RabbitMQ 一、RabbitMQ概述 RabbitMQ RabbitMQ最初由LShift和CohesiveFT于2007年开发&#xff0c;后来由Pivotal Software Inc.&#xff08;现为VMware子公司&#xff09;接管。RabbitMQ 是一个开源的消息代理和队列服务器&#xff0c;用 Erlang 语言编写。广泛应用于各种分布…...

Go语言多线程问题

打印零与奇偶数&#xff08;leetcode 1116&#xff09; 方法1&#xff1a;使用互斥锁和条件变量 package mainimport ("fmt""sync" )type ZeroEvenOdd struct {n intzeroMutex sync.MutexevenMutex sync.MutexoddMutex sync.Mutexcurrent int…...

AI语音助手的Python实现

引言 语音助手(如小爱同学、Siri)通过语音识别、自然语言处理(NLP)和语音合成技术,为用户提供直观、高效的交互体验。随着人工智能的普及,Python开发者可以利用开源库和AI模型,快速构建自定义语音助手。本文由浅入深,详细介绍如何使用Python开发AI语音助手,涵盖基础功…...

CSS3相关知识点

CSS3相关知识点 CSS3私有前缀私有前缀私有前缀存在的意义常见浏览器的私有前缀 CSS3基本语法CSS3 新增长度单位CSS3 新增颜色设置方式CSS3 新增选择器CSS3 新增盒模型相关属性box-sizing 怪异盒模型resize调整盒子大小box-shadow 盒子阴影opacity 不透明度 CSS3 新增背景属性ba…...