gpt4 book ai didi

node.js - 使用范围保护 API(oauth2orize、passport、express、Nodejs)

转载 作者:搜寻专家 更新时间:2023-10-31 23:24:56 24 4
gpt4 key购买 nike

我正在尝试使用 node/express 创建一个 API,并使用 Passport 和 oauth2orize 来保护它。我已经让 API 正常工作,我已经让 oauth2 东西正常工作,但我似乎无法弄清楚如何使用范围实现安全的 API 方法。

oauth2orize token 处理程序:

server.exchange(oauth2orize.exchange.password(function (client, username, password, scope, done) {
scope = scope || ['unauthorized'];
db.collection('oauth_users').findOne({username: username}, function (err, user) {
if (err) return done(err);
if (!user) return done(null, false);
for (i in scope)
if(user.scope.indexOf(scope[i]) < 0) return done(null, false);
bcrypt.compare(password, user.password, function (err, res) {
if (!res) return done(null, false);

var token = utils.uid(256)
var refreshToken = utils.uid(256)
var tokenHash = crypto.createHash('sha1').update(token).digest('hex')
var refreshTokenHash = crypto.createHash('sha1').update(refreshToken).digest('hex')

var expirationDate = new Date(new Date().getTime() + (3600 * 1000))

db.collection('oauth_access_tokens').save({token: tokenHash, expirationDate: expirationDate, clientId: client.clientId, userId: username, scope: scope}, function (err) {
if (err) return done(err)
db.collection('oauth_refresh_tokens').save({refreshToken: refreshTokenHash, clientId: client.clientId, userId: username}, function (err) {
if (err) return done(err)
done(null, token, refreshToken, {expires_in: expirationDate})
})
})
})
}) }))

Passport 持有人 token 检查器:

passport.use("accessToken", new BearerStrategy(
{passReqToCallback: true},
function (req, accessToken, done) {
console.dir(req.params);
var accessTokenHash = crypto.createHash('sha1').update(accessToken).digest('hex')
db.collection('oauth_access_tokens').findOne({token: accessTokenHash}, function (err, token) {
if (err) return done(err);
if (!token) return done(null, false);
if (new Date() > token.expirationDate) {
db.collection('oauth_access_tokens').remove({token: accessTokenHash}, function (err) { done(err) });
} else {
db.collection('oauth_users').findOne({username: token.userId}, function (err, user) {
if (err) return done(err);
if (!user) return done(null, false);
// no use of scopes for no
var info = { scope: '*' }
done(null, user, info);
})
}
})
}))

API 安全性:

router.get('/restricted', passport.authenticate('accessToken', { scope: "unauthorized", session: false }), function (req, res) {
res.send("Restricted Function");})

我找不到访问 passport.authenticate 中传递给 passport.use 的“范围”选项的示例。我以为它在 req 对象中,但我在那里找不到它。有帮助吗?

最佳答案

有点晚了。但认为这可能会有所帮助。您作为第三个参数传递的 info 对象可以从中间件用作 req.authInfo。如果您将 scope 附加到 user 对象,或者如果您已在 passport.authenticate 初始化级别声明它,则可以通过此参数传递它并在中间件中使用。请查看此链接 Usage of scopes

关于node.js - 使用范围保护 API(oauth2orize、passport、express、Nodejs),我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/29481771/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com