1. 程式人生 > 程式設計 >koa-passport實現本地驗證的方法示例

koa-passport實現本地驗證的方法示例

安裝

yarn add koa-passport passport-local

先看下passport.js登入策略,判斷使用者和密碼

const passport = require('koa-passport')
const LocalStrategy = require('passport-local').Strategy
const User = require('../../dbs/models/users')

passport.use(new LocalStrategy((username,password,done) => {
 User.findOne({username},(err,user) => {
  if (err) return done(err)
  if (!user) return done(null,false,{message: '使用者不存在'})
  if (user.password !== password) return done(null,{message: '密碼錯誤'})
  return done(null,user)
 })
}))

passport.serializeUser((user,done) => {
 done(null,user)
})

passport.deserializeUser((user,user)
})

module.exports = passport

在入口中掛載passport

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

這時候passport策略配置完成

登入介面實現

router.post('/signin',async ctx => {
 return Passport.authenticate('local',user,info,status) => {
  if (err) {
   ctx.body = {
    code:-1,msg:err
   }
  }else {
   if (user) {
    ctx.body = {
     code:0,msg:'登入成功',user
    }
    return ctx.login(user)
   } else {
    ctx.body = {
     code:1,msg:info
    }
   }
  }
 })(ctx)
})

使用者是否登入

router.get('/getUser',async ctx => {
 if (ctx.isAuthenticated()){
  const {username,email} = ctx.session.passport.user
  ctx.body = {
   username,email
  }
 } else {
  ctx.body = {
   username: '',email: ''
  }
 }
})

使用者退出

router.get('/exit',async ctx => {
 await ctx.logout()
 if (!ctx.isAuthenticated()) {
  ctx.body = {
   code:0
  }
 } else {
  ctx.body = {
   code:-1
  }
 }
})

分析

通過passport.serializeUser函式定義序列化操作,呼叫ctx.login()會觸發序列化操作

通過passport.deserializeUser函式定義反序列化操作,在session中如果存在passport:{user:'Susan'}會觸發反序列化操作

通過passport.use(new LocalStrategy('local',...)) 註冊策略,呼叫passport.authenticate('local',...)呼叫策略

app.use(passport.initialize()) 會在ctx掛載以下方法

  ctx.state.user 認證使用者

  ctx.login(user) 登入使用者

  ctx.logout() 使用者退出登入

  ctx.isAuthenticated() 判斷是否認證

到此這篇關於koa-passport實現本地驗證的方法示例的文章就介紹到這了,更多相關koa-passport 本地驗證內容請搜素我們以前的文章或下面相關文章,希望大家以後多多支援我們!