spring boot 基础案例【3】构建RESTful API与单元测试

教程1
案例教程
案例仓库
在线编程

教程2
基础教程
教程仓库
在线编程

本案例所在的仓库
本案例所在的文档


进入正文

1.文件目录

在这里插入图片描述

1. Chapter21Application.java

地址:chapter2-1/src/main/java/com/didispace/chapter21/Chapter21Application.java

package com.didispace.chapter21;import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;@SpringBootApplication
public class Chapter21Application {public static void main(String[] args) {SpringApplication.run(Chapter21Application.class, args);}}

2. User.java

地址:chapter2-1/src/main/java/com/didispace/chapter21/User.java

package com.didispace.chapter21;import lombok.Data;@Data
public class User {private Long id;private String name;private int age;public User(Long id, String name, int age) {this.id = id;this.name = name;this.age = age;}// Getter and Setter methods// 略...
}

这段代码是一个简单的 Java 类定义,使用了 Lombok 库中的 @Data 注解,用于自动生成 getter、setter 和 toString 等方法。这个类定义了一个 User 类,包含了三个字段:idnameage,分别表示用户的唯一标识、姓名和年龄。

在 Java 中,通常需要为类的每个字段手动编写 getter 和 setter 方法以及 toString 方法来实现类的基本功能,但是使用 Lombok 的 @Data 注解可以自动帮助生成这些方法,从而简化了代码编写过程。

下面是这段代码的详细解释:

  • package com.didispace.chapter21;:这行代码定义了类的包路径,即 User 类所属的包名为 com.didispace.chapter21。包路径用于组织类,以便在不同的类之间进行引用和管理。

  • import lombok.Data;:这行代码导入了 Lombok 库中的 @Data 注解。通过导入该注解,我们可以在 User 类上使用 @Data 注解来自动生成 getter、setter 和 toString 方法。

  • @Data:这个注解是 Lombok 提供的,用于在编译时自动生成 getter、setter、equals、hashCode 和 toString 等方法。在 User 类上添加了 @Data 注解后,就不需要手动编写这些方法了,Lombok 会在编译时自动生成。

  • public class User {:这行代码定义了一个公共的 User 类。在 Java 中,类通常被定义为公共的(即 public),以便在其他包中可以访问到该类。

  • private Long id;private String name;private Integer age;:这三行代码定义了 User 类的三个私有字段,分别是 idnameage。这些字段被声明为私有的(即 private),意味着它们只能在 User 类的内部访问,外部无法直接访问这些字段。

  • }:这行代码表示类定义的结束。

总的来说,这段代码定义了一个简单的 Java 类 User,通过使用 Lombok 的 @Data 注解简化了 getter、setter 和 toString 方法的编写,使得代码更加简洁和易读。

3. UserController.java

地址:chapter2-1/src/main/java/com/didispace/chapter21/UserController.java

package com.didispace.chapter21;import org.springframework.web.bind.annotation.*;import java.util.*;@RestController
@RequestMapping(value = "/users")     // 通过这里配置使下面的映射都在/users下
public class UserController {// 创建线程安全的Map,模拟users信息的存储static Map<Long, User> users = Collections.synchronizedMap(new HashMap<Long, User>());static {User user1 = new User(1566L, "Alice", 25);User user2 = new User(2L, "Bob", 30);User user3 = new User(3L, "Charlie", 35);users.put(user1.getId(), user1);users.put(user2.getId(), user2);users.put(user3.getId(), user3);}/*** 处理"/users/"的GET请求,用来获取用户列表** @return*/@GetMapping("/")public List<User> getUserList() {// 还可以通过@RequestParam从页面中传递参数来进行查询条件或者翻页信息的传递List<User> r = new ArrayList<User>(users.values());return r;}/*** 处理"/users/"的POST请求,用来创建User** @param user* @return*/@PostMapping("/")public String postUser(@RequestBody User user) {// @RequestBody注解用来绑定通过http请求中application/json类型上传的数据users.put(user.getId(), user);return "success";}/*** 处理"/users/{id}"的GET请求,用来获取url中id值的User信息** @param id* @return*/@GetMapping("/{id}")public User getUser(@PathVariable Long id) {// url中的id可通过@PathVariable绑定到函数的参数中return users.get(id);}/*** 处理"/users/{id}"的PUT请求,用来更新User信息** @param id* @param user* @return*/@PutMapping("/{id}")public String putUser(@PathVariable Long id, @RequestBody User user) {User u = users.get(id);u.setName(user.getName());u.setAge(user.getAge());users.put(id, u);return "success";}/*** 处理"/users/{id}"的DELETE请求,用来删除User** @param id* @return*/@DeleteMapping("/{id}")public String deleteUser(@PathVariable Long id) {users.remove(id);return "success";}}

解释:

这段代码是一个基于Spring框架的RESTful风格的API示例,用于管理用户信息。让我逐步解释每个部分的功能和作用:

