【问题标题】:fetch the data from the mongodb using node js使用 node js 从 mongodb 获取数据
【发布时间】:2018-03-22 03:41:27
【问题描述】:

我已经使用节点创建了一个登录程序,目前我只从 jwt 获取令牌,但我还需要用户名、_id 和手机号码以及已经存储在数据库中的令牌如何获取此详细信息。请帮助我,我是 node 和 mongo 的新手

-------架构------------

var mongoose = require('mongoose');

var users = new mongoose.Schema({
    _id: Number,
    username: String,
    mobile: Number,
    email: { type: String, required: true},
    password: { type: String, required: true},
});

module.exports = mongoose.model('users', users);

const express = require('express');
const router = express.Router();
const mongoose = require('mongoose');
const bcrypt = require('bcrypt');
const jwt = require('jsonwebtoken');


const User = require('../models/users');
router.post('/login', (req, res, next) => {

  User.find({ email: req.body.email })
    .exec()
    .then(users => {
      if (users.length < 1) {
        return res.status(401).json({
          message: "This email does not exist please registor"
        });
      }

      console.log(users[0].password);
      bcrypt.compare(req.body.password, users[0].password, (err, result) => {
        if (err) {
          return res.status(401).json({
            message: "Auth fail"
          });
        }
        console.log(result);
        if (result) {
          const token = jwt.sign({
            email: users[0].email,
            userId: users[0]._id
          }, process.env.JWT_KEY,
            {
              expiresIn: "1h"
            }
          );
          return res.status(200).json({
            message: 'login successfull',
            token: token
          });
        } else {
          res.status(401).json({
            message: "password is incorrect"
          });
        }
      });
    })
    .catch(err => {
      res.status(500).json({
        error: err
      });
    });
});
module.exports = router;

请帮我获取用户名、ID 和手机以及令牌

【问题讨论】:

  • 您必须将用户名或 id 与时间戳或任何其他参数结合起来制作令牌..但是用户数据中应该有一个唯一的密钥...这样当您解码该令牌时,您可以在用户集合中轻松搜索该 id

标签: node.js mongodb mongoose


【解决方案1】:

在创建令牌时添加这些信息。

const token = jwt.sign({
        username: users[0].username,
        email: users[0].email,
        userId: users[0]._id,
        mobile: users[0].mobile
      }, process.env.JWT_KEY,
        {
          expiresIn: "1h"
        }
      );

你也应该使用猫鼬“findOne”而不是使用“find”,它允许你使用像“user.email”这样的用户对象,而不是处理数组和做“users[0]”。

【讨论】:

    猜你喜欢
    • 2021-02-06
    • 1970-01-01
    • 1970-01-01
    • 2018-03-07
    • 1970-01-01
    • 1970-01-01
    • 2017-08-06
    • 1970-01-01
    • 2021-07-10
    相关资源
    最近更新 更多