egg.js设置了中间件,为啥状态为404 了

发布于 2022-09-11 18:55:30 字数 1248 浏览 19 评论 0

在路由中设置的中间件,去掉中间件正常,加上中间件status=404了?

//中间件
const jwt = require('jsonwebtoken');
const { config } = require('./../utils/config');

module.exports = () => {
    return async function isAuth(ctx, next) {
        const token = ctx.cookies.get('token', { signed: false });
        if (token) {
            jwt.verify(token, config.privateKey, async function(err, decoded) {
                if (err) {
                    console.log(err);
                    ctx.body = {
                        code: 5001,
                        data: null,
                        msg: 'token失效!'
                    };
                    return;
                }
               
                ctx.request.body.sessionKey = decoded.sessionKey;
                ctx.request.body.token = token;
                await next();
            });
        } else {
            ctx.body = {
                code: 5003,
                data: null,
                msg: '请求出错,无token!'
            };
        }
    };
};
//路由
    const isAuth = middleware.isAuth();

 apiRouter.post('/updateUserInfo', isAuth, clientUserInfo.updateUserInfo);
//控制器
//有返回body内容

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

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

发布评论

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

评论(1

姐不稀罕 2022-09-18 18:55:30
if (token) {
  try {
    const decoded = jwt.verify(token, config.privateKey);
    ctx.request.body.sessionKey = decoded.sessionKey;
    ctx.request.body.token = token;
  } catch (err) {
    console.log(err);
    ctx.body = {
      code: 5001,
      data: null,
      msg: 'token失效!',
    };
  }
  await next();
}
~没有更多了~
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文