簡體   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