最新公告
  • 欢迎您光临起源地模板网,本站秉承服务宗旨 履行“站长”责任,销售只是起点 服务永无止境!立即加入钻石VIP
  • 关于过大的请求参数被改变导致请求数据失败(404)的问题

    正文概述 掘金(宁静_致远)   2021-07-11   687

    场景

    当我们请求某一个数据的具体内容的时候,我们可能需要在发起请求的时候传入该数据具体内容的 id 作为请求参数,以此匹配当对应的数据内容。

    而这个 id ,也通常都是我们之前发送请求从服务端获取的

    当我们的数据较多的时候,服务器返回给我们的 id 可能是一个很大的数字。

    这个时候我们携带这个 id 去请求数据,会发现浏览器报错

    Error: Request failed with status code 404
    

    404: 表示服务器没有找到对应的资源,是我们的参数错了吗?

    分析

    我们通过 浏览器 调试工具去查看我们之前获取的 id

    后端返回给我们的数据,通常都是 JSON 格式的字符串

    '{ "id": 9007199254740995, "name": "Jack", "age": 18 }'
    

    我们需要将这个字符串,用JSON.parse()转化成对象,才能供我们方便的使用数据

    一般 axios 会在内部帮我们处理好数据直接返回给我们

    那么现在我们将这个数据转化为 对象

      var res = JSON.parse(
            '{ "id": 9007199254740995, "name": "Jack", "age": 18 }'
          )
          console.log(res)
    

    我们发现输出结果

     Object: {
            age: 18
            id: 9007199254740996
            name: "Jack"
            __proto__: Object
          }
    

    这里解析出来的 id 比之前 服务器返回给我们的 id 要大1

    这是因为 JS 语言自身的原因:

    JavaScript 能够准确表示的整数范围在-2^532^53之间(不含两个端点),超过这个范围,无法精确表示这个值,这使得 JavaScript 不适合进行科学和金融方面的精确计算。

    Math.pow(2, 53) // 9007199254740992
    
    9007199254740992  // 9007199254740992
    9007199254740993  // 9007199254740992
    

    所以当我们再用这个 被解析错误的 id 再去发起请求,服务器自然是找不到对应的资源。

    解决

    json-bigint 是一个第三方包,它可以帮我们很好的处理这个问题。

    使用步骤

    • 安装

      npm i json-bigint
      
    • 导入

      import jsonBig from 'json-bigint'
      
    • 基本使用(具体看官方文档,这里只说怎么解决这个问题的使用)

       var overDate = '{"value": 9007199254740993,"name": "booker"}'
            console.log(jsonBig.parse(overDate))
      

      返回一个对象

      {value: BigNumber, name: "booker"}
      {
       name: "booker"
       value: BigNumber
      	c: (2) [90, 7199254740993]
      	e: 15
      	s: 1
       __proto__: Object
      }
      

      通过这个方法解析的对象,过大的数字会被转化成一个对象BigNumber

      **注意:**我们可以直接用这个数作为参数,因为字符串拼接的途中会自动将对象转化成字符串类型

       console.log('booker' + res.value)
       // booker9007199254740993
      

    在axios 中配置使用

    const request = axios.create({
      baseURL: '接口基础路径', // 接口基础路径
    
      // transformResponse 允许自定义原始的响应数据(字符串)
      transformResponse: [function (data) {
        try {
          // 如果转换成功则返回转换的数据结果
          return jsonBig.parse(data)
        } catch (err) {
          // 如果转换失败,则包装为统一数据格式并返回
          return {
            data
          }
        }
      }]
    })
    
    export default request
    

    起源地下载网 » 关于过大的请求参数被改变导致请求数据失败(404)的问题

    常见问题FAQ

    免费下载或者VIP会员专享资源能否直接商用?
    本站所有资源版权均属于原作者所有,这里所提供资源均只能用于参考学习用,请勿直接商用。若由于商用引起版权纠纷,一切责任均由使用者承担。更多说明请参考 VIP介绍。
    提示下载完但解压或打开不了?
    最常见的情况是下载不完整: 可对比下载完压缩包的与网盘上的容量,若小于网盘提示的容量则是这个原因。这是浏览器下载的bug,建议用百度网盘软件或迅雷下载。若排除这种情况,可在对应资源底部留言,或 联络我们.。
    找不到素材资源介绍文章里的示例图片?
    对于PPT,KEY,Mockups,APP,网页模版等类型的素材,文章内用于介绍的图片通常并不包含在对应可供下载素材包内。这些相关商业图片需另外购买,且本站不负责(也没有办法)找到出处。 同样地一些字体文件也是这种情况,但部分素材会在素材包内有一份字体下载链接清单。
    模板不会安装或需要功能定制以及二次开发?
    请QQ联系我们

    发表评论

    还没有评论,快来抢沙发吧!

    如需帝国cms功能定制以及二次开发请联系我们

    联系作者

    请选择支付方式

    ×
    迅虎支付宝
    迅虎微信
    支付宝当面付
    余额支付
    ×
    微信扫码支付 0 元