1.redis的安装(linux CentOS 7)
yum install epel-release #下载epel仓库
yum install redis #安装redis
service redis start #启动redis
service redis stop #停止redis
修改相关配置
vim /etc/redis.conf #vim打开配置文件
/ port #查找到默认端口配置修改(可选)
/ requirepass #查找到密码配置修改(可选)
redis-server /etc/redis.conf & #文件启动
redis-cli -h 127.0.0.1 -p 6379 #端口登录(6379为配置文件端口)
最后输入自己修改后的密码就完了。
注意:修改安全组端口和防火墙。
如果连接不上可查看运行状态和端口 ps -ef | grep processName | grep -v grep
2.egg引入redis(使用egg-redis)
$ npm i egg-redis --save #安装
#config/plugin.js 中添加
exports.redis = {
enable: true,
package: 'egg-redis',
};
#config/config.default.js 中配置redis服务器参数
config.redis = {
client: {
port: 6379, // 端口
host: '127.0.0.1', // host
password: 'auth',
db: 0,
},
}
3.创建中间件对token进行判断。
新建app/middleware文件夹。
在middleware目录下新建isAdmin.js文件。
规则:exports 一个普通的 function,接受两个参数:
options: 中间件的配置项,框架会将 app.config[${middlewareName}] 传递进来。
app: 当前应用 Application 的实例。
module.exports = (options, app) => {
return async function isAdmin(ctx, next) {
// 获取头部token信息 如果不存在,表示没有登录,跳转到首页
let token = ctx.request.header.qmtoken
if (token) {
// 对比redis信息
const result = await app.redis.get('userid');
if (result == null) {
ctx.redirect('/')
} else {
await next();
}
} else {
ctx.redirect('/'); //重定向
};
};
};
4.router 中使用中间件
在对应的路由挂载即可。
例:
const isAdmin = app.middleware.isAdmin({}, app);
router.get('/h5/info',isAdmin, controller.home.info);//用户信息
注:路由中使用中间件不需要在config.default.js再开启中间件,开启后会处理每一次请求。
5.redis存入用户token信息
await app.redis.set('foo', 'bar'); //键值
token生成可以使用node crypto模块生成自定义的hash。
也可以使用jwt生成。