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

发布于 2022-09-12 02:09:45 字数 804 浏览 38 评论 0

这里是在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()
})

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

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。

评论(1

半世蒼涼 2022-09-19 02:09:45
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 )
~没有更多了~
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文