解析 ID 数组传参的解决方案:基于 Axios 的实现

解析 ID 数组传参的解决方案:基于 Axios 的实现

在实际开发中,经常需要将一个 ID 数组作为参数传递给后端接口。然而,不同的后端框架和前端库对数组参数的处理方式可能有所不同。通过一个具体的例子,在前端使用 Axios 框架发送 ID 数组,并在后端正确接收和处理这些参数。

请求的URL示例:/admin/lzWithdrawal//setTransfer/batch?ids=1,2,3

注意:

URL query请求方式(即?ids=1,2,3)
前端的 params: { ids },

paramsSerializer: (params) => qs.stringify(params, { arrayFormat: 'comma' }),
后端的 @RequestParam("ids") List ids
是一组固定搭配。
少加 任意一个,或者写成@RequestBody 、少加paramsSerializer ,都有可能联调失败
如果改成@RequestBody 即请求体传参,该文章不适用

前端代码:使用 Axios 发送 ID 数组

假设我们有一个批量转账的功能,需要将一组 ID 传递给后端接口。以下是前端代码的实现:

javascript 复制代码
import axios from 'axios';
import qs from 'qs';

export function batchTransfer(ids) {
  return axios({
    url: '/admin/lzWithdrawal/setTransfer/batch',
    method: 'post',
    params: { ids },
    paramsSerializer: (params) => qs.stringify(params, { arrayFormat: 'comma' }),
  });
}

代码解析

  1. 引入 Axios 和 qs

    • axios 是一个基于 Promise 的 HTTP 客户端,用于浏览器和 node.js。
    • qs 是一个用于序列化和解析 URL 查询字符串的库,它可以帮助我们将数组参数正确地转换为查询字符串。
  2. 构造请求

    • 我们使用 axios 构造了一个 POST 请求,目标 URL 是 /admin/lzWithdrawal/setTransfer/batch
    • params 是一个对象,包含我们要传递的参数。在这个例子中,我们只传递了一个名为 ids 的数组。
    • paramsSerializer 是一个函数,它将 params 对象序列化为查询字符串。我们使用了 qs.stringify 方法,并设置了 arrayFormat: 'comma',这表示数组参数将以逗号分隔的形式发送(例如 ids=1,2,3)。

后端代码:接收和处理 ID 数组

后端代码使用了 Spring Boot 框架,以下是对应的控制器方法:

java 复制代码
import org.springframework.web.bind.annotation.*;
import java.util.List;

@RestController
@RequestMapping("/admin/lzWithdrawal")
public class WithdrawalController {

    @PostMapping("/setTransfer/batch")
    public R setTransferBatch(@NotEmpty @RequestParam("ids") List<Long> ids) {
        ids.parallelStream().forEach(id -> {
            withdrawalService.lambdaUpdate()
                .eq(TpLzWithdrawal::getId, id)
                .set(TpLzWithdrawal::getStatus, 2)
                .update();
        });
        return R.ok(true);
    }
}

代码解析

  1. @RequestParam 注解

    • @RequestParam("ids") 表示从请求的查询参数中获取名为 ids 的参数,并将其绑定到方法参数 List<Long> ids 上。
    • Spring Boot 默认会将逗号分隔的字符串解析为数组或列表,因此前端发送的 ids=1,2,3 会被正确解析为一个 List<Long>
  2. 并行流处理

    • 使用 ids.parallelStream() 创建一个并行流,对每个 ID 进行处理。
    • 在流的 forEach 方法中,我们调用了 withdrawalServicelambdaUpdate 方法,更新对应 ID 的状态。

前端调用

假设我们有一个 ID 数组 [1, 2, 3],调用 batchTransfer 方法:

javascript 复制代码
batchTransfer([1, 2, 3])
  .then(response => {
    console.log('Success:', response.data);
  })
  .catch(error => {
    console.error('Error:', error);
  });

请求的URL示例:/admin/lzWithdrawal//setTransfer/batch?ids=1,2,3

相关推荐
D_alyoo8 分钟前
06 Activiti 与 Spring Boot 整合
java·activiti·activiti7源码
小陈不好吃13 分钟前
Spring Boot配置文件加载顺序详解(含Nacos配置中心机制)
java·开发语言·后端·spring
星光一影13 分钟前
Spring Boot 3+Spring AI 打造旅游智能体!集成阿里云通义千问,多轮对话 + 搜索 + PDF 生成撑全流程
人工智能·spring boot·spring
ゞ 正在缓冲99%…20 分钟前
leetcode1770.执行乘法运算的最大分数
java·数据结构·算法·动态规划
渡我白衣25 分钟前
链接的迷雾:odr、弱符号与静态库的三国杀
android·java·开发语言·c++·人工智能·深度学习·神经网络
007php00739 分钟前
大厂深度面试相关文章:深入探讨底层原理与高性能优化
java·开发语言·git·python·面试·职场和发展·性能优化
掘金安东尼44 分钟前
前端周刊第439期(2025年11月3日–11月9日)
前端·javascript·vue.js
qq_334466861 小时前
excel VBA应用
java·服务器·excel
E_ICEBLUE1 小时前
快速合并 Excel 工作表和文件:Java 实现
java·microsoft·excel
有蝉1 小时前
vue-office——支持多种文件(docx、excel、pdf)预览的vue组件库,支持vue2/3。也支持非Vue框架的预览。
vue.js·pdf·excel