当前位置: 首页 > news >正文

[mockjs]Mock使用过程中的坑

[mockjs]Mock使用过程中的坑

  • 现象描述
  • 原因分析
  • 解决方案
    • 修改源码
    • 处理无法识别的文件流

现象描述

mockjs在使用的过程中出现了下载文件无法正常打开的问题,但是在线上环境是正常的

console.log打印返回的response,发现是本地无法正常解析response.data

在代码中,该请求设置了responseType:blob,所以正常情况下接收的response.data应该是blob类型

data: Blob{size: 4608,type: "application/vnd.ms-excel"}

在使用了 mockjs 的情况下,接收到的response.data不是文件流,而是string类型

data: '��\x11ࡱ\x1A�\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00;\x00\x03\x00��\t\x00\x06\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x01\x00\x00\x00\x00\x00\x00\x00…\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00',

原因分析

两者的区别是线上环境是没有使用mockjs的

mockjs源码中responseType的值被覆盖了,导致mockjs开启的情况下,调用真实接口responseType无法使用设置的值

解决方案

修改源码

 this.custom.xhr.responseType = this.responseType //复制原始XHR的responseTypethis.custom.xhr.send(data)//源代码

该方式是直接对mockjs中/src/mock/xhr/xhr.js文件进行修改,但是该方式只有原作者修改并上传才不会影响下次的使用,否则更改的是本地的,对于每次初始化时重新下载了mockjs无法从根本上解决

处理无法识别的文件流

mockjs源码导致了文件流被responseType:'json’解析了,因此无法正确识别,因此,我们只需在将转换为json的response.data重新转换为需要的类型。
例如 arrayBuffer,可以对接收到的res.data:

new Uint8Array(res.data)

例如 blob ,可以对接收到的res.data:

const blob=new Blob([JSON.stringify(res.data)], { type: "application/json" })

mockjs 引用导致responseType:"blob"被重写为json了,因此需要把转成json的数据重新转为想要的格式,按照上述方式转化,下载文件恢复正常

http://www.lryc.cn/news/168265.html

相关文章:

  • 华为云云耀云服务器L实例评测|部署前后端分离项目
  • 02目标检测-传统检测方法
  • RP-母版 流程图 发布和预览 团队项目
  • 【第200篇原创文章】解决低于1%概率出现的芯片VPSS模块跑飞的问题
  • 微信小程序——生命周期详解(代码解读)
  • 多分类中混淆矩阵的TP,TN,FN,FP计算
  • Linux系统:OpenSSH7.4p升级到9.0p(服务器漏洞)
  • 【面试刷题】——C++的特点简单说明
  • C2基础设施威胁情报对抗策略
  • 差异备份详细说明(InsCode AI 创作助手)
  • flask要点与坑
  • EasyUI combobox 实现搜索(模糊匹配)功能
  • Postman的高级用法一:重新认识postman核心模块
  • git命令的操作
  • 超级详细 SQL 优化大全
  • 数据治理-数据存储和操作-数据库组织模型
  • IDEA最新激 20活23码
  • flutter产物以aar形式嵌入android原生工程
  • C++语法
  • antd react 文件上传只允许上传一个文件且上传后隐藏上传按钮
  • C语言指针进阶(2)
  • 51 单片机 led 灯光操作
  • VSCODE 使用技巧
  • 数据库安全(Mysql,Hadoop,Redis)
  • C【动态内存管理】
  • Javase | 集合-上
  • Multitor:一款带有负载均衡功能的多Tor实例创建工具
  • AIGC专栏6——通过阿里云与AutoDL快速拉起Stable Diffusion和EasyPhoto
  • Mysql的逻辑架构、存储引擎
  • [ES6]模块