Node.js 如何在nodejs中设置标头?
我正在nodeJs中进行身份验证。我成功创建了登录API,它在邮递员上运行良好。我卡在客户端。它没有在头上设置令牌。我使用passport jwt进行身份验证。我的代码是Node.js 如何在nodejs中设置标头?,node.js,passport.js,Node.js,Passport.js,我正在nodeJs中进行身份验证。我成功创建了登录API,它在邮递员上运行良好。我卡在客户端。它没有在头上设置令牌。我使用passport jwt进行身份验证。我的代码是 app.post('/login', (req, res, next) => { var name = { name: req.body.name, password: req.body.password } // let m = ''; // console.log(name) re
app.post('/login', (req, res, next) => {
var name = {
name: req.body.name,
password: req.body.password
}
// let m = '';
// console.log(name)
request({
url: "http://localhost:3000/api/login",
method: "POST",
json: true, // <--Very important!!!
body: name
}, function (error, response) {
if (response.body.error == true) {
req.flash('errorMsg', response.body.message);
res.redirect('/');
}
else {
// localStorage.setItem('token', response.body.token);
// console.log(localStorage.getItem('token'))
// req.headers['authorization'] = response.body.token;
// res.setHeader('authorization', response.body.token);
// req.session['token'] = response.body.token;
// console.log(req.session['token'])
// res.set({
// 'Content-Type': 'text/plain',
// 'authorization':response.body.token
// });
// res.setHeader('authorization', response.body.token);
// req.headers['authorization'] = response.body.token;
res.redirect('/secret');
next();
}
});
// console.log(m);
});
我已尝试在标题中设置令牌,但效果不佳。如果我在app.use中间件上获得令牌,则我可以轻松验证令牌,但它不允许设置令牌。
我该怎么做???您是否尝试过为请求模块设置标题,如
请求({url:,方法:“POST”,json:true,//您尝试过为请求模块设置头吗
请求({url:,方法:“POST”,json:true,//您找到这个@nitin的答案了吗?您找到这个@nitin的答案了吗
app.use((req, res, next) => {
var token = req.body.token || req.session['token'] || req.query.token || req.headers['x-access-token'] || localStorage.getItem('token');
req.headers['authorization'] = token;
console.log(req.session['token'], token)
console.log(req.headers['authorization'], config.jwtSecret);
if (token) {
jwt.verify(token, config.jwtSecret, (err, decoded) => {
if (err) {
res.json({
'message': 'Failed to authenticate user'
});
} else {
req.decoded = decoded;
next();
}
});
} else {
// logger.warn('Unauthorized');
return res.sendStatus(401);
}
console.log(req.headers['authorization'])
});