【bug记录】mockjs导致polyv上传插件上传失败问题

10 篇文章 0 订阅
5 篇文章 0 订阅

环境:polyv上传插件,生产环境上传失败,测试环境成功

问题代码:

main.js生产环境中运行了mockXHR方法

import { mockXHR } from '../mock'
if (process.env.NODE_ENV === 'production') {
    mockXHR()
}
export function mockXHR() {
  // mock patch
  // https://github.com/nuysoft/Mock/issues/300
  Mock.XHR.prototype.proxy_send = Mock.XHR.prototype.send
  Mock.XHR.prototype.send = function() {
    if (this.custom.xhr) {
      this.custom.xhr.withCredentials = this.withCredentials || false

      if (this.responseType) {
        this.custom.xhr.responseType = this.responseType
      }
    }
    this.proxy_send(...arguments)
  }

  function XHR2ExpressReqWrap(respond) {
    return function(options) {
      let result = null
      if (respond instanceof Function) {
        const { body, type, url } = options
        // https://expressjs.com/en/4x/api.html#req
        result = respond({
          method: type,
          body: JSON.parse(body),
          query: param2Obj(url)
        })
      } else {
        result = respond
      }
      return Mock.mock(result)
    }
  }

  for (const i of mocks) {
    Mock.mock(new RegExp(i.url), i.type || 'get', XHR2ExpressReqWrap(i.response))
  }
}

问题原因:mockXHR执行后,XHR请求来会被拦截,使用内部MockXMLHttpRequest来替代原生的XMLHttpRequest,原生XMLHttpRequest已被覆盖,load成功后,得到返回值是buffer,需要进行解析,responseType需要是'arrayBuffer'类型,但是mockXHR方法中没有把responseType进行设置,而是设置成了空值。因此无法解析成功。

解决办法:判断只在开发环境使用,生产弃用

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值