![](/img/trans.png)
[英]How to create an onclick cookie link and then after navigating to link's url, have that cookie redirect the current url
[英]How to redirect url after setting cookie using express?
这是我在快速路由器中的登录代码:
if (password === realpassword) {
res.cookie('thecookie', 'somethingliketoken');
res.redirect(302, '/somepages');
} else {
res.status(403).end();
}
我想设置Cookie,以便/somepages
可以识别谁是该用户。
但是我收到Error: Can't set headers after they are sent.
我已经尝试过return res.redirect(302, '/somepages');
。 对/somepages
的查询已正确发送,但该页面仍停留在我的/login
。
请帮忙。
我想我有原因。 我使用AJAX发布了用户名和密码,因此302重定向已发送到AJAX查询,是的,它成功重定向了,但这是AJAX查询 (而不是页面)的原因,这就是为什么收到第二个查询但页面却没有的原因更改。
this.$http({
url: '/userLogin',
method: 'post',
data: {
username: this.username,
password: SHA3(this.password, {outputLength: 256}).toString(),
},
}).then(res => {
console.log(res);
this.hintColor = '#00bdd8';
this.hint = 'success';
}).catch(err => {
this.hintColor = 'red';
if (err.response.status == 403) {
this.hint = 'mismatch';
} else {
this.hint = '500err';
}
});
我认为可能不应该这样使用它。
将使用window.location
代替。
如果还有其他方法,我非常感谢您的帮助。
我已经在我的登录帖子请求中做了类似的事情,并且它对我有用。
app.post('/index',function(req,res){
var uname = req.body.Username;
var pwd = req.body.Password;
if(uname && pwd === 'admin'){
var token = jwt.sign( { username: uname }, 'q1W2e3R4t5Y6u7I8o9P',{ expiresIn: '1m' }
);
res.cookie('auth',token);
res.redirect('home');
console.log('Authentication is done successfully.....');
console.log(token);
}
});
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.