这是我的完整代码
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)
我已经尝试了所有方法,并在这里看到了所有的答案.但似乎没有人遇到这种非法的争论错误.请为我找出这一个我确定有一个我无法看到的错误
在您的用户架构中,您将密码字段设置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)
我已经尝试过一次相同的代码进行身份验证并得到相同的错误Error: Illegal arguments: string, function。
但我没有看到代码有任何问题。问题是,我用相同的用户名和不同的密码注册了两个用户。然后,当我尝试使用用户名和一个密码登录时,发生了此错误并停止了服务器。
所以看来你也面临着同样的问题。如果您不想在代码中出现错误,请确保这些内容没有错误。
| 归档时间: |
|
| 查看次数: |
5298 次 |
| 最近记录: |