Zgb*_*ell 1 ajax redirect node.js express
我正在nodejs/expressjs中构建购物车应用程序.在用户登录后,我遇到了一些重定向到正确页面的问题.我发现了几篇与之密切相关的文章,但我尝试从那些给定的文章中修复它并没有成功.
access: function(req, res){
var data = JSON.parse(req.body.data);
console.log(data);
Customers.findOne({"custEmail": data.custEmail}, function(err, user){
if(err){
console.log(err);
res.send("error");
}if(!user){
console.log("user not found");
res.send("error");
}else{
console.log("user found");
bcrypt.compare(data.custPassword, user.custPassword, function(err, reponse){
if(reponse){
req.session.regenerate(function(err){
if(err){
console.log(err);
res.send("error");
}else{
req.session.success = true;
res.send("Success");
//res.redirect('/');
}
});
}else{
console.log("error");
}
});
}
});
Run Code Online (Sandbox Code Playgroud)
会发生什么,用户输入他们的登录信息并单击登录按钮.Ajax请求将数据发送到此访问功能.该函数首先检查用户是否存在于数据库中.如果它确实比继续比较bcrypt密码,如果它们相等则成功登录,如果它们不相等,那么显然它会出错.
问题似乎在这里: }else{
req.session.success = true;
res.send("Success");
//res.redirect('/');
}
当用户的电子邮件和密码匹配时,就会点击此处.它说...将此会话设置为true,因此用户可以访问需要此会话的页面,然后将Success消息发送回ajax请求.这当前工作完全正常,res.send被发送到前端.当我取消注释res.redirect时,会发生"在设置后无法设置标头"的预期结果.因此,当我注释掉res.send时,res.redirect根本就不起作用了.没有错误,没有任何破坏,只是没有.
我很好奇为什么这里的重定向不起作用?标头没有在此函数中的任何其他位置设置,预期结果应该是重定向将完美地工作.任何帮助是极大的赞赏.谢谢.
当您发送ajax调用并获得响应时,浏览器不会根据该ajax响应对浏览器中的当前页面执行任何操作.因此,无论您是否向ajax调用发送重定向响应都无关紧要.无论如何,浏览器都不会更改浏览器中的当前页面.Ajax响应为您的Javascript生成数据,然后您的Javascript必须决定如何处理它.
仅供参考,只有当重定向发生在浏览器页面请求或浏览器提交的表单发布(不是Javascript提交)时,浏览器才会更改当前页面. 由于这不是您登录的方式,因此您无法使用重定向来更改当前的浏览器页面.
因此,如果您要在客户端上使用ajax调用进行登录,并且您希望客户端在成功进行Ajax登录后更改页面,那么您可能希望在登录响应中发送重定向URL并让客户端处理它并设置window.location
为登录时进行重定向.
例如,您可以更改:
res.send("Success");
Run Code Online (Sandbox Code Playgroud)
对此:
res.json({status: "Success", redirect: '/'});
Run Code Online (Sandbox Code Playgroud)
然后,让您的客户端代码检查来自ajax调用的返回,如果状态成功,它可以获取redirect属性并执行以下操作:
if (ajaxResult.status === "Success") {
window.location = ajaxResult.redirect;
}
Run Code Online (Sandbox Code Playgroud)
我很好奇为什么这里的重定向不起作用?标头没有在此函数中的任何其他位置设置,预期结果应该是重定向将完美地工作.任何帮助是极大的赞赏.
已发送有关标头的消息意味着已发送整个响应res.send("Success");
,您现在正尝试发送另一个响应.您只能获得一个给定请求的响应.完成后res.send("Success");
,http服务器对象已发送整个响应,然后关闭该响应.此时您无法发送更多数据.
归档时间: |
|
查看次数: |
2711 次 |
最近记录: |