如何快速通过护照认证
How to get express route to go through passport for authentification
我最近将我在 es6 中制作的样板更改为稍旧的 es5 版本。我不得不重新创建导出,要求而不是使用导入,路由现在可以正常工作了。
我有这样的结构:
index.js (app)
api/index.js (/api endpoint)
api/auth.js (/api/auth endpoint)
api/protected.js (/api/protected endpoint)
在我的授权路线中,我有登录和注册功能并生成令牌:
const token = jwt.sign({id: req.body.username}, config.jwtSecret)
在我的 protected.js 中,我有以下内容:
const express = require('express');
const router = express.Router();
const passport = require('../config/passport');
router.use(passport.initialize({ session: false }));
router.use(passport.session());
router.get('/test', passport.authenticate('jwt') , (req, res) => {
res.status(200).json({ message: 'Hello sweetie', auth: req.isAuthenticated(), user: req.session.passport.user})
});
module.exports = router;
在我的 passport.js
const
passport = require('passport'),
config = require('./../config'),
passportJwt = require('passport-jwt'),
JwtStrategy = passportJwt.Strategy,
ExtractJwt = passportJwt.ExtractJwt,
userSchema = require('./../schemas/userSchema');
passport.serializeUser(function(user, done) {
console.log(JSON.stringify(user));
done(null, user[0].username);
});
passport.deserializeUser(function(username, done) {
console.log('DESER -- '+username);
userSchema.checkUsername(username)
.then(user => {
console.log(user[0]);
done(null, user[0]);
})
.catch(err =>{
console.log(JSON.stringify(err));
});
});
const jwtOptions = {
secretOrKey: config.jwtSecret,
jwtFromRequest: ExtractJwt.fromHeader('authorization'),
}
passport.use('jwt', new JwtStrategy(jwtOptions, function(jwt_payload, done) {
console.log('Strategy: '+ jwt_payload.id);
userSchema.checkUsername(jwt_payload.id)
.then(user => {
console.log(user[0].username);
if(user[0]) return done(null, user)
else return done(null, false)
})
.catch(err =>{
console.log(JSON.stringify(err));
});
}));
module.exports = passport;
问题是当我尝试访问:127.0.0.1:8080/api/protected/test
使用我登录时获得的令牌,它会给我一个:Unauthorized
此外console.log
里面的:
- 序列化用户
- 反序列化用户
- jwt 策略
从未显示,因此我认为没有使用 passport 中间件。
如何获得 /protected
路由来使用 passport 中间件?
编辑:我尝试打印护照对象,我可以看到我的 jwt
策略确实已定义。所以我不明白为什么它不想通过它。
问题是您的护照正在寻找 authorization
header 而不是 Authorization
header.
改变你的
jwtFromRequest: ExtractJwt.fromHeader('authorization')
到
ExtractJwt.fromAuthHeaderAsBearerToken()
所以你的选项看起来像
const jwtOptions = {
secretOrKey: config.jwtSecret,
jwtFromRequest: ExtractJwt.fromAuthHeaderAsBearerToken(),
}
现在,passport 将查找值为 bearer your_jwt_token
的 Authorization
header。
https://www.npmjs.com/package/passport-jwt
我最近将我在 es6 中制作的样板更改为稍旧的 es5 版本。我不得不重新创建导出,要求而不是使用导入,路由现在可以正常工作了。
我有这样的结构:
index.js (app)
api/index.js (/api endpoint)
api/auth.js (/api/auth endpoint)
api/protected.js (/api/protected endpoint)
在我的授权路线中,我有登录和注册功能并生成令牌:
const token = jwt.sign({id: req.body.username}, config.jwtSecret)
在我的 protected.js 中,我有以下内容:
const express = require('express');
const router = express.Router();
const passport = require('../config/passport');
router.use(passport.initialize({ session: false }));
router.use(passport.session());
router.get('/test', passport.authenticate('jwt') , (req, res) => {
res.status(200).json({ message: 'Hello sweetie', auth: req.isAuthenticated(), user: req.session.passport.user})
});
module.exports = router;
在我的 passport.js
const
passport = require('passport'),
config = require('./../config'),
passportJwt = require('passport-jwt'),
JwtStrategy = passportJwt.Strategy,
ExtractJwt = passportJwt.ExtractJwt,
userSchema = require('./../schemas/userSchema');
passport.serializeUser(function(user, done) {
console.log(JSON.stringify(user));
done(null, user[0].username);
});
passport.deserializeUser(function(username, done) {
console.log('DESER -- '+username);
userSchema.checkUsername(username)
.then(user => {
console.log(user[0]);
done(null, user[0]);
})
.catch(err =>{
console.log(JSON.stringify(err));
});
});
const jwtOptions = {
secretOrKey: config.jwtSecret,
jwtFromRequest: ExtractJwt.fromHeader('authorization'),
}
passport.use('jwt', new JwtStrategy(jwtOptions, function(jwt_payload, done) {
console.log('Strategy: '+ jwt_payload.id);
userSchema.checkUsername(jwt_payload.id)
.then(user => {
console.log(user[0].username);
if(user[0]) return done(null, user)
else return done(null, false)
})
.catch(err =>{
console.log(JSON.stringify(err));
});
}));
module.exports = passport;
问题是当我尝试访问:127.0.0.1:8080/api/protected/test
使用我登录时获得的令牌,它会给我一个:Unauthorized
此外console.log
里面的:
- 序列化用户
- 反序列化用户
- jwt 策略
从未显示,因此我认为没有使用 passport 中间件。
如何获得 /protected
路由来使用 passport 中间件?
编辑:我尝试打印护照对象,我可以看到我的 jwt
策略确实已定义。所以我不明白为什么它不想通过它。
问题是您的护照正在寻找 authorization
header 而不是 Authorization
header.
改变你的
jwtFromRequest: ExtractJwt.fromHeader('authorization')
到
ExtractJwt.fromAuthHeaderAsBearerToken()
所以你的选项看起来像
const jwtOptions = {
secretOrKey: config.jwtSecret,
jwtFromRequest: ExtractJwt.fromAuthHeaderAsBearerToken(),
}
现在,passport 将查找值为 bearer your_jwt_token
的 Authorization
header。
https://www.npmjs.com/package/passport-jwt