Express实现路由分发控制、RESTful API
Express實(shí)現(xiàn)路由分發(fā)控制、RESTful API
標(biāo)簽(空格分隔): Node.js
最近在用Express作為自己的WEB應(yīng)用框架,其中最為迷惑的就是Express的路由控制和分發(fā),在網(wǎng)上搜了很多資料,但是大部分的資料都是將Express的路由控制寫在了app.js入口文件中,但是這樣的寫法寫一些Demo是可以的,但是在實(shí)戰(zhàn)項(xiàng)目中基本上不會(huì)這樣來(lái)寫,因?yàn)殡S著項(xiàng)目的龐大,在app.js入口文件中的路由控制將會(huì)越來(lái)越復(fù)雜。所以,我們實(shí)際項(xiàng)目中一般會(huì)將不同的業(yè)務(wù)邏輯交給不同的模塊開負(fù)責(zé)。
以下是這幾天摸索出來(lái)的一些簡(jiǎn)單實(shí)現(xiàn)
如果有大神有更好的實(shí)現(xiàn)方案或建議,歡迎給予指點(diǎn)
具體實(shí)現(xiàn)方式如下
本Demo的目錄結(jié)構(gòu)如下
- node-modules
- api
- user.js
- routes
- index.js
- app.js
- package.json
創(chuàng)建Node.js應(yīng)用
首先通過(guò)cd進(jìn)入到項(xiàng)目希望放置的目錄,然后執(zhí)行以下命令
npm init -y
執(zhí)行完以后,會(huì)在目錄中創(chuàng)建一個(gè)package.json配置文件,打開該文件,在配置文件中添加項(xiàng)目中所需要的所有依賴。(我個(gè)人的搭配是Express+redis數(shù)據(jù)庫(kù)),添加完以后的package.json文件如下
{
"name": "RestfulDocApi",
"version": "1.0.0",
"description": "",
"main": "app.js",
"scripts": {
"test": "echo \"Error: no test specified\" && exit 1"
},
"keywords": [],
"author": "",
"license": "ISC",
"dependencies":{
"express":"^4.13.4", // express框架
"redis":"^2.5.2", // redis數(shù)據(jù)庫(kù)
"body-parser": "~1.0.1", // 用于解析提交的請(qǐng)求表單
"response-time": "^2.3.1" // 計(jì)算響應(yīng)時(shí)間中間件
}
}
安裝Express框架及其依賴
編輯完以后,進(jìn)入到該目錄,然后執(zhí)行以下命令安裝Express框架及其依賴
npm install
注意
由于國(guó)內(nèi)被墻,這個(gè)過(guò)程如果依賴包過(guò)多或過(guò)大的時(shí)候,會(huì)非常慢,所以,建議使用淘寶的cnpm來(lái)安裝(不安裝也可以,只是會(huì)比較慢)
-
安裝cnpm
npm install -g cnpm
-
然后通過(guò)cnpm安裝Express框架及其依賴
cnpm install
創(chuàng)建入口文件app.js
在根目錄創(chuàng)建app.js并添加以下代碼
/**
* app.js
* @authors 袁俊亮 (1610712512@qq.com)
* @date 2016-12-09 16:57:54
* @webSite http://www.yuanjunliang.cc
*/
?
var app = require('express')();
var responseTime = require('response-time');
var redis = require('redis');
?
// 創(chuàng)建數(shù)據(jù)庫(kù)客戶端
var client = redis.createClient();
client.on('error',function(err){
console.log('error'+err);
});
?
// 設(shè)置端口
app.set('port',(process.env.PORT || 3000));
?
// 使用請(qǐng)求計(jì)時(shí)模塊
app.use(responseTime());
?
// 設(shè)置/routes/index文件為總的路由控制文件
// 在routes/index文件中再進(jìn)行統(tǒng)一的路由分發(fā),這樣防止app.js中代碼過(guò)于臃腫
var routes = require('./routes/index');
routes(app);
?
// 啟動(dòng)服務(wù)的時(shí)候監(jiān)聽端口號(hào)
app.listen(app.get('port'),function(){
console.log('Server listening on port:',app.get('port'));
});
實(shí)現(xiàn)路由分發(fā)控制文件/routes/index.js
創(chuàng)建路由分發(fā)控制文件/routes/index.js,在該文件中,實(shí)現(xiàn)將用戶所有的請(qǐng)求邏輯處理分發(fā)到不同的業(yè)務(wù)模塊進(jìn)行處理。實(shí)現(xiàn)代碼如下
module.exports = function(app){
// 分發(fā)user模塊,比如用戶的注冊(cè)和登錄請(qǐng)求業(yè)務(wù)邏輯將會(huì)在/api/user.js中實(shí)現(xiàn)
var user = require('../api/user');
app.use('/user',user);
};
處理具體的業(yè)務(wù)邏輯(與數(shù)據(jù)庫(kù)相關(guān)的業(yè)務(wù)邏輯處理都在這里完成)
創(chuàng)建一個(gè)/api目錄下的user.js文件,在其中實(shí)現(xiàn)user模塊的業(yè)務(wù)邏輯處理,代碼如下
/**
* 用戶模塊user.js
* @authors 袁俊亮 (1610712512@qq.com)
* @date 2016-12-09 17:06:42
* @webSite http://www.yuanjunliang.cc
*/
?
var express = require('express');
var router = express.Router();
?
// 處理get請(qǐng)求
router.get('/', function(req, res) {
res.send({
'username':'john',
'sex':'man',
'address':'上海'
});
});
?
// 處理POST請(qǐng)求
router.post('/',function(req,res){
console.log('接受到了post請(qǐng)求');
res.send({
'regist':{title:req.param('username')}
})
});
?
module.exports = router;
經(jīng)過(guò)上訴的處理以后就完成了user模塊的路由控制分發(fā),每當(dāng)用戶發(fā)起與user相關(guān)的請(qǐng)求時(shí),就可以在/api/user.js中接收到用戶的相關(guān)請(qǐng)求,并做相關(guān)處理
業(yè)務(wù)邏輯擴(kuò)展
其他的分發(fā)邏輯類似,比如在添加一個(gè)文章編輯和查看模塊
-
在/api目錄下創(chuàng)建一個(gè)post.js文件并在其中實(shí)現(xiàn)文章的業(yè)務(wù)邏輯處理
-
在/routes/index.js文件中添加一條路由規(guī)則如下
module.exports = function(app){
// 分發(fā)user模塊,比如用戶的注冊(cè)和登錄請(qǐng)求業(yè)務(wù)邏輯將會(huì)在/api/user.js中實(shí)現(xiàn)
var user = require('../api/user');
app.use('/user',user);
// 文章編輯及查看路由模塊
var post = requier('../api/post');
app.use('/post',post);
};
最后給出上訴項(xiàng)目的Demo源碼
源碼地址為:
鏈接: https://pan.baidu.com/s/1c2kPYCS 密碼: ni3r
源碼使用方法
-
解壓源碼
解壓完源碼以后通過(guò)終端cd到本項(xiàng)目中,然后執(zhí)行npm install安裝所有的依賴。
-
啟動(dòng)服務(wù)
node app.js
如果終端中返回一下信息,說(shuō)明啟動(dòng)成功
Server listening on port: 3000
-
在瀏覽器中訪問(wèn)
http://localhost:3000/user
如果返回一下json數(shù)據(jù),說(shuō)明請(qǐng)求成功
{
"username": "john",
"sex": "man",
"address": "上海"
}
總結(jié)
以上是生活随笔為你收集整理的Express实现路由分发控制、RESTful API的全部?jī)?nèi)容,希望文章能夠幫你解決所遇到的問(wèn)題。
- 上一篇: Python ——告白小程序,添加微信号
- 下一篇: 下拉选择框 其他_列表框 vs 下拉列表