/request-Interceptor-mock

基于浏览器插件来对请求进行拦截修改

Primary LanguageJavaScriptMIT LicenseMIT

安装依赖

cnpm install

cnpm run build

yarn 安装 会导致 ReactJson 组件报错 pnpm 安装 会导致@douyinfe/semi-ui 安装不全

mT 插件功能列表:

  • 拦截所有的请求
    • 难点在与设计代理 xhr 对象,覆盖属性和监听方法
    • 对于修改请求头的信息,需要放在 readystate 等于 1 的时候修改
    • 对于同一属性比如 timeout 插件设置的值要覆盖用户设置的值
  • 可视化输出及交互数据
    • 通信时机如何设计,需要 background content pagescript 三方通信以及数据交互来满足一些需求
    • popup 的交互需要改变 pageScript 执行的代码数据
    • 代理的 xhr 对象需要在所有请求前面之前运行,但是必须又要先通过通信拿到保存的数据,这样可能导致有部分请求在挂载之前就发送出去了
  • 替换状态码、响应头、body 数据
    • 如果接口报 404 那么要支持手动改成 200

已完成功能

  • 2022/7/17: 支持 url 分类展示
  • 2022/6/30: 支持 manifest_versionV3 版本
  • 2022/6/29: 支持单个请求配置代理地址
  • 2022/6/03: 全局设置支持对同一域名下的请求配置拦截
  • 2022/5/27: 支持输入内容检索请求接口
  • 2022/5/02: 支持 404 时,客户端能够使用自定义 mock 数据
  • 2022/4/24: 支持全屏展示、切换 mock 数据和原生响应数据
  • 2022/4/22:增加统一复制操作按钮
  • 2022/4/06:已支持 fetch 请求
  • 2022/3/20: 已支持 xhr 请求修改发送、响应数据

问题总结:

  • 改为 iframe 渲染后,通信链路很长,之前 popup 用 div 渲染,跟 pagescript 通信和 content 通信很方便,现在两者之前通信都要通过 background,和 content 做跳转。 1.比如展开和收缩,popup 只能发送消息到 background,然后在转发到 content 改变 iframe 的样式, 2.更新 mock 列表,pagescript 只能发送消息到 content,content 到 background,然后 background 在发送到 popup。
  • 当 Access-Control-Allow-Origin 的值为 '*' 的时候跨域请求不允许携带认证

效果图

'效果图'

最新版

img

待更新

  • 手动请求
  • 接入 mock 规则造数据
  • 完善动画交互/ui 界面
  • 。。。