- 什么是中间件:
1)一个流程上,独立的业务模块
2)可扩展,可插拔
3)类似于工厂的流水线 - 为什么使用中间件
1)拆分业务模块,使代码更清晰。
2)统一使用中间件,使得各业务代码都规范标准
3)扩展性好,易添加,易删除 - koa2业务代码都是中间件
1)app.js中,所有的app.use(…)都是中间件
2)路由也是中间件(只不过限制了url规则) - 一个http请求会经过如下
req=>bodyparser=>json=>logger=>static=>views=>自定义log=>routes=>res - 模拟登陆功能
1)假如所有请求都要经过登录验证,代码如下
// 模拟登陆,为了使用中间件
app.use(async(ctx, next) => {
// next为下一个中间件,此处下一个中间件为路由
const query = ctx.query;
if (query.user === '张三') {
// 模拟登陆成功
await next(); // 执行下一步中间件
}else {
// 模拟登陆失败
ctx.body = '请登录'
}
})
完整代码如下,app.js中:
const Koa = require('koa')
const app = new Koa()
const views = require('koa-views')
const json = require('koa-json')
const onerror = require('koa-onerror')
const bodyparser = require('koa-bodyparser')
const logger = require('koa-logger')
const index = require('./routes/index')
const users = require('./routes/users')
const comments = require('./routes/comments')
// error handler 错误处理器
onerror(app)
// middlewares 中间件 (app.use(...))
app.use(bodyparser({ // request body的转换
enableTypes:['json', 'form', 'text']
}))
app.use(json())
app.use(logger()) // 日志格式化
app.use(require('koa-static')(__dirname + '/public')) // 静态文件服务
app.use(views(__dirname + '/views', { // 服务端模版引擎
extension: 'pug'
}))
// logger 打印当前请求所花费的时间
app.use(async (ctx, next) => {
const start = new Date()
await next()
const ms = new Date() - start
console.log(`${ctx.method} ${ctx.url} - ${ms}ms`)
})
// 模拟登陆,为了使用中间件
app.use(async(ctx, next) => {
// next为下一个中间件,此处下一个中间件为路由
const query = ctx.query;
if (query.user === '张三') {
// 模拟登陆成功
await next(); // 执行下一步中间件
}else {
// 模拟登陆失败
ctx.body = '请登录'
}
})
// routes 注册路由
app.use(index.routes(), index.allowedMethods())
app.use(users.routes(), users.allowedMethods())
app.use(comments.routes(), comments.allowedMethods()); // allowedMethods()对于404或返回是空的情况的一种补充
// error-handling
app.on('error', (err, ctx) => {
console.error('server error', err, ctx)
});
module.exports = app