5分鐘教你用nodeJS手寫一個(gè)mock數(shù)據(jù)服務(wù)器的方法
對(duì)于前端開(kāi)發(fā)者而言,javascript正扮演著越來(lái)越重要的地位,它不僅能為瀏覽器端賦能,在web服務(wù)器方面也有很大的價(jià)值(我們可以用nodeJS來(lái)寫服務(wù)端代碼,啟動(dòng)web服務(wù)器),因此本文所要描述的,便是javascript在服務(wù)端的應(yīng)用。我將介紹如何使用nodeJS來(lái)搭建一個(gè)mock服務(wù)器,方便前端自定義mock數(shù)據(jù)請(qǐng)求,提高前端開(kāi)發(fā)的主觀能動(dòng)性和對(duì)項(xiàng)目健壯性的探索。
我們將學(xué)到
- koa基本使用
- koa-router的基本用法
- koa-logger的使用
- glob支持文件遍歷查尋
- node幾個(gè)核心api的使用
- 使用nodemon做自動(dòng)重啟
mock服務(wù)器基本設(shè)計(jì)思路
通過(guò)目錄路徑和服務(wù)端api的映射關(guān)系來(lái)實(shí)現(xiàn)我們的api訪問(wèn),比如我們?cè)L問(wèn)接口/api/article/122,我們只需要在mock服務(wù)器目錄的api的article目錄下,創(chuàng)建122.json文件即可,json文件的數(shù)據(jù)可以自定義,方便前端調(diào)試。

具體實(shí)現(xiàn)
1.搭建一個(gè)node服務(wù)
const Koa = require('koa');
const app = new Koa();
app.listen(3000)
2.注冊(cè)路由 我們使用koa-router來(lái)實(shí)現(xiàn)后臺(tái)服務(wù)的路由功能,并通過(guò)koa提供的上下文ctx將讀取到的數(shù)據(jù)返回給前端:
const Koa = require('koa');
const Router = require('koa-router');
const app = new Koa();
const router = new Router({prefix: '/api'});
router.get('/name', (ctx, next) => {
ctx.body = {
name: 'xuxiaoxi'
}
});
app
.use(router.routes())
.use(router.allowedMethods());
app.listen(3000)
這樣我們就能實(shí)現(xiàn)一個(gè)勉強(qiáng)能用的基本的后臺(tái)api服務(wù)器了,當(dāng)我們請(qǐng)求/api/name時(shí),會(huì)返回相應(yīng)的數(shù)據(jù)給前臺(tái),這一步是我們實(shí)現(xiàn)mock服務(wù)的關(guān)鍵一步,接下來(lái)我們具體來(lái)實(shí)現(xiàn)目錄的遍歷和api的自動(dòng)注冊(cè)。
3.自動(dòng)注冊(cè)api接口并返回?cái)?shù)據(jù) 我們將在這個(gè)階段實(shí)現(xiàn)api服務(wù)的自動(dòng)注冊(cè),這里我們使用glob這個(gè)第三方模塊來(lái)遍歷目錄,并通過(guò)node的fs模塊讀取api文件的數(shù)據(jù)并返回給前臺(tái)。glob的使用很簡(jiǎn)單,感興趣的朋友可以自行學(xué)習(xí),這里就不做過(guò)多介紹了。具體實(shí)現(xiàn)如下:
const Koa = require('koa');
const Router = require('koa-router');
const glob = require("glob");
const { resolve } = require('path');
const fs = require('fs');
const app = new Koa();
const router = new Router({prefix: '/api'});
// 注冊(cè)路由
glob.sync(resolve('./api', "**/*.json")).forEach((item, i) => {
let apiJsonPath = item && item.split('/api')[1];
let apiPath = apiJsonPath.replace('.json', '');
router.get(apiPath, (ctx, next) => {
try {
let jsonStr = fs.readFileSync(item).toString();
ctx.body = {
data: JSON.parse(jsonStr),
state: 200,
type: 'success' // 自定義響應(yīng)體
}
}catch(err) {
ctx.throw('服務(wù)器錯(cuò)誤', 500);
}
});
});
app
.use(router.routes())
.use(router.allowedMethods());
app.listen(3000);
添加控制臺(tái)日志 我們使用koa-logger實(shí)現(xiàn)在終端打印node日志,方便調(diào)試,雖然這不是該文章的重點(diǎn),但是對(duì)于想做node開(kāi)發(fā)的前端從業(yè)者,還是很有必要了解的。
const logger = require('koa-logger')
app.use(logger());
這樣,我們每個(gè)請(qǐng)求都會(huì)在終端打印出來(lái)。
路由映射文件的生成 該功能也不是本文的重點(diǎn),但是會(huì)極大的方便前端開(kāi)發(fā)者調(diào)試請(qǐng)求,因?yàn)槿绻鸻pi路徑很長(zhǎng),我們需要一個(gè)個(gè)查找,但是有了這個(gè)map文件,我們只需要拷貝自動(dòng)生成的路徑即可。具體實(shí)現(xiàn)如下:
//...
const routerMap = {}; // 存放路由映射
// 注冊(cè)路由
glob.sync(resolve('./api', "**/*.json")).forEach((item, i) => {
// ...
// 記錄路由
routerMap[apiJsonPath] = apiPath;
});
fs.writeFile('./routerMap.json', JSON.stringify(routerMap, null , 4), err => {
if(!err) {
console.log('路由地圖生成成功!')
}
});
基本目錄結(jié)構(gòu)

