Spring mysql 网络接口( HTTP 方法与增删改查, Spring MVC Controller 接收参数的常用注解与参数传递方式)

前言

最近在看接口文档, 和写项目的增删改查时, 老是搞不清楚HTTP 方法、参数传递方式 以及 Spring MVC Controller 层接收参数的常用注解之间的关系( 只是我经常看见的总结一下, 不一定对, 也很不完整哈 ).

目录

    • 前言
    • [一、**HTTP 方法与增删改查**( RESTful风格常用规范 )](#一、HTTP 方法与增删改查( RESTful风格常用规范 ))
    • [二 HTTP 方法与参数传递方式( 只是我经常碰见的我自己总结的 )](#二 HTTP 方法与参数传递方式( 只是我经常碰见的我自己总结的 ))
    • [三 Spring MVC Controller 接收参数的常用注解与参数传递方式](#三 Spring MVC Controller 接收参数的常用注解与参数传递方式)
      • [1. @RequestParam ------ 接收 URL查询参数(URL后面带?key1=value1&key2=value2)](#1. @RequestParam —— 接收 URL查询参数(URL后面带?key1=value1&key2=value2))
      • [2. @PathVariable ------ 接收 URL 路径中的变量](#2. @PathVariable —— 接收 URL 路径中的变量)
      • [3. @RequestBody ------ 接收 请求体中的 JSON/XML 数据](#3. @RequestBody —— 接收 请求体中的 JSON/XML 数据)

一、HTTP 方法与增删改查( RESTful风格常用规范 )

记个口诀就好大概是这样: 增加用POST, 删除用DELETE, 修改用PUT, 查询用GET

二 HTTP 方法与参数传递方式( 只是我经常碰见的我自己总结的 )

HTTP 方法 典型用途 参数传递位置 是否有请求体(Body)
POST 新增数据 请求体(Body)(JSON / Form 表单) ✅ 有
DELETE 删除数据 URL 路径参数 或 查询参数 ❌ 通常无
PUT 更新数据 请求体(Body ✅ 有
GET 查询数据 URL查询参数(后面带?key1=value1&key2=value2) 或者路径参数 (/user/{id}) ❌ 一般没有(即使有也不被推荐/支持)

三 Spring MVC Controller 接收参数的常用注解与参数传递方式

1. @RequestParam ------ 接收 URL查询参数(URL后面带?key1=value1&key2=value2)

  • 适用场景:GET 查询参数、POST 表单(application/x-www-form-urlencoded)
  • 参数来源:URL 中的 ?name=Tom 或 表单字段
java 复制代码
@GetMapping("/search")
public String search(@RequestParam String keyword, 
                     @RequestParam(defaultValue = "1") int page) {
    // 请求: /search?keyword=Java&page=2
}

2. @PathVariable ------ 接收 URL 路径中的变量

  • 适用场景:RESTful 风格的路径参数
  • 参数来源:URL 路径中的 {xxx} 占位符
java 复制代码
@GetMapping("/user/{id}")
public User getUser(@PathVariable Long id) {
    // 请求: /user/123 → id = 123
}

// 多个路径变量
@GetMapping("/dept/{deptId}/user/{userId}")
public User getUserInDept(@PathVariable("deptId") Long did,
                          @PathVariable("userId") Long uid) { ... }

3. @RequestBody ------ 接收 请求体中的 JSON/XML 数据

  • 适用场景:前端发送 JSON(如 Axios、Fetch)
  • 参数来源:HTTP 请求体(Body)
  • 仅用于 POST/PUT/PATCH
java 复制代码
@PostMapping("/user")
public Result save(@RequestBody UserDTO userDTO) {
    // 前端发送 JSON:
    // { "name": "Alice", "email": "alice@example.com" }
}

小白啊!!!写的不好轻喷啊🤯如果觉得写的不好,点个赞吧🤪(批评是我写作的动力)

...。。。。。。。。。。。...

...。。。。。。。。。。。...

相关推荐
闪电悠米2 分钟前
黑马点评短信登录01_session_sms_login
java·spring boot·redis·git·spring·面试
爱吃土豆的马铃薯ㅤㅤㅤㅤㅤㅤㅤㅤㅤ2 分钟前
MySQL选择字符集和排序规则
数据库·mysql
努力努力再努力wz3 分钟前
【QT入门系列】QWidget 六大常用属性详解:windowOpacity、cursor、font、focus、toolTip 与 styleSheet
android·开发语言·数据结构·c++·qt·mysql·算法
艾莉丝努力练剑8 分钟前
【Linux网络】Linux 网络编程:HTTP(三)HTTP 协议原理
linux·运维·服务器·网络·c++·http
云烟成雨TD10 分钟前
Spring AI Alibaba 1.x 系列【56】SAA Admin 平台功能介绍
java·人工智能·spring
周易宅13 分钟前
Docker MySQL 8.0.45 性能优化配置文档
mysql·docker·性能优化
一条泥憨鱼20 分钟前
深入理解 MySQL 索引:原理、分类与优化实战
数据库·mysql
一条泥憨鱼21 分钟前
详解MySQL事务(超详细版)
java·数据库·mysql·spring·maven·后端开发
j7~22 分钟前
【MYSQL】 数据库的常见数据类型--详解
数据库·mysql·decimal·varchar·数据库的基本类型
二哈赛车手9 小时前
新人笔记---ApiFox的一些常见使用出错
java·笔记·spring