• vue全家桶+Koa2开发笔记(7)--登陆注册功能


    1 文件结构:pages中放置页面代码;server 分为 dbs 和interface两个文件夹;

    dbs设置有关数据库的代码;interface设置接口信息;

    2.2 先看dbs的,在dbs的配置文件config.js中定义:

    export default {                  //该文件是配置文件,在 server/index 和interface 中引入使用。
        dbs:'mongodb://127.0.0.1:27017/student',//配置数据库host和数据库名字student
        redis:{                       //配置redis快速存储的数据库地址和端口
          get host(){
            return '127.0.0.1'
          },
          get port(){
            return 6379
          }
        },
        smtp:{                      //配置发送邮箱的信息
          get host(){
            return 'smtp.qq.com'    //smtp发送邮件的协议
          },
          get user(){
            return '2751581738@qq.com'  //邮箱地址
          },
          get pass(){
            return 'XXXXXXXX'  //授权码
          },
          get code(){               //发送的四位随机码
            return ()=>{
              return Math.random().toString(16).slice(2,6).toUpperCase()
            }
          },
          get expire(){
            return ()=>{           //设置验证码的设置有效期
              return new Date().getTime()+60*60*1000
            }
          }
        }
      }
      

    然后在数据库的dbs中model中新建数据表:

    import mongoose from 'mongoose' //使用 mongoose 新建数据库的表 users
    const Schema = mongoose.Schema
    const UserSchema=new Schema({
      username:{
        type:String,
        unique:true,
        require:true
      },
      password:{
        type:String,
        require:true
      },
      email:{
        type:String,
        require:true
      }
    })
    
    export default mongoose.model('User',UserSchema)

    还要在server/index.js中

    import mongoose from 'mongoose'
    mongoose.connect(dbConfig.dbs,{
      useNewUrlParser:true
    })

    处理完数据库之后,再来设置接口,在interface文件夹中:

    首先在interface/utils文件夹下新建 axios和passport两个文件, 然后设置 passport文件:

    passport获取用户在调用登陆接口时,输入的用户名和密码,然后在数据库中根据用户名判断密码是否正确;并且在用户执行login()时,序列化用户名,待

    详见:  koa2 使用passport权限认证中间件

               Koa集成权限认证中间件之Passport

               koa-passport学习笔记

    最后,我们需要在app中开启koa-passport对session的支持

    app.use(passport.initialize())
    app.use(passport.session())

    app.use(passport.initialize()) 会在请求周期ctx对象挂载以下方法与属性

    • ctx.state.user 认证用户
    • ctx.login(user) 登录用户(序列化用户)
    • ctx.isAuthenticated() 判断是否认证

    passport.session()则是passport自带的策略,用于从session中提取用户信息

  • 相关阅读:
    Tomcat生命周期管理与观察者模式
    利于ThreadLocal管理Hibernate Session
    Spring多数据源配置
    MySQL数据库性能优化之硬件瓶颈分析
    浅谈监听器与过滤器
    StringManager与单例模式
    ThreadLocal在spring框架中的作用
    spring中事件机制
    MySQL数据库性能优化之存储引擎选择
    Spring常用的Listener
  • 原文地址:https://www.cnblogs.com/xiaozhumaopao/p/10401450.html
Copyright © 2020-2023  润新知