1.简介
Expres是基于Node.js平台,快速、开放、极简的web开发框架。(Expres中文官网首页原话)。之所以引用这句话,是因为这句话简单明了的告知了大家,它到底是什么。基于Node的一个开发框架,目的是给web开发提供了方便。今天我们就用测试用例开发的模式,一步步追踪Express路由系统源码是怎么实现的。
整体代码感知
本次实践项目,完整目录结构如下(以下会直接说某个文件的内容):
Express
|--lib
| |-express.js(主文件)
| |-application.js(相当于中转站直接访问路由信息)
| |-Router(路由,中间件)
| |-index.js
| |-layer.js
| |-route.js
|
|--test
| |-getTest.js
| |-routerTest.js
| |-middleTest.js
测试用例一(简单服务)
var express = require('express');
var app = express();
app.get('/', function (req, res) {
res.send('Hello World!');
});
var server = app.listen(3000, function () {
console.log('server started on port 3000');
});
以上代码是Express官网入门的一个最简单的实例,简单的搭建了一个服务,并且访问根目录的时候,会返回Hello World!我们可以看到app是引用后的express执行得到的一个对象(说明express是一个函数),并且在该对象上有get和listen两个方法。主文件express.js,结构如下:
const app = require('./application');
function createApplication(){
return app;
}
module.exports = createApplication;
application.js中应该具有一个对象,并且该对象上面有两个方法.首先有一个存放路由的数组,默认有一个对象,我定义为兜底对象,就是当输入的路由信息并不存在的时候,执行该对象的handler。到此,两个文件执行完毕,我们就实现最简单的服务搭建以及get路由功能。
let router = [
{
path:'*',
method:'*',
handler(req,res){
res.end('Not Found');
}
}
];
let http = require('http');
const app = {
get(path,handler){
router.push({
method:'get',
path,
handler
});
},
listen(){
const server = http.createServer(function(req,res){
for(let i=0;i<router.length;i++){
let {path,method,handler} = router[i];
if(path == req.url && method == req.method.toLowerCase()){
return handler(req,res);
}
}
router[0].handler(req,res);
});
server.listen.apply(server,arguments);
}
}
module.exports = app;
测试用例二(路由)
app.get('/',function(req,res,next){
console.log(1);
next();
},function(req,res,next){
console.log(11);
next();
}).get('/',function(req,res,next){
console.log(2);
next();
}).get('/'