解决:axios 请求头url传参数组时发生400错误

2024-09-05 02:52

本文主要是介绍解决:axios 请求头url传参数组时发生400错误,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

一、前言

  • axios封装的网络请求,url传参时,数组作为参数传递,发生400错误
  • 请求时数组参数url会保留 []

在这里插入图片描述

二、原因

RFC3986:除了 数字 + 字母 + -_.~ 不会被转义,其他字符都会被以百分号(%)后跟两位十六进制数 %{hex} 的方式进行转义

  • url 编码标准 RFC3986 是保留方括号的
  • 可能 axios 非最新版本也是一个原因,当前使用的"axios": "^1.7.2",据说最新版本是已经转换方括号了,没有试过…

三、解决方案

  • 一般 axios 自带 qs 模块,使用 qsparamsSerializer 方法序列化 params
  • 参考axios请求配置文档:https://www.axios-http.cn/docs/req_config
 // 解决数组url传参时参数带'[]'问题paramsSerializer: function (params) {return qs.stringify(params, { arrayFormat: "repeat" });},

在这里插入图片描述

  • 相关代码如下:

    1. 封装的axios文件request.js

      /**** Author: **** Date: 2024-09-04** Description: axios接口封装**/import axios from "axios";
      import { Message } from "element-ui";// create an axios instance  创建 axios 实例
      const service = axios.create({baseURL: process.env.VUE_APP_BASE_API, // url = base url + request urltimeout: 20000, // request timeoutheaders: {"Content-Type": "application/json;charset=UTF-8","x-requested-with": "XMLHttpRequest",},
      });let globalVarMsg = null; // 全局变量Msg,用于控制Message只弹出一次/*** request interceptor 请求拦截*/
      service.interceptors.request.use((config) => {return config;},(error) => {// do something with request errorreturn Promise.reject(error);}
      );
      /*** response interceptor 响应拦截*/
      service.interceptors.response.use((response) => {const status = response.status;const res = response.data;// if the custom code is not 20000, it is judged as an error.if (!res.success && response.config.headers.popUps !== false) {if (!globalVarMsg) {globalVarMsg = true;Message({message:status != 200 ? "系统开小差,请稍后再试" : res.msg || "未知错误",type: "error",duration: 5 * 1000,onClose: () => {globalVarMsg = null;},});}}return res;},(error) => {const msg = error.response?.data?.message || "";if (!globalVarMsg) {globalVarMsg = true;Message({message: msg || error.message || "系统开小差,请稍后再试",type: "error",duration: 5 * 1000,onClose: () => {globalVarMsg = null;},});}return Promise.reject(error);}
      );export default service;
    2. 接口文件 manage.js

      /***   接口-管理*/
      import request from "@/utils/request";       // 上面封装的request.js文件
      const qs = require("qs");                    // 一般 axios 自带 qs 模块const api = {delEvents: "/rest/event/batch/delete",
      };/*** 批量删除事件*/
      export function delEvents(params) {return request({url: api.delEvents,method: "delete",params: params,// 解决数组url传参时参数带'[]'问题paramsSerializer: function (params) {return qs.stringify(params, { arrayFormat: "repeat" });},});
      }
      

四、qs 的常用 arrayFormat 参数

qs地址:https://github.com/ljharb/qs

qs镜像中文地址:https://gitcode.com/gh_mirrors/qs/qs/overview?utm_source=csdn_github_accelerator&isLogin=1

qs.stringify({ a: ['b', 'c', 'd'] });  // 数组字符串化遵循 arrayFormat 选项,默认为 indices:
// 结果为 'a[0]=b&a[1]=c&a[2]=d'
qs.stringify({ a: ['b', 'c', 'd'] }, { indices: false });// 结果为 'a=b&a=c&a=d'
qs.stringify({ a: ['b', 'c'] }, { arrayFormat: 'indices' })// 结果为 'a[0]=b&a[1]=c'
qs.stringify({ a: ['b', 'c'] }, { arrayFormat: 'brackets' })// 结果为 'a[]=b&a[]=c'
qs.stringify({ a: ['b', 'c'] }, { arrayFormat: 'repeat' })// 结果为 'a=b&a=c'
qs.stringify({ a: ['b', 'c'] }, { arrayFormat: 'comma' })// 结果为 'a=b,c'

这篇关于解决:axios 请求头url传参数组时发生400错误的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1137765

相关文章

IDEA编译报错“java: 常量字符串过长”的原因及解决方法

《IDEA编译报错“java:常量字符串过长”的原因及解决方法》今天在开发过程中,由于尝试将一个文件的Base64字符串设置为常量,结果导致IDEA编译的时候出现了如下报错java:常量字符串过长,... 目录一、问题描述二、问题原因2.1 理论角度2.2 源码角度三、解决方案解决方案①:StringBui

部署Vue项目到服务器后404错误的原因及解决方案

《部署Vue项目到服务器后404错误的原因及解决方案》文章介绍了Vue项目部署步骤以及404错误的解决方案,部署步骤包括构建项目、上传文件、配置Web服务器、重启Nginx和访问域名,404错误通常是... 目录一、vue项目部署步骤二、404错误原因及解决方案错误场景原因分析解决方案一、Vue项目部署步骤

如何使用Java实现请求deepseek

《如何使用Java实现请求deepseek》这篇文章主要为大家详细介绍了如何使用Java实现请求deepseek功能,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 目录1.deepseek的api创建2.Java实现请求deepseek2.1 pom文件2.2 json转化文件2.2

mybatis和mybatis-plus设置值为null不起作用问题及解决

《mybatis和mybatis-plus设置值为null不起作用问题及解决》Mybatis-Plus的FieldStrategy主要用于控制新增、更新和查询时对空值的处理策略,通过配置不同的策略类型... 目录MyBATis-plusFieldStrategy作用FieldStrategy类型每种策略的作

Android 悬浮窗开发示例((动态权限请求 | 前台服务和通知 | 悬浮窗创建 )

《Android悬浮窗开发示例((动态权限请求|前台服务和通知|悬浮窗创建)》本文介绍了Android悬浮窗的实现效果,包括动态权限请求、前台服务和通知的使用,悬浮窗权限需要动态申请并引导... 目录一、悬浮窗 动态权限请求1、动态请求权限2、悬浮窗权限说明3、检查动态权限4、申请动态权限5、权限设置完毕后

Python Jupyter Notebook导包报错问题及解决

《PythonJupyterNotebook导包报错问题及解决》在conda环境中安装包后,JupyterNotebook导入时出现ImportError,可能是由于包版本不对应或版本太高,解决方... 目录问题解决方法重新安装Jupyter NoteBook 更改Kernel总结问题在conda上安装了

Goland debug失效详细解决步骤(合集)

《Golanddebug失效详细解决步骤(合集)》今天用Goland开发时,打断点,以debug方式运行,发现程序并没有断住,程序跳过了断点,直接运行结束,网上搜寻了大量文章,最后得以解决,特此在这... 目录Bug:Goland debug失效详细解决步骤【合集】情况一:Go或Goland架构不对情况二:

解决jupyterLab打开后出现Config option `template_path`not recognized by `ExporterCollapsibleHeadings`问题

《解决jupyterLab打开后出现Configoption`template_path`notrecognizedby`ExporterCollapsibleHeadings`问题》在Ju... 目录jupyterLab打开后出现“templandroidate_path”相关问题这是 tensorflo

如何解决Pycharm编辑内容时有光标的问题

《如何解决Pycharm编辑内容时有光标的问题》文章介绍了如何在PyCharm中配置VimEmulator插件,包括检查插件是否已安装、下载插件以及安装IdeaVim插件的步骤... 目录Pycharm编辑内容时有光标1.如果Vim Emulator前面有对勾2.www.chinasem.cn如果tools工

在MySQL执行UPDATE语句时遇到的错误1175的解决方案

《在MySQL执行UPDATE语句时遇到的错误1175的解决方案》MySQL安全更新模式(SafeUpdateMode)限制了UPDATE和DELETE操作,要求使用WHERE子句时必须基于主键或索引... mysql 中遇到的 Error Code: 1175 是由于启用了 安全更新模式(Safe Upd