Bcrypt错误:非法参数字符串未识别

Han*_*ani 10 node.js

这是我的完整代码

var express = require('express'),
    app = express(),
    mongoose = require('mongoose'),
    bodyParser = require('body-parser'),
    morgan = require('morgan'),
    webToken = require('jsonwebtoken'),
    bcrypt = require('bcryptjs'),
    assert = require('assert');
    Schema = mongoose.Schema,
    secretKey = "omjdiuwkslxmshsoepdukslsj";

//User Schema
var userSchema = new Schema({
    username: {type: String, required: true, index: {unique:true}},
    password: {type: String, required: true, select: false}
})

userSchema.pre('save', function(next){
    var user = this;

    if(!user.isModified('password')) return next();

    bcrypt.hash(user.password, null, null, function(err, hash){
        if(err) return next(err);

        user.password = hash;
        next();
    })
});

userSchema.methods.comparePassword = function(password){
    var user = this;

    bcrypt.compare(password, user.password, function(err, result){
        if(err){
            console.log(err);
        }
        else {
            console.log("passwords match!");
            return;
        }
    })
}

var userModel = mongoose.model('users', userSchema);


//Connecting to Mongo
mongoose.connect("mongodb://localhost/userstories", function(err){
    if(err) {
        console.log(err);
    }
    else {
        console.log("Connected to database!");
    }
});

//Creating Token
function createToken(user){
    var token = webToken.sign({
        _id: user.id,
        username: user.username
    },  secretKey,{
        expiresIn: 30 * 60 * 1000
    })
    return token;
    }

//Middlewares
app.use(bodyParser.urlencoded({extended: true}));
app.use(bodyParser.json());
app.use(morgan('dev'));

//Api's

app.post('/signup', function(req, res){    
    var user = new userModel({
        username: req.body.username,
        password: req.body.password
    })

    user.save(function(err){
        if(err){
            console.log(err);
        }

        else{
            res.json({message: "User created!"});
        }
    })
})

app.post('/login', function(req, res){

    userModel.findOne({username: req.body.username}, function(err, user){
        if(err) console.log(err);

            if(!user){
                res.send("User not found!");
            }
                 else if(user){

                      var validPassword = user.comparePassword(req.body.password);

                       if(validPassword){
                                var tokens = createToken(user);

                                res.json({
                                    success: true,
                                    message: "Successfully logged In",
                                    token: tokens
                                });
                        } 

                            else {
                                    res.send("Invalid password");
                                  }

                     }
    })
});


//Running the server
app.listen(3000, function(err){
    if(err) console.log("port not working");
    else{
        console.log("Everything went just fine");
    }
})
Run Code Online (Sandbox Code Playgroud)

我已经尝试了所有方法,并在这里看到了所有的答案.但似乎没有人遇到这种非法的争论错误.请为我找出这一个我确定有一个我无法看到的错误

Peo*_*ray 5

在您的用户架构中,您将密码字段设置select为 false。这意味着,每当您在请求中尝试在架构中查找用户时login,您都不会获得该字段的值或架构中定义password为 false 的任何其他字段的值。select

您需要做的是在找到用户时指定您需要密码:

app.post('/login', function(req, res){
  userModel.findOne({username: req.body.username}, 'password', function(err, user){
   // continue
}

Run Code Online (Sandbox Code Playgroud)

这将仅从数据库返回_id和。password如果你想返回其他字段,你必须将它们添加到:

app.post('/login', function(req, res){
  userModel.findOne({username: req.body.username}, 'password firstName lastName email', function(err, user){
   // continue
}

Run Code Online (Sandbox Code Playgroud)


Bud*_*ana 3

我已经尝试过一次相同的代码进行身份验证并得到相同的错误Error: Illegal arguments: string, function

但我没有看到代码有任何问题。问题是,我用相同的用户名和不同的密码注册了两个用户。然后,当我尝试使用用户名和一个密码登录时,发生了此错误并停止了服务器。

所以看来你也面临着同样的问题。如果您不想在代码中出现错误,请确保这些内容没有错误。