  1. package com.didispace.chapter21;:这行代码定义了类的包路径,即 UserController 类所属的包名为 com.didispace.chapter21。包路径用于组织类,以便在不同的类之间进行引用和管理。

  2. import org.springframework.web.bind.annotation.*;:这行代码导入了Spring框架中用于处理HTTP请求的注解,包括 @RestController@RequestMapping@GetMapping@PostMapping@PutMapping@DeleteMapping。这些注解用于定义RESTful API的请求映射和处理方法。

  3. @RestController:这个注解标注在类上,表示该类是一个RESTful风格的控制器,可以处理HTTP请求并返回RESTful风格的响应。

  4. @RequestMapping(value = "/users"):这个注解用于映射HTTP请求的URL路径,指定了处理该控制器的请求路径为 /users。因为在类级别上使用了这个注解,所以下面所有的请求映射路径都相对于 /users

  5. public class UserController {:这行代码定义了一个公共的 UserController 类。在Spring框架中,控制器类通常被定义为公共的(即 public),以便可以被其他类和组件引用。

  6. static Map<Long, User> users = Collections.synchronizedMap(new HashMap<Long, User>());:这行代码定义了一个静态的 Map 对象 users,用于存储用户信息。这里使用了 Collections.synchronizedMap 方法创建了一个线程安全的 Map,以确保在多线程环境下对用户信息的操作是安全的。

接下来是几个请求处理方法,它们分别处理不同的HTTP请求:

  • @GetMapping("/"):处理GET请求,用来获取用户列表。使用 @GetMapping 注解将该方法映射到处理 /users/ 路径的GET请求,并通过 List<User> 类型的返回值返回用户列表。

  • @PostMapping("/"):处理POST请求,用来创建新用户。使用 @PostMapping 注解将该方法映射到处理 /users/ 路径的POST请求,并通过 @RequestBody 注解从请求体中获取用户信息,并将用户信息添加到 users Map 中。

  • @GetMapping("/{id}"):处理GET请求,用来获取指定ID用户的信息。使用 @GetMapping 注解将该方法映射到处理 /users/{id} 路径的GET请求,并通过 @PathVariable 注解将URL中的 id 参数绑定到方法的参数中,然后根据 idusers Map 中获取对应的用户信息并返回。

  • @PutMapping("/{id}"):处理PUT请求,用来更新指定ID用户的信息。使用 @PutMapping 注解将该方法映射到处理 /users/{id} 路径的PUT请求,并通过 @PathVariable 注解将URL中的 id 参数绑定到方法的参数中,通过 @RequestBody 注解从请求体中获取新的用户信息,并更新 users Map 中对应ID的用户信息。

  • @DeleteMapping("/{id}"):处理DELETE请求,用来删除指定ID用户。使用 @DeleteMapping 注解将该方法映射到处理 /users/{id} 路径的DELETE请求,并通过 @PathVariable 注解将URL中的 id 参数绑定到方法的参数中,然后从 users Map 中删除对应ID的用户信息。

总的来说,这段代码实现了一个简单的用户管理系统,通过HTTP请求来实现对用户信息的增删改查操作,符合RESTful风格的API设计原则。

3.效果

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/web/5152.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Flink checkpoint 源码分析- Flink Checkpoint 触发流程分析

序言 最近因为工作需要在阅读flink checkpoint处理机制&#xff0c;学习的过程中记录下来&#xff0c;并分享给大家。也算是学习并记录。 目前公司使用的flink版本为1.11。因此以下的分析都是基于1.11版本来的。 在分享前可以简单对flink checkpoint机制做一个大致的了解。 …

人工智慧时代的引擎:揭开机器人核心零部件的奥秘

机器人核心零部件技术现状及趋势 工业机器人是我国制造业的“顶冠明珠”&#xff0c;在机器人核心零部件的研发制造上&#xff0c;我国在很多方面已经接近国际顶尖水平&#xff0c;但一些核心技术仍无法满足复杂高端领域应用需求&#xff0c;如精密减速器的传动精度与寿命间竞争…

深度学习的瓶颈是什么!

深度学习主要的瓶颈&#xff1a; 数据依赖与标注问题&#xff1a;深度学习模型通常需要大量的标注数据来进行训练。然而&#xff0c;获取大量的标注数据不仅成本高昂&#xff0c;而且在某些领域&#xff08;如医疗、金融等&#xff09;中可能难以获取足够的标注数据。此外&…

人脸识别开源算法库和开源数据库

目录 1. 人脸识别开源算法库 1.1 OpenCV人脸识别模块 1.2 Dlib人脸识别模块 1.3 SeetaFace6 1.4 DeepFace 1.5 InsightFace 2. 人脸识别开源数据库 2.1 CelebA 2.2 LFW 2.3 MegaFace 2.4 Glint360K 2.5 WebFace260M 人脸识别 (Face Recognition) 是一种基于人的面部…

无人机反制:雷达探测+信号干扰器技术详解

固定翼无人机、旋翼无人机等&#xff0c;可折叠式无机、DIY无人机等。黑飞&#xff0c;监管困难给航空业带来了诸多隐患&#xff1b;给恐怖袭击及间谍侦察带来新的方式、引发了各国地区政府的忧虑&#xff0c;在中国存在的问题更加严峻。 反无人飞行器防御系统(AUDS)&#xff0…

【C++】手撕list(list的模拟实现)

目录 01.节点 02.迭代器 迭代器运算符重载 03.list类 &#xff08;1&#xff09;构造与析构 &#xff08;2&#xff09;迭代器相关 &#xff08;3&#xff09;容量相关 &#xff08;4&#xff09;访问操作 &#xff08;5&#xff09;插入删除 我们在学习数据结构的时候…

使用 GitHub Actions 实现项目的持续集成(CI)

目录 什么是 GitHub Actions 基础概念 Workflow 文件 Workflow 语法 实例&#xff1a;编译 OpenWrt 什么是 GitHub Actions GitHub Actions 是 GitHub 推出的持续集成&#xff08;Continuous Integration&#xff0c;简称 CI&#xff09;服务它允许你创建自定义工作流&am…

黑马面试篇1(续)

黑马面试篇1-CSDN博客&#xff08;续集&#xff09; 六、消息中间件篇 6.1 RabbitMQ 1&#xff09;使用场景&#xff1a; 异步发送&#xff08;验证码、短信、邮件…&#xff09;MYSQL和Redis , ES之间的数据同步分布式事务削峰填谷… 2&#xff09;RabbitMQ消息的重复消费问…

分享三款可以给pdf做批注的软件

PDF文件不像Word一样可以直接编辑更改&#xff0c;想要在PDF文件上进行编辑批注需要用到一些专业的软件&#xff0c;我自己常用的有三款&#xff0c;全都是官方专业正版的软件&#xff0c;功能丰富强大&#xff0c;使用起来非常方便&#xff01; 1.edge浏览器 这个浏览器不仅可…

【Spring】Spring中AOP的简介和基本使用,SpringBoot使用AOP

&#x1f4dd;个人主页&#xff1a;哈__ 期待您的关注 一、AOP简介 AOP的全称是Aspect-Oriented Programming&#xff0c;即面向切面编程&#xff08;也称面向方面编程&#xff09;。它是面向对象编程&#xff08;OOP&#xff09;的一种补充&#xff0c;目前已成为一种比较成…

ton-http-api安装部署

1、拉取github代码 mkdir /data git clone https://github.com/toncenter/ton-http-api.git cd ton-http-api2、创建环境变量 ./configure.py cat .env TON_API_CACHE_ENABLED0 TON_API_CACHE_REDIS_ENDPOINTcache_redis TON_API_CACHE_REDIS_PORT6379 TON_API_CACHE_REDIS_T…

Facebook’s Tectonic Filesystem: Efficiency from Exascale——论文阅读

FAST 2021 Paper 分布式元数据论文阅读笔记整理 背景 Blob storage 用来存放大量的文本、图片、视频等非结构化数据 包含 EB 级别的数据 存储内容大小不一&#xff0c;大小几KB到几MB不等 要求低时延 使用 Haystack 和 F4 Data warehouse 存放用于数据分析和机器学习的…

Leetcode—1232. 缀点成线【简单】

2024每日刷题&#xff08;122&#xff09; Leetcode—1232. 缀点成线 算法思想 实现代码 class Solution { public:bool checkStraightLine(vector<vector<int>>& coordinates) {int x0 coordinates[0][0];int y0 coordinates[0][1];int x1 coordinates[1…

Excel 中用于在一个范围中查找特定的值,并返回同一行中指定列的值 顺序不一样 可以处理吗

一、需求 Excel 中&#xff0c;在一列&#xff08;某范围内&#xff09;查找另一列特定的值&#xff0c;并返回同一行中另一指定列的值&#xff0c; 查找列和返回列的顺序不一样 二、 实现 1、下面是一个使用 INDEX 和 MATCH 函数的例子&#xff1a; 假设你有以下数据&…

python数据可视化:雷达图

【小白从小学Python、C、Java】 【计算机等考500强证书考研】 【Python-数据分析】 python数据可视化&#xff1a; 雷达图 选择题 关于以下代码输出的雷达图中&#xff0c;以下说法正确的是&#xff1f; import numpy as np import matplotlib.pyplot as plt from pylab impor…

看懂原理图

EL3H7光耦 作用&#xff1a; 光耦还可以隔离驱动电机什么的、485隔离通讯啊、pwm信号传输&#xff0c;韦根&#xff0c;强电压。 参考&#xff1a;光耦应用及参数设计_el3h7光耦中文资料-CSDN博客

C# winform 漂亮的日期时间控件

源代码下载&#xff1a; https://download.csdn.net/download/gaoxiang19820514/89242240 效果图 在 HZH-Controls控件 基础上修改的日期控件 因为HZH_Controls控件 中的日期控件太大了&#xff0c; 我的程序中需要多个日期时间的控件放不下&#xff0c;主题是绿色的&#…

【介绍下Selenium】

&#x1f3a5;博主&#xff1a;程序员不想YY啊 &#x1f4ab;CSDN优质创作者&#xff0c;CSDN实力新星&#xff0c;CSDN博客专家 &#x1f917;点赞&#x1f388;收藏⭐再看&#x1f4ab;养成习惯 ✨希望本文对您有所裨益&#xff0c;如有不足之处&#xff0c;欢迎在评论区提出…

SpringWebFlux RequestBody多出双引号问题——ProxyPin抓包揪出真凶

缘起 公司有个服务做埋点收集的&#xff0c;可以参考我之前的文章埋点日志最终解决方案&#xff0c;今天突然发现有些数据日志可以输出&#xff0c;但是没法入库。 多出的双引号 查看Flink日志发现了JSON解析失败&#xff0c;Flink是从Kafka拿数据&#xff0c;Kafka本身不处…

C++信息学奥赛 数据结构认识

数据结构 1.1数据结构分类 1.2基本数据类型 1.3数字编码 1.4字符编码 1.1数据结构分类 数据结构如同一副稳固而多样的框架。为数据的有序组织提供了蓝图&#xff0c;算法得以在此基础上生动起来。 常用的数据结构包括哪些 &#xff0c; &#xff0c; &…