npm install mockjs express --save
api.josn主要是放請求的json數據,有新增的請求,只須要在api.json添加便可。git
{ "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主要是作mock的服務器。
1.建立一個服務。
2.讀取api.json文件內容
3.攔截請求,返回匹配的數據github
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(); });
項目地址:https://github.com/rainbowChenhong/mock-server.gitexpress