手牵手快速上手,egg router中间件结合redis实现登录验证

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生成。

以上是学习过程中,汇总的一份总结,如有不对,请指出,求点赞,求分享,求评论~~转请注明连接

你可能感兴趣的:(手牵手快速上手,egg router中间件结合redis实现登录验证)