完整代碼
clone地址 github地址
https://github.com/MrXujiang/openCoder/tree/master/mockServer
以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
利用forever和pm2部署node.js項(xiàng)目過(guò)程
這篇文章主要給大家介紹了如何利用forever和pm2部署node.js項(xiàng)目的相關(guān)資料,文中給出了詳細(xì)的介紹和示例代碼供大家參考學(xué)習(xí),相信對(duì)大家的學(xué)習(xí)或者工作具有一定的學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編一起來(lái)看看吧。2017-05-05
用Electron寫個(gè)帶界面的nodejs爬蟲(chóng)的實(shí)現(xiàn)方法
這篇文章主要介紹了用Electron寫個(gè)帶界面的nodejs爬蟲(chóng)的實(shí)現(xiàn)方法,小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2019-01-01
Nodejs使用mysql2操作數(shù)據(jù)庫(kù)的方法完整講解
MySQL2是一個(gè)基于Node.js的MySQL數(shù)據(jù)庫(kù)驅(qū)動(dòng)程序,它是MySQL官方推薦的驅(qū)動(dòng)之一,下面這篇文章主要給大家介紹了關(guān)于Nodejs使用mysql2操作數(shù)據(jù)庫(kù)的相關(guān)資料,需要的朋友可以參考下2024-01-01
Nodejs進(jìn)階:如何將圖片轉(zhuǎn)成datauri嵌入到網(wǎng)頁(yè)中去實(shí)例
這篇文章主要介紹了Nodejs進(jìn)階:如何將圖片轉(zhuǎn)成datauri嵌入到網(wǎng)頁(yè)中去,有興趣的可以了解一下。2016-11-11
node.js操作mongoDB數(shù)據(jù)庫(kù)示例分享
這里給大家分享的是node.js操作mongoDB數(shù)據(jù)庫(kù)的示例,包括連接數(shù)據(jù)庫(kù)、插入數(shù)據(jù)、關(guān)閉數(shù)據(jù)庫(kù)、讀取數(shù)據(jù)、插入數(shù)據(jù)等方面,十分的全面,這里推薦給需要的小伙伴們。2014-11-11
node基于async/await對(duì)mysql進(jìn)行封裝
這篇文章主要介紹了node基于async/await對(duì)mysql進(jìn)行封裝,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,,需要的朋友可以參考下2019-06-06
Express+Nodejs 下的登錄攔截實(shí)現(xiàn)代碼
本篇文章主要介紹了Express+Nodejs 下的登錄攔截實(shí)現(xiàn)代碼,小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2017-07-07

