Express+Vercel+Github部署自己的Mock服务

起因和目标

做了个小工具需要mock数据,但是又不想自己写或者安装mock对应插件,只是想要一个能够访问的url快速响应一些数据,然后发现了mockend.com/ 这个网站。

官网是可以选择github托管JSON schema去更新数据,但是要钱。于是想着照着这个原理应该能自己搭一个偶尔用用吧。

于是一顿操作,找了一下Vercel可以拉取github的代码做免费部署,虽然也有流量限制,但是偶尔用用应该也够,结合express+github+vercel应该可以满足基本的mock数据,express接口定义和编写也可以自己修改,实现接口定制化自由。

步骤

  1. Vercel官网用github注册账号
  2. 新建一个github仓库,名字可以取自己好记的,到时候会用于访问的url。
  3. 提交代码到github
  4. Vercel导入对应的github仓库,然后Deploy,我是直接把node_modules也提交了,所以deploy的时候不用写什么命令,如果没有node_modules的话,应该要执行一下install。

主要代码解析

  1. 代码结构

mock-schemas存放需要访问的json数据,因为用了json-schema-faker去生成,所以放的是适合json-schema-faker用的数据。

  1. 主要代码
    index.js做了简单的处理,按照mock-schemas的文件名去返回结果

当访问url和文件名匹配,会读取json,通过json-schema-faker生成模拟数据并返回。这个只是简单的例子,可以在这个基础上扩充,加入url参数和代码逻辑定义复杂的mock接口

改动和更新

任何对主分支的 push / commit,Vercel都会触发部署。所以git提交修改内容,就会自动更新部署。如果想优化,可以通过git action去优化部署更新流程,比如只在json变动的时候去更新部署,感兴趣的可以查查相关的资料。

Github Demo 链接

相关推荐
wx_lidysun5 小时前
Nextjs学习笔记
前端·react·next
无羡仙7 小时前
从零构建 Vue 弹窗组件
前端·vue.js
源心锁8 小时前
👋 手搓 gzip 实现的文件分块压缩上传
前端·javascript
源心锁9 小时前
丧心病狂!在浏览器全天候记录用户行为排障
前端·架构
GIS之路9 小时前
GDAL 实现投影转换
前端
烛阴9 小时前
从“无”到“有”:手动实现一个 3D 渲染循环全过程
前端·webgl·three.js
BD_Marathon9 小时前
SpringBoot——辅助功能之切换web服务器
服务器·前端·spring boot
Kagol9 小时前
JavaScript 中的 sort 排序问题
前端·javascript
eason_fan10 小时前
Service Worker 缓存请求:前端性能优化的进阶利器
前端·性能优化
光影少年10 小时前
rn如何和原生进行通信,是单线程还是多线程,通信方式都有哪些
前端·react native·react.js·taro