ctx.redirect跳转时候没有效果怎么破

这里是在server中建的文件用来拦截passport的用户权限
ctx.req.user.auth

const allowpage = ['/login']
//拦
export default {
  userAuth: async ctx => {
    let url = ctx.originalUrl
    if (allowpage.indexOf(url) > -1) {
    } else {
      if (ctx.isAuthenticated()) {
        if (ctx.req.user.auth === 'staff') {
          var parts = url.split('/', 2);
          if (parts[1] === 'manager') {
            await ctx.redirect('/login')
            console.log('权限不足')
          } else {
          }
        } else {

        }
      } else {
        console.log('未登录')
        ctx.redirect('/login')
      }
    }
  }
}

然后再indes.js进行引入,

app.use(async (ctx, next) => {
  userauth.userAuth(ctx)
  await next()
})

但是“权限不足”已经打出来了,可是重定向没有效果,想问一下怎末办谢谢

阅读 3.6k
1 个回答
const allowpage = ['/login']
//拦
export default {
  userAuth: async (ctx, next) => {
    let url = ctx.originalUrl
    if (allowpage.indexOf(url) > -1) {
      next()
      return
    } else {
      if (ctx.isAuthenticated()) {
        if (ctx.req.user.auth === 'staff') {
          var parts = url.split('/', 2);
          if (parts[1] === 'manager') {
            await ctx.redirect('/login')
            console.log('权限不足')
          } else {
           return next()
          }
        } else {
            return next()
        }
      } else {
        console.log('未登录')
        ctx.redirect('/login')
      }
    }
  }
}
app.use( userauth.userAuth )
撰写回答
你尚未登录,登录后可以
  • 和开发者交流问题的细节
  • 关注并接收问题和回答的更新提醒
  • 参与内容的编辑和改进,让解决方法与时俱进
推荐问题