护照和智威汤逊
Posted
技术标签:
【中文标题】护照和智威汤逊【英文标题】:passport and JWT 【发布时间】:2015-05-25 19:36:37 【问题描述】:所以我设法让 passport-twitter 与 jsonwebtoken 库一起工作,但为了使其正常工作,我必须使用 express-session 作为中间件。我不想添加会话,因为我正在使用 jsonwebtoken 返回令牌。
这是代码 验证.js
router.get('/twitter', function(req, res, next)
passport.authenticate('twitter', session: false, function(err, user, info)
if(err) return next(err);
if(user)
var token = createToken(user);
console.log(token);
return res.json(token: token);
else
return res.status(401).json(info);
)(req, res, next);
);
我已经添加了 session: false 作为参数,但是在 server.js 上它一直在吐错误,我需要使用 express-session。
server.js
var express = require('express');
var path = require('path');
var logger = require('morgan');
var bodyParser = require('body-parser');
var mongoose = require('mongoose');
var passport = require('passport');
var session = require('express-session');
var config = require('./config');
mongoose.connect('mongodb://localhost', function()
console.log("Connected to the database");
)
require('./passport')(passport);
var app = express();
var authenticate = require('./routes/authenticate')(app, express, passport);
var api = require('./routes/api') (app, express, passport);
// uncomment after placing your favicon in /public
//app.use(favicon(__dirname + '/public/favicon.ico'));
app.use(logger('dev'));
app.use(bodyParser.json());
app.use(bodyParser.urlencoded( extended: false ));
app.use(session(
secret: config.TOKEN_SECRET,
resave: true,
saveUninitialized: true,
));
app.use(express.static(path.join(__dirname, 'public')));
app.use(passport.initialize());
app.use('/auth', authenticate);
app.use('/api', api);
app.get('*', function(req, res)
res.sendFile(__dirname + '/public/app/views/index.html');
);
app.listen(3000, function(err)
if(err)
return res.send(err);
console.log("Listening on port 3000");
);
所以每当我删除 app.use(session()) 并尝试使用 passport-twitter 进行身份验证时。我会得到这个错误
error Oauth Strategy requires app.use(express-session));
我知道显而易见的解决方案是添加该行,但我不想使用 session. Oauth 0.1 真的需要使用 session 吗?
【问题讨论】:
这个问题有答案了吗? 我也想知道它的解决方案。 【参考方案1】:Passports 基于 OAuth 的策略使用会话中间件来跟踪登录过程。您不需要将会话中间件用于其他任何事情,只需将您的身份验证基于您的令牌并忽略会话。
【讨论】:
有人有这个工作的例子吗? @airsoftFreak 你有可以分享的解决方案吗?以上是关于护照和智威汤逊的主要内容,如果未能解决你的问题,请参考以下文章