Controller中接收数组参数 post请求中在body中传+post请求中通过表单形式传(x-www-form-urlencoded)

1、场景

需要根据用户id集合批量删除用户数据,前端使用post请求,controller中参数接收数组参数并根据用户id删除用户基本信息

2、分析处理:
2.1、前端请求类型contentType:application/json

请求体中为json字符串,后端新建一个UserDTO(用户数据传输类),用于接收前端json参数。

复制代码
    在controller参数体中直接使用@RequestBody UserDTO userDTO即可将前端数组自动转化为userDTO中对应的属性

前端请求及后端返回值:

controller

userDTO中需要包含name、ids属性,如下:

2.2、前端请求类型contentType:application/x-www-form-urlencoded(form表单提交)

需要注意的是,上图中不是选择的form-data (这是get请求通过表单形式提交应该选择的)
controller

实例代码:

** 实战 :后台使用:@RequestParam("userId") Long userId 这种的,前台该怎么传参**

java 复制代码
后端代码:

   //获取用户信息 通过id
    @GetMapping("/getUserById")
    @Operation(method = "GET", summary = "根据id查询用户信息")
    public Result<UserResVO> getUserInfoById(@RequestParam("userId") Long userId) {
        if (ObjectUtil.isEmpty(userId)) {
            return Result.fail(Constant.ErrorCode, "用户id不能为空");
        }
        return userService.getUserInfoById(userId);
    }
javascript 复制代码
Vue
前段js代码-定义方法
// 结算单详情
export function getUserInfoById(id) {
  return request({
    url: '/User/getUserById',
    method: 'get',
    params: {userId: id},
  });
}


//前端vue中的写法--引用方法
import {getUserInfoById} from  user.js

//使用:
function getUserDetail() {
  getUserInfoById(detailId.value).then((res) => {
    detailOb.value = res.data;
    。。。。。。
	}

实战:后台使用:@PathVariable(name="userId") Long userId 这种的,前台该怎么传参

参考:
Controller中接收数组参数

相关推荐
Full Stack Developme几秒前
G1回收器的工作机制
java·jvm
砍材农夫4 分钟前
物联网实战:Spring Boot + Netty 搭建 MQTT平台 | 多协议适配与模块化设计
java·spring boot·后端·物联网·spring
云烟成雨TD6 分钟前
Spring AI 1.x 系列【41】接入高德 MCP 服务
java·人工智能·spring
winlife_9 分钟前
全程用 AI 做一款商业级手游 · EP7 表现层与手感:从“能跑“到“摸起来爽“
java·开发语言·人工智能·unity·ai编程·游戏开发·mcp
千纸鹤の脉搏10 分钟前
多线程的初步使用
java·开发语言·学习·多线程
一个儒雅随和的男子16 分钟前
MQTT常见的问题?
java
Mr.456716 分钟前
Netty中实现设备消息串行处理:Semaphore + 线程池
java·后端
2601_9611940218 分钟前
考研资料电子版|下载|pdf
java·python·考研·eclipse·django·pdf·pygame
骄马之死21 分钟前
JVM 核心知识
java·jvm
好家伙VCC25 分钟前
Rust+Bioinfo:80ms极速SNP注释引擎
java·开发语言·算法·rust