SpringBoot 编写第一个 REST 接口(Get/Post/Put/Delete)

不管是做后台、微服务、前后端分离,第一步永远是写接口。

这一节我带你从零开始,一次性学会:

  • GET 查询

  • POST 新增

  • PUT 修改

  • DELETE 删除


一、先搞懂:REST 风格是什么?

简单记 4 个规范:

  • GET

    :查询数据(查)

  • POST

    :新增数据(增)

  • PUT

    :修改数据(改)

  • DELETE

    :删除数据(删)

不用记复杂理论,会用这 4 个注解就算学会 REST。


二、第一步:创建项目 & 必备依赖

只需要一个依赖:

go 复制代码
1<dependency>
2<groupId>org.springframework.bootgroupId>
3<artifactId>spring-boot-starter-webartifactId>
4dependency>

三、第二步:写第一个统一返回结果

前后端分离必须用统一格式:

go 复制代码
1importlombok.Data;
2
3@Data
4publicclassResult<T>{
5privateint code;
6privateString msg;
7privateT data;
8
9publicstatic<T>Result<T>success(T data){
10Result<T> r =newResult<>();
11        r.setCode(200);
12        r.setMsg("成功");
13        r.setData(data);
14return r;
15}
16
17publicstatic<T>Result<T>fail(String msg){
18Result<T> r =newResult<>();
19        r.setCode(500);
20        r.setMsg(msg);
21return r;
22}
23}

四、第三步:4 种接口实战

1. GET(查询)

go 复制代码
1@RestController
2@RequestMapping("/user")
3publicclassUserController{
4
5// 查询单个用户
6@GetMapping("/{id}")
7publicResult<String>getById(@PathVariableInteger id){
8returnResult.success("查询到用户:"+ id);
9}
10
11// 多条件查询
12@GetMapping("/list")
13publicResult<String>list(String name,Integer age){
14returnResult.success("查询列表:name="+ name +", age="+ age);
15}
16}

2. POST(新增)

go 复制代码
1// 新增用户(JSON 格式)
2@PostMapping
3publicResult<String>add(@RequestBodyUser user){
4returnResult.success("新增成功:"+ user.getUsername());
5}

3. PUT(修改)

go 复制代码
1// 修改用户
2@PutMapping
3publicResult<String>update(@RequestBodyUser user){
4returnResult.success("修改成功:"+ user.getId());
5}

4. DELETE(删除)

go 复制代码
1// 删除用户
2@DeleteMapping("/{id}")
3publicResult<String>delete(@PathVariableInteger id){
4returnResult.success("删除成功:"+ id);
5}

五、第四步:实体类 User

go 复制代码
1importlombok.Data;
2
3@Data
4publicclassUser{
5privateInteger id;
6privateString username;
7privateInteger age;
8}

六、测试接口

  • GET:http://localhost:8080/user/1

  • GET:http://localhost:8080/user/list?name=张三

  • POST:JSON 格式提交

  • PUT:JSON 格式提交

  • DELETE:http://localhost:8080/user/1


七、必须记住的 5 个注解

  1. @RestController

    :返回 JSON,不走页面

  2. @RequestMapping

    :统一前缀

  3. @GetMapping

    :查询

  4. @PostMapping

    :新增

  5. @RequestBody

    :接收 JSON


八、容易踩的坑

  1. 忘记加 @RestController → 404
  2. POST 没加 @RequestBody → 接收不到 JSON
  3. 请求方式不匹配(用 POST 访问 GET)→ 405
  4. 路径写错 → 404
  5. 返回值没统一 → 前端很难对接

九、总结

SpringBoot 写 REST 接口就 3 步:

  1. @RestController

  2. @GetMapping/@PostMapping/@PutMapping/@DeleteMapping

  3. 接收参数,返回统一结果

学会这一节,你已经具备后台开发基础能力了!


相关推荐
其实是白羊10 分钟前
CoderTools 1.5.3:让 AI 帮你看懂代码调用链路
后端·ai编程·vibecoding
妙码生花12 分钟前
从 PHP 到 AI + Golang,程序员自救转型手记(二):目录结构、初始化 GIT、设计并开发配置系统
前端·后端·go
千寻girling21 分钟前
一份不可多得的《微服务》教程
后端·面试·github
星沉远浦30 分钟前
用Gemini高效解决Java代码报错难以定位的问题
java
用户63623005716736 分钟前
NestJS实战-文章专栏功能模块
后端
洛阳泰山1 小时前
从 0 到 1.6K Star:一个 Java 开源项目的增长复盘
人工智能·后端·开源
铁皮饭盒2 小时前
Bun执行python代码
前端·javascript·后端
菜鸟谢2 小时前
Rust 枚举 (enum) 完整核心知识点
后端
晓杰在写后端3 小时前
从0到1实现Balatro游戏后端(9):Blind奖励结算与金币系统实现
后端·游戏开发
Patrick_Wilson3 小时前
幂等到底是什么?从前端视角讲透 SQL、HTTP 与 POST 接口的幂等设计
前端·后端·架构