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 链接

相关推荐
_膨胀的大雄_2 分钟前
01-创建型模式
前端·设计模式
小林rush5 分钟前
uni-app跨分包自定义组件引用解决方案
前端·javascript·vue.js
我的一行6 分钟前
已有项目,接入pnpm + turbo
前端·vue.js
亮子AI7 分钟前
【Svelte】怎样实现一个图片上传功能?
开发语言·前端·javascript·svelte
心.c8 分钟前
为什么在 Vue 3 中 uni.createCanvasContext 画不出图?
前端·javascript·vue.js
咸鱼加辣10 分钟前
【vue面试】ref和reactive
前端·javascript·vue.js
LYFlied11 分钟前
【每日算法】LeetCode 104. 二叉树的最大深度
前端·算法·leetcode·面试·职场和发展
汤姆Tom12 分钟前
前端转战后端:JavaScript 与 Java 对照学习指南(第五篇 —— 面向对象:类、接口与多态)
java·前端·后端
宁雨桥16 分钟前
前端并发控制的多种实现方案与最佳实践
前端