一个“不需要”写代码 的 mock & 代理 工具

ruoxie一个“不需要”写代码 的 mock & 代理 工具

一个“不需要”写代码 的 mock & 代理 工具

install

yarn create @lowcoding/mock

start

yarn start

mock server 默认在本地 3000 端口启动,访问 http://localhost:3000/ 即可。

lowcode-mock 默认支持跨域,前端项目中可不必再配置代理,直接请求 lowcode-mock 起的服务即可。

mock

src\routes 目录下新建一个 js 文件,将如下内容复制进去保存即可:

import KoaRouter from 'koa-router'
import proxy from '../middleware/Proxy'
import { delay } from '../lib/util'
let Mock = require('mockjs')
let Random = Mock.Random

const router = new KoaRouter()
router.get('/your-mock-api', (ctx) => {
	ctx.body = '你的第一个 mock 接口'
})
module.exports = router

使用 vscode 插件 yapi-code ,可直接根据 JSON 数据或者 YAPI 接口定义自动生成 mock 接口以及 mock 数据。

根据 YAPI 生成 mock

复制 YAPI 上接口 id,比如 https://你的 yapi 地址 /project/869/interface/api/14037 最后面的数字部分

一个“不需要”写代码 的 mock & 代理 工具

访问创建的 mock 接口,即可拿到随机的 mock 数据:

一个“不需要”写代码 的 mock & 代理 工具

根据 JSON 生成 mock

复制 JSON 数据,比如:

一个“不需要”写代码 的 mock & 代理 工具

通过 JSON 数据生成的 mock 接口需要手动修改路由地址。

根据字段类型或字段名称生成特定的 mock 数据

配置 yapi-code

配在 package.json 中即可。

	"yapi-code.mockKeyWordLike": {
		"icon": "Random.image('48x48')",
		"img":"Random.image('48x48')",
		"image":"Random.image('48x48')",
		"code": "200&&number",
		"name":"'模糊匹配后生成的 mock'"
	},
	"yapi-code.mockKeyWordEqual": {
		"message": "'这是一条精确的 mock'",
		"total": 200,
	},
	"yapi-code.mockString": "Random.cword(5, 6)",
	"yapi-code.mockBoolean": "Random.boolean()",
	"yapi-code.mockNumber": "Random.natural(100,1000)"

根据 json 数据:

const json = {
	code: 100,
	message: '请求成功',
	result: {
		list: [
			{
				code: '注意这是一个字符串的 code',
				name: '张三',
				icon: '',
				actived: false,
			},
		],
		total: 0,
	},
}

生成如下代码

.get(`xxxxx`, async (ctx, next) => {
		const list1 = []
		for (let i = 0; i < 3; i++) {
			list1.push({
				code: Random.cword(5, 6),
				name: '模糊匹配后生成的 mock',
				icon: Random.image('48x48'),
				actived: Random.boolean(),
			})
		}
		ctx.body = {
			code: 200,
			message: '这是一条精确的 mock',
			result: { list: list1, total: 200 },
		}
	})

访问 mock 接口即可拿到如下类似数据:

{
	"code": 200,
	"message": "这是一条精确的 mock",
	"result": {
		"list": [
			{
				"code": "八别因教者活",
				"name": "模糊匹配后生成的 mock",
				"icon": "http://dummyimage.com/48x48",
				"actived": true
			},
			{
				"code": "毛着何工时白",
				"name": "模糊匹配后生成的 mock",
				"icon": "http://dummyimage.com/48x48",
				"actived": false
			},
			{
				"code": "县称县单下外",
				"name": "模糊匹配后生成的 mock",
				"icon": "http://dummyimage.com/48x48",
				"actived": true
			}
		],
		"total": 200
	}
}

延时

import KoaRouter from 'koa-router'
import proxy from '../middleware/Proxy'
import { delay } from '../lib/util'
let Mock = require('mockjs')
let Random = Mock.Random

const router = new KoaRouter()
router.get('/delay', (ctx) => {
	delay(3) // 3 秒后返回结果
	ctx.body = 'delay'
})

可用于测 loading 效果。

http 异常状态码

router.get('/httpError', (ctx) => {
	ctx.status = 401
	ctx.body = 'http 401'
})

代理

router.get('/proxy', proxy('https://github.com/wjkang/lowcode-mock'), (ctx) => {
	ctx.body = 'https://github.com/wjkang/lowcode-mock'
})

来自 /proxy 的请求转发到 https://github.com/wjkang/lowcode-mock/proxy ,用于后端接口可联调的时候跳过本地 mock,转发请求到后端接口。

router.all(new RegExp('^/lowcode/mock/(|^$)'), proxy('https://github.com/wjkang/lowcode-mock'))

不需要 mock 并且匹配正则的接口直接转发到后端地址。

PHP中的“and”和“&&”运算符之间有什么区别吗? - php

我有以下代码,不认为并且不是必需的,即应该使用&&,因为没有什么可以分配左边的部分?if($_REQUEST['foo'] != 'abc' and $_REQUEST['bar'] == 'def') { echo "all your base…

赚点辛苦费,欢迎各位老板&大佬咨询购买惠普产品

Caan07:[赚点辛苦费] 主营惠普商用 PC/商务笔记本,保修一切按照惠普官方来执行。 贴图并不是所有型号和配置,有些产品特定工厂生产,或者有些型号不支持 CTO 特配,麻烦微信确认型号再确定是否支持特配。 有 INTEL 平台的,也有 AMD 平台的,也有国产芯片机型(不支持 CTO ) 品牌机,价格肯定不被各位 DIY 大佬看上,希望各位 DIY 大…

如何使OR(||)和AND(&&)语句协同工作?的PHP - php

我无法使此代码正常工作if ($title != 'Main' || $nSpace == 56 || $nSpace == 30 && $ifHome != 361) 所以我同意了这个代码if ($title != 'ArticleCategories' || $nSpace == 1) if ($n…

[9 元秒杀] <美团&字节&快手&网易&B 站>秋招算法真题详解

hakunamatata11:?Facebook 大佬带你拆解大厂原题,理顺解题思路,1 月内高效备战算法面试。 解析五个一线大厂的 40 多道 2020 算法真题+99 道配套巩固习题搭建面试必备知识框架,让你快速掌握面试核心软硬技能:省时!高效! 点击链接即可立即报名免费上车:https://www.jiuzhang.com/course/73/?utm…

尝试将JS &&运算符转换为C# - javascript

我有要转换为C#的JS代码。由于某种原因,我的C#方法返回的值比JS函数的返回值小10。我尝试更改多个内容并检查JS中&&运算符的含义,但似乎无法弄清楚我在做什么错。正确的返回值为97。JavaScript功能和用法:function rir(t, e, c, n) { return t > e && t <= c…