前端视角下的Spring-Boot语法学习:demo-crud 实现增删改查

ops/2024/10/21 9:52:27/

今日话题

基于 Spring Boot 实现增删改查,仅仅只是提供接口不涉及数据库增删改查

作者:云层上的光

时间:2024年6月21日 15时19分14秒

主线任务

一、项目创建

1、基于 idea 创建项目

2、选择项目依赖 Spring Web

二、实现增删改查

1、新建 controller 软件包

2、新建 UserController 文件类

选择 “类”进行创建~

3、实现 增删改查 4个方法

package com.chuxin.democrud.controller;public class UserController {// 增加public String add() {return "add";}// 删除public String delete() {return "delete";}// 修改public String edit() {return "edit";}// 查看public String getList() {return "getList";}
}

三、基于 Spring Boot 注解提供对外接口

1、使用 Spring Boot 注解注册为 controller ,也就是前端访问的接口

package com.chuxin.democrud.controller;import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.PostMapping;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RestController;@RestController
@RequestMapping("/user")
public class UserController {// 增加@GetMapping("/add")public String add() {return "add";}// 删除@PostMapping("/delete")public String delete() {return "delete";}// 修改@PostMapping("/edit")public String edit() {return "edit";}// 查看@GetMapping("/getList")public String getList() {return "getList";}
}

2、运行项目

3、浏览器访问:http://localhost:8080/user/getList

支线任务

一、public String add 语法解析

1、以 add 方法代码举例,前端代码如下:

class UserController {constructor(){}add() {return "add";}
}

2、而 Java 中 前面多了 public String

package com.chuxin.democrud.controller;import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.PostMapping;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RestController;@RestController
@RequestMapping("/user")
public class UserController {// 增加@GetMapping("/add")public String add() {return "add";}
}

3、先说 public 意思是公共的、还有其他值:private 私有 这里声明的是否给到外部访问 目前还没有学那个受保护的那个,这里先不进行演示了

4、浏览器访问 http://localhost:8080/user/add

5、修改 public 为 private (是否接口就不能访问了呢?)

6、再次访问 http://localhost:8080/user/add private 也可以访问到

7、这是因为:(后期再深入研究 TODO)

private 和 public 是方法可见性,对于类而言。对注解了的接口则都提供接口访问

8、接下来解析 String ,它是 Java 中描述字符串类型

代码如下:

