繁体   English   中英

快递 | node.js | oauth2 未进行身份验证

[英]express | node.js | oauth2 not authenticating

所以,我使用 express 和passport-oauth2 / passport-discord为我的 discord 机器人创建了一个网站,但是 checkauth function 总是返回 false,并且在身份验证过程中,我只是被重定向到主要身份验证路由,没有任何反应。 (我永远不会被重定向到仪表板)

继承人的代码:(我试图包括与问题相关的每个文件):

// strategy file 

const DiscordStrategy = require('passport-discord').Strategy;
const passport = require('passport');
const DiscordUser = require('.././models/DiscordUser');
var session = require('express-session')


passport.serializeUser((user, done) =>{
    done(null, user.id)
})

passport.deserializeUser(async (id, done) =>{
    const user = await DiscordUser.findById(id);
    if(user){
        done(null, user);
    }
})


passport.use(new DiscordStrategy({
    clientID: process.env.CLIENT_ID,
    clientSecret: process.env.CLIENT_SECRET,
    callbackURL: process.env.CLIENT_REDIRECT,
    scope: ['identify', 'guilds', 'email', 'bot']
}, async (accessToken, refreshToken, profile, done) => {
    try{
        const user = await DiscordUser.findOne({ discordId: profile.id});
        if(user) {
            console.log('a known user entered!')
            done(null, user);
        }else{
            console.log('a new user entered!')
            const newUser = await DiscordUser.create({
                discordId: profile.id,
                username: profile.username,
                discriminator: profile.discriminator,
                email: profile.email,
                guilds: profile.guilds
            });
            const savedUser = await newUser.save();
            done(null, savedUser);
        }

    }catch(err) {
        console.log(err);
        done(err, null);
    }
    
}));










//checkauth file

module.exports = async (req, res, next) => {
    if(req.isAuthenticated()){
        return next();
    } else {
        return res.redirect("/auth");
    }
};









//auth router

const router = require('express').Router();
const passport = require('passport');

router.get('/', passport.authenticate('discord'));

router.get('/redirect', passport.authenticate('discord', {
    failureRedirect: '/forbidden',
    successRedirect: '/dashboard'
}), (req, res) => {
    res.sendStatus(200);
})


module.exports = router;









//dashboard router

const router = require('express').Router();
var session = require('express-session');
const CheckAuth = require('../CheckAuth');


router.get('/', CheckAuth, (req, res) => {
    res.sendFile('../views/dashboard/index')
})


module.exports = router;

在主文件中,我只是创建一个随机 cookie,定义路由,然后使用 app.use(passport.initialize()) 和 app.use(passport.session())。

如果您需要其他任何信息,请告诉我,ty:)

文档中,他们使用回调方法而不是successRedirect

router.get('/redirect', passport.authenticate('discord', {
    failureRedirect: '/'
}), function(req, res) {
    res.redirect('/secretstuff') // Successful auth
});

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM