NodeJs - Retrieve user infor from JWT token?

前端 未结 4 547
天涯浪人
天涯浪人 2020-12-06 00:19

Node and Angular. I have a MEAN stack authentication application where I am setting a JWT token on successful login as follows, and storing it in a session in the controller

4条回答
  •  猫巷女王i
    2020-12-06 00:46

    First of all, it is a good practice to use Passport middleware for user authorization handling. It takes all the dirty job of parsing your request and also provides many authorization options. Now for your Node.js code. You need to verify and parse the passed token with jwt methods and then find the user by id extracted from the token:

    exports.me = function(req,res){
        if (req.headers && req.headers.authorization) {
            var authorization = req.headers.authorization.split(' ')[1],
                decoded;
            try {
                decoded = jwt.verify(authorization, secret.secretToken);
            } catch (e) {
                return res.status(401).send('unauthorized');
            }
            var userId = decoded.id;
            // Fetch the user by id 
            User.findOne({_id: userId}).then(function(user){
                // Do something with the user
                return res.send(200);
            });
        }
        return res.send(500);
    }
    

提交回复
热议问题