java mockserver搭建_搭建mock-server

本文介绍如何利用MockJS和Express搭建一个简单的Mock Server。首先通过npm安装MockJS和Express,然后创建api.json文件存放接口数据,接着编写server.js作为Mock服务器,监听指定端口,并拦截请求返回匹配的JSON数据。
摘要由CSDN通过智能技术生成

安装mockjs和express

npm install mockjs express --save

新建api.json

api.josn主要是放请求的json数据,有新增的请求,只需要在api.json添加即可。

{

"login": [{

"url": "/login",

"desc": "接口描述",

"res": {

"message": "成功",

"code": 1,

"data": {

"loginName": "@cword(4,10)"

}

}

}],

"loginTest": [{

"url": "/loginTest",

"desc": "接口描述",

"res": {

"message": "成功",

"code": 1,

"data": {

"loginName": "@cword(4,10)"

}

}

}]

}

新建server.js

server.js主要是做mock的服务器。

1.创建一个服务。

2.读取api.json文件内容

3.拦截请求,返回匹配的数据

const express = require('express');

const path = require('path');

const fs = require('fs');

const Mock = require('mockjs');

const app = express();

const port = 5050;

const apiPath = path.join(__dirname, './api.json');

let apiData = {};

app.listen(port, function () {

console.info('mock server is listening at ' + port)

});

//读取文件

let getApi = () => {

let readStream = fs.createReadStream(apiPath, {

encoding: 'utf8'

});

readStream.on('data', (chunk) => {

apiData = JSON.parse(chunk)

});

readStream.on('end', () => {

console.info('读取已完成..');

});

}

fs.watchFile(apiPath, () => {

getApi();

console.info('mock server update');

});

getApi();

app.use((req, res, next) => {

const originalUrl = req.originalUrl;

let data = undefined;

//匹配路径

for (let url in apiData) {

let findItem = apiData[url].find((result) => {

if (result.url === originalUrl) {

return result

}

});

if (findItem !== undefined) {

data = Mock.mock(findItem.res);

break;

}

}

res.set('Access-Control-Allow-Origin', '*');

res.set('Access-Control-Allow-Methods', 'POST, GET, PUT, DELETE, OPTIONS');

res.set('Access-Control-Allow-Headers', 'Origin, X-Requested-With, Content-Type, Accept, Authorization');

//返回数据

data !== undefined ? res.send(data) : res.sendStatus(404);

next();

});

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值