get请求400报错 params参数带有[]括号

文章讲述了在开发搜索功能时遇到的问题,即当参数传递包含[]时,后端Tomcat会报400错误,因为特殊字符没有正确转义。为了解决这个问题,作者提供了一个方法,该方法能自动将params转换为字符串,确保特殊字符如括号得到转义,从而可以安全地添加到URL中。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

写搜索功能的时候,被测试发现,如果参数传[],接口就会报400,研究了下发现[]被后端tomcat拦截了,不会转译成%XX这种参数,
比如花括号 { 会转译成 %7B,不知道为啥ASCII码的对照表图片放不上来,下次再放了

参考百度百科里面的图片:https://baike.baidu.com/pic/ASCII/309296/1/e850352ac65c103880a07b53bc119313b17e8941?fr=lemma&fromModule=lemma_top-image&ct=single#aid=1&pic=e850352ac65c103880a07b53bc119313b17e8941

那么要如何解决这个问题呢?那就不传params,直接url里面把参数都带上就行

const getEncodeUrl = (params) => {
  const arr = [];
  for (const item in params) {
    if (Object.prototype.hasOwnProperty.call(params, item)) {
      const nowData = params[item];
      try {
        params[item] = encodeURIComponent(decodeURIComponent(nowData));
      } catch (err) {
        const reg = new RegExp(/\%/, 'g');
        params[item] = encodeURIComponent(decodeURIComponent(nowData.replace(reg, '%25')));
      }
      arr.push(item + '=' + params[item]);
    }
  }
  let encodeUrl = '';
  if (arr.length > 0) {
    encodeUrl = '?' + arr.join('&');
  }
  return encodeUrl;
};

写了个方法,自动把params转成字符串,括号这种特殊字符会自动转译, 最后在get url后面加上这个方法就行了

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值