系统城装机大师 - 固镇县祥瑞电脑科技销售部宣传站!

当前位置:首页 > 网络编程 > JavaScript > 详细页面

koa-passport实现本地验证的方法示例

时间:2020-02-20来源:系统城作者:电脑系统城

安装


 
  1. yarn add koa-passport passport-local

先看下passport.js登录策略,判断用户和密码


 
  1. const passport = require('koa-passport')
  2. const LocalStrategy = require('passport-local').Strategy
  3. const User = require('../../dbs/models/users')
  4.  
  5. passport.use(new LocalStrategy((username, password, done) => {
  6. User.findOne({username}, (err, user) => {
  7. if (err) return done(err)
  8. if (!user) return done(null, false, {message: '用户不存在'})
  9. if (user.password !== password) return done(null, false, {message: '密码错误'})
  10. return done(null, user)
  11. })
  12. }))
  13.  
  14. passport.serializeUser((user, done) => {
  15. done(null, user)
  16. })
  17.  
  18. passport.deserializeUser((user, done) => {
  19. done(null, user)
  20. })
  21.  
  22. module.exports = passport
  23.  

在入口中挂载passport


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

这时候passport策略配置完成

登录接口实现


 
  1. router.post('/signin', async ctx => {
  2. return Passport.authenticate('local', (err, user, info, status) => {
  3. if (err) {
  4. ctx.body = {
  5. code:-1,
  6. msg:err
  7. }
  8. }else {
  9. if (user) {
  10. ctx.body = {
  11. code:0,
  12. msg:'登录成功',
  13. user
  14. }
  15. return ctx.login(user)
  16. } else {
  17. ctx.body = {
  18. code:1,
  19. msg:info
  20. }
  21. }
  22. }
  23. })(ctx)
  24. })
  25.  

用户是否登录


 
  1. router.get('/getUser', async ctx => {
  2. if (ctx.isAuthenticated()){
  3. const {username, email} = ctx.session.passport.user
  4. ctx.body = {
  5. username,
  6. email
  7. }
  8. } else {
  9. ctx.body = {
  10. username: '',
  11. email: ''
  12. }
  13. }
  14. })
  15.  

用户退出


 
  1. router.get('/exit', async ctx => {
  2. await ctx.logout()
  3. if (!ctx.isAuthenticated()) {
  4. ctx.body = {
  5. code:0
  6. }
  7. } else {
  8. ctx.body = {
  9. code:-1
  10. }
  11. }
  12. })
  13.  

分析

通过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 本地验证内容请搜素我们以前的文章或下面相关文章,希望大家以后多多支持我们!

分享到:

相关信息

系统教程栏目

栏目热门教程

人气教程排行

站长推荐

热门系统下载