2

我正在尝试使用 NodeJS 验证签名令牌并从中提取信息。

我现在浏览器中有一个名为 userToken 的令牌,登录后已经保存(顺便用 auth0 登录)。

我尝试在此处手动验证我的令牌:http: //jwt.io,它可以正常工作并毫无问题地为我提供有效负载数据。但是,我不能用 NodeJS 做同样的事情。我该怎么做?

我阅读了文档,但我无法得到它。 https://github.com/auth0/express-jwt

这是我的 server.js

var http = require('http');
var express = require('express');
var cors = require('cors');
var app = express();
var jwt = require('express-jwt');
var dotenv = require('dotenv');

dotenv.load();

var authenticate = jwt({
    secret: new Buffer(process.env.AUTH0_CLIENT_SECRET, 'base64'),
    audience: process.env.AUTH0_CLIENT_ID
});


// view engine setup
var path = require('path');
app.set('views', path.join(__dirname, 'views'));
app.use(express.static(path.join(__dirname, 'public')));

app.set('view engine', 'jade');


app.configure(function () {

    // Request body parsing middleware should be above methodOverride
    app.use(express.bodyParser());
    app.use(express.urlencoded());
    app.use(express.json());
    app.use(cors());

    app.use(app.router);
});


app.get('/', function (req, res) {
    res.render('index');
});

app.get('/test', function(req,res) {
    // how do I check it?
});


var port = process.env.PORT || 3001;

http.createServer(app).listen(port, function (err) {
    console.log('listening in http://localhost:' + port);
});
4

2 回答 2

6

您无需执行任何操作。由于您正在使用它express-jwt,只需将userProperty标签传递给jwt

var authenticate = jwt({
    secret: new Buffer(process.env.AUTH0_CLIENT_SECRET, 'base64'),
    audience: process.env.AUTH0_CLIENT_ID,
    userProperty: 'payload'
});

因此,您可以req.payload在控制器中使用所有 jwt 有效负载数据。你可以用console.log(req.payload).

你可以在这里看到它是如何工作的:https ://github.com/auth0/express-jwt/blob/master/lib/index.js#L121

我希望它有帮助,对我的英语感到抱歉。

于 2016-06-25T17:59:31.003 回答
5

这个样本应该可以帮助你,它没有经过测试,但确定它是正确的,看看源代码express-jwt,它在幕后确实是一样的

app.get('/test', function(req, res) {
    var jsonwebtoken = require('jsonwebtoken'); //install this, move to declarations
    var loginToken = req.headers.authentication || req.body.userToken || req.headers.Bearer; //or your own, it's just headers that pass from browser to client
    jsonwebtoken.verify(loginToken, new Buffer(process.env.AUTH0_CLIENT_SECRET, 'base64'), function(err, decoded) {
        if(err) {
            return res.status(401).send({message: 'invalid_token'});
        }
        //be aware of encoded data structure, simply console.log(decoded); to see what it contains
        res.send(decoded); //`decoded.foo` has your value
    });
});

问题是您必须自己对数据进行编码,然后进行解码,因此请注意 auth0 会为您返回有效的数据结构(否则我不确定)

于 2015-10-19T06:30:23.917 回答