egg中间件
1、在app/middleware文件夹下新建auth.js文件,每一个文件为一个中间件
module.exports = options => {
return async function auth(ctx, next) {
// 如果有用户信息,则进入后台管理页面,否则进入登录页
if (ctx.cookies.get('userInfo')){
await next();
} else {
// 排除登录页,避免死循环
if (ctx.request.url === '/admin/login') {
await next();
} else {
ctx.redirect('/admin/login');
}
}
}
}
2、在config/config.default.js里面注册中间件
config.middleware = ['auth'];
3、如果只需要验证部分路由接口,比如只验证后台管理入口,config/config.default.js修改如下(方法一)
config.middleware = ['auth'];
// 中间件匹配路由
config.auth = {
enable: true, // 是否开启该中间件,不写默认开启
match: ['/admin'], // 只匹配指定路由,反之如果只忽略指定路由,可以用ignore
// ignore: ['/'] // 不要与match一起使用,避免冲突
}
4、指定路由使用中间件,在router.js内配置,此时config.default.js中删除auth中间件的配置(方法二)
'use strict';
module.exports = app => {
const { router, controller } = app;
const auth app.middleware.auth(); // 引入auth中间件,括号内可以传递参数给中间件{key: value}
router.get('/', controller.index.index.index);
router.get('/list', auth, controller.index.index.list); // 只在/list路由使用,放到第二个参数
};