我如何通知用户,他们输入了重复条目
How do I notify users, that they have entered dupilcate entry
我正在使用 mongodb 来存储详细信息。我知道已经有人问过这个问题,但解决方案对我不起作用。
const userSchema = {
email: {type: String, unique: true},
password: String
};
我使用了我在上面输入的模式,它有点管用,我的意思是,它不会让重复的条目插入到数据库中。但我遇到的问题是,它没有出现任何错误,所以我无法使用以下代码。
if(err){
console.log("Repeated record");
}
由于没有错误,页面继续加载,大约 2-3 分钟,最后显示“页面不工作,localhost 没有发送任何数据。”有人可以让我知道我应该采取什么方法来实现这一目标。
编辑:这是服务器代码:
app.get("/", function(req, res){
res.render("home");
});
app.get("/login", function(req, res){
res.render("login");
});
app.get("/register", function(req, res){
res.render("register");
});
app.post("/register", function(req, res){
const newUser = new User({
email: req.body.username,
password: req.body.password
});
newUser.save(function(err){
if(err){
console.log(err);
}else{
res.render("login");
};
});
});
app.post("/login", function(req, res){
const username = req.body.username;
const password = req.body.password;
User.findOne({email: username}, function(err, foundUser){
if(err){
console.log(err);
}else{
if(foundUser){
if(foundUser.password == password){
res.sendFile(__dirname + "/public/upload.html");
}
}
}
});
});
我已经安装了 express、body-parser 和 ejs。 Home、login、register是扩展名.ejs的模板。
谢谢。
如果发生错误或其他情况,您必须向客户端发送响应。否则您的函数将不会发送任何数据。我在您的代码中添加了一些注释行,标记为 --> Here
。在这些函数中使用 res.send()
或 res.render()
将响应发送到您的客户端。
同时添加状态代码可能有助于理解错误代码(只是建议)。
app.post("/register", function(req, res){
const newUser = new User({
email: req.body.username,
password: req.body.password
});
newUser.save(function(err){
if(err){
console.log(err);
// res.status(422).send(err) or res.render(errorPage) --> Here
}else{
res.render("login");
};
});
});
app.post("/login", function(req, res){
const username = req.body.username;
const password = req.body.password;
User.findOne({email: username}, function(err, foundUser){
if(err){
console.log(err);
// res.status(500).send(err) or res.render(errorPage); --> Here
}else{
if(foundUser){
if(foundUser.password == password){
res.sendFile(__dirname + "/public/upload.html");
} else {
// res.status(401).send('Some error message') res.render(errorPage); --> And here
}
}
}
});
});
我正在使用 mongodb 来存储详细信息。我知道已经有人问过这个问题,但解决方案对我不起作用。
const userSchema = {
email: {type: String, unique: true},
password: String
};
我使用了我在上面输入的模式,它有点管用,我的意思是,它不会让重复的条目插入到数据库中。但我遇到的问题是,它没有出现任何错误,所以我无法使用以下代码。
if(err){
console.log("Repeated record");
}
由于没有错误,页面继续加载,大约 2-3 分钟,最后显示“页面不工作,localhost 没有发送任何数据。”有人可以让我知道我应该采取什么方法来实现这一目标。
编辑:这是服务器代码:
app.get("/", function(req, res){
res.render("home");
});
app.get("/login", function(req, res){
res.render("login");
});
app.get("/register", function(req, res){
res.render("register");
});
app.post("/register", function(req, res){
const newUser = new User({
email: req.body.username,
password: req.body.password
});
newUser.save(function(err){
if(err){
console.log(err);
}else{
res.render("login");
};
});
});
app.post("/login", function(req, res){
const username = req.body.username;
const password = req.body.password;
User.findOne({email: username}, function(err, foundUser){
if(err){
console.log(err);
}else{
if(foundUser){
if(foundUser.password == password){
res.sendFile(__dirname + "/public/upload.html");
}
}
}
});
});
我已经安装了 express、body-parser 和 ejs。 Home、login、register是扩展名.ejs的模板。
谢谢。
如果发生错误或其他情况,您必须向客户端发送响应。否则您的函数将不会发送任何数据。我在您的代码中添加了一些注释行,标记为 --> Here
。在这些函数中使用 res.send()
或 res.render()
将响应发送到您的客户端。
同时添加状态代码可能有助于理解错误代码(只是建议)。
app.post("/register", function(req, res){
const newUser = new User({
email: req.body.username,
password: req.body.password
});
newUser.save(function(err){
if(err){
console.log(err);
// res.status(422).send(err) or res.render(errorPage) --> Here
}else{
res.render("login");
};
});
});
app.post("/login", function(req, res){
const username = req.body.username;
const password = req.body.password;
User.findOne({email: username}, function(err, foundUser){
if(err){
console.log(err);
// res.status(500).send(err) or res.render(errorPage); --> Here
}else{
if(foundUser){
if(foundUser.password == password){
res.sendFile(__dirname + "/public/upload.html");
} else {
// res.status(401).send('Some error message') res.render(errorPage); --> And here
}
}
}
});
});