【发布时间】:2016-01-07 18:19:57
【问题描述】:
我正在使用 Mailgun 节点 machine-pack 发送一封电子邮件,其中包含一个使用 machinepack-jwt 创建的 JWT 的 url。当用户在生成的电子邮件中单击“确认”时,它会点击我想要解码 JWT 的 Sails 控制器方法。
我不断得到一个具有空字符串作为其值的属性的对象。
供参考: 我正在使用node-machine machinepack-jwt 进行编码和解码。我试图这样标记问题,但此标记不在可用标记中,而且我没有所需的 1500 个代表点
我的帆控制器:
module.exports = {
//Encode method
signup: function (req, res){
if (!req.param('serviceManager')) {
res.badRequest('Missing required parameter!');
} else {
var Mailgun = require('machinepack-mailgun');
var JWT = require('machinepack-jwt');
var newUser = req.param('serviceManager');
JWT.encode({
secret: 'my_secret',
algorithm: 'my_algo',
expires: 2880, //in minutes(two days)
payload: newUser.email + ':' + newUser.password
}).exec({
error: function (err){
console.log(err);
},
success : function (authToken){
Mailgun.sendHtmlEmail({//my Mailgun send with template that has authToken in it});
//Decode method
confirm_email: function (req, res){
if (!req.params[0]) {
res.badRequest('Missing required parameter!');
} else {
var JWT = require('machinepack-jwt');
var authToken = req.params[0];
console.log(authToken);
JWT.decode({
secret: 'my_secret',
token: authToken,
algorithm: 'my_algo'
}).exec({
error: function (err) {
res.send(err);
},
success: function (decodedToken) {
res.view('emailconfirmed');
console.log(decodedToken);// returns { id: '', email: '', role: '', sessionId: '' }
}
});
}
}
我期待的是我在发送的 JWT 中编码的用户电子邮件和密码。
【问题讨论】:
-
我知道这是一篇旧帖子,但
jsonwebtoken非常可爱:npmjs.com/package/jsonwebtoken。它让你.sign()编码和.verify()解码。 jwt.io
标签: node.js sails.js jwt sails-postgresql