public class UserController {private String add() {// 定义一个 字符串类型的 变量String result = "add";return result + "接口";}
}

2、public String add 在这里的作用是指明返回类型,add 方法最终需要返回字符串类型值

public class UserController {public String add() {return "add";}
}

二、RestController 作用是啥?

@RestController 是 Spring 框架中的一个注解,用于标记一个类为 RESTful 控制器。这个注解结合了 @Controller 和 @ResponseBody 的功能

1、内部重要的两个注解:

2、@Controller

@Controller 注解用于标记一个类作为 Spring MVC 控制器。它告诉 Spring 这个类将处理来自用户的请求。控制器类通常包含多个方法,每个方法都映射到一个或多个 URL 请求

白话:其实就是用来定义接口的

3、@ResponseBody

@ResponseBody 注解用于方法级别,表示该方法的返回值应该直接写入 HTTP 响应体中,而不是作为视图模型的一部分来渲染视图。这意味着如果方法返回的是 Java 对象,Spring 将尝试将其序列化为相应的格式(如 JSON 或 XML)并发送给客户端

白话:这里处理的就是前端接口返回的数据信息,表示方法的返回值应该直接写入 HTTP 响应体

总结:定义了接口,并且包装了返回给前端的数据格式 这里指 HTTP响应体,不是说的业务封装的 code 等

三、RequestMapping 作用

@RequestMapping 是 Spring MVC 框架中的一个核心注解,用于建立 Web 请求与处理器方法之间的映射关系。它可以作用于类级别或方法级别,用于指定哪些 HTTP 请求(URL 和请求类型)应该映射到特定的控制器类或其方法上

1、定义接口前缀

2、浏览器访问时:http://localhost:8080/user/add 前面必须带上 user

3、RequestMapping 本质工作是定义接口的

总结:定义接口,还可以增加接口前缀,被 GetMapping 等进行了二次包赚

四、PostMapping 用法

详细版见:https://www.yuque.com/chuxin-cs/spring-boot-demo/rb0vo3mme8ouibvo#hiveB

1、定义一个 POST 请求,访问:http://localhost:8080/user/edit

package com.chuxin.democrud.controller;import org.springframework.web.bind.annotation.*;@RestController
@RequestMapping("/user")
public class UserController {// 修改@PostMapping("/edit")public String edit() {return "edit";}
}

2、改造 edit 方法之前,需要先介绍一下 实体类,新建 entity

3、新建 User 类

4、文件名大写,并且选择 “类” 进行创建

5、修改 User 实体类

代码如下:

package com.chuxin.democrud.entity;public class User {/*** 主键id*/private Integer id;/*** 用户名*/private String userName;/*** password*/private String password;
}

6、在 Java 中,新增和修改在实体类中 需要有 getter 和 setter 方法,改造如下:

外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传

代码如下:

package com.chuxin.democrud.entity;public class User {public Integer getId() {return id;}public void setId(Integer id) {this.id = id;}public String getUserName() {return userName;}public void setUserName(String userName) {this.userName = userName;}public String getPassword() {return password;}public void setPassword(String password) {this.password = password;}/*** 主键id*/private Integer id;/*** 用户名*/private String userName;/*** password*/private String password;
}

7、使用快捷方式生成 getter 和 setter

8、选择 Getter 和 Setter

9、有了实体类,接下来改造 edit 方法,接收前端传入的 json 格式:

10、重新编译项目

11、接口访问,成功返回参数

12、改造 edit1 方法,基于 ModelAttribute 接收前端传递过来的参数

接收格式:x-www-form-urlencoded

代码如下:

package com.chuxin.democrud.controller;import com.chuxin.democrud.entity.User;
import org.springframework.web.bind.annotation.*;@RestController
@RequestMapping("/user")
public class UserController {@PostMapping("/edit1")public String edit1(@ModelAttribute User user) {return "add:" + user.getUserName() + user.getId() + user.getPassword();}
}

13、重新编译

13、接口访问,成功返回参数

五、GetMapping 用法

详细版见: https://www.yuque.com/chuxin-cs/spring-boot-demo/rb0vo3mme8ouibvo#hzswp

1、定义一个 GET 请求,访问:http://localhost:8080/user/add

package com.chuxin.democrud.controller;import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.PostMapping;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RestController;@RestController
@RequestMapping("/user")
public class UserController {// 增加@GetMapping("/add")public String add() {String result = "add";return result + "接口";}
}

2、改造 getList 方法,基于 RequestParam 接收前端传递过来的参数

代码如下:

package com.chuxin.democrud.controller;import org.springframework.web.bind.annotation.*;@RestController
@RequestMapping("/user")
public class UserController {// 查看@GetMapping("/getList")public String getList(@RequestParam int page, @RequestParam int pageSize) {return "getList:" + page + " " + pageSize;}
}

3、浏览器访问 http://localhost:8080/user/getList?page=1&pageSize=20

4、改造 getList1 方法,基于 PathVariable 接收前端传递过来的参数

代码如下:

package com.chuxin.democrud.controller;import org.springframework.web.bind.annotation.*;@RestController
@RequestMapping("/user")
public class UserController {// 查看@GetMapping("/getList1/{page}/{pageSize}")public String getList1(@PathVariable String page, @PathVariable String pageSize) {return "getList:" + page + " " + pageSize;}
}

5、运行代码

6、浏览器访问:http://localhost:8080/user/getList1/1/20

代码仓库

https://github.com/chuxin-cs/spring-boot-demo/tree/master/demo-crud

往期内容

点击链接查看:https://www.yuque.com/chuxin-cs/it/ge9wybczy0wsq1l1


http://www.ppmy.cn/ops/56231.html

相关文章

LLM - 神经网络的训练过程

1. 对于回归问题,用损失函数来计算预测值和真实值的差异,一种常用的公式是如下图所示(Mean Square Error),如果损失函数的值越小说明神经网络学习越准确,所以神经网络训练目标是减小损失函数的值, 2. 对于分类问题&…

ES6 Reflect 详解(三)

Reflect 对象与Proxy 对象一样,也是 ES6 为了操作对象而提供的新 API。 Reflect 对象的设计目的有 4 个。 将 Object 对象的一些明显属于语言内部的方法(比如 Object.defineProperty ),放到 Reflect 对象上。现阶段,某…

一款专业的 Windows 恶意程序分析与清理工具

大家好,今天给大家分享一款专业的 Windows 恶意程序分析与清理工具OpenArk,它能够帮助用户发现系统中隐藏的恶意软件。 OpenArk是一款Windows平台上的开源Ark工具. Ark是Anti-Rootkit(对抗恶意程序)的简写, OpenArk目标成为逆向工…

如何在word中敲出可以点击打勾和取消打勾的方框呢?

文章目录 要解决的问题网上出现的几种不可行的方案发现解决措施 要解决的问题 在word中敲出 点击就可以打对勾和取消对钩的方框 网上出现的几种不可行的方案 插入-> 符号,此方法打出的方框是fixed的,不是我想要的可以自己自主打勾和不打勾的方式。 …

ELK的储存、分析功能介绍!

ELK是由Elasticsearch、Logstash和Kibana三个开源软件组成的日志管理解决方案,它们在日志数据的储存和分析方面发挥着重要作用。 储存功能: Elasticsearch:Elasticsearch是一个基于Lucene的搜索服务器,它提供了一个分布式多用户能…

探索金融数据API:现代投资的关键工具

在当今快节奏的金融市场中,实时准确的数据对于投资者而言至关重要。金融数据API(Application Programming Interface)成为了投资者获取和管理数据的核心工具。本文将探讨金融数据API的基本概念、用途及其对投资策略的影响。 什么是金融数据A…

视频技术助力智慧城市一网统管:视频资源整合与智能化管理

随着信息技术的飞速发展,智慧城市已成为现代城市发展的重要方向。在智慧城市建设中,一网统管作为城市管理的重要策略,通过整合各类信息资源,实现资源的优化配置和问题的快速响应。其中,视频技术作为一网统管场景中的关…

【问题记录】Nodeclub运行make install报错npm ERR! code ELIFECYCLE

问题展示 按照官网给出的教程进行到make install这一步卡住了,显示了如下报错。 解决方法 将node.js版本变更为能够识别代码的版本,我将版本修改成了16.14.0以后成功运行。 nvm install 16.14.0