![](/img/trans.png)
[英]Passport.js / Google OAuth2 strategy - How to use token on login for API access
[英]How can I access profile information in google Oauth2 passport?
所以我希望索引頁在索引頁的頁腳中顯示當前登錄的用戶的名稱。
我的谷歌登錄路線
router.get("/login/google", passport.authenticate('google', { scope:
[ 'email', 'profile' ] }));
router.get("/login/google/callback", passport.authenticate("google", {
successRedirect: "/videos",
failureRedirect: "/login/google/error"
}));
router.get("/login/google/error", (req, res) => {
res.send("Error in google login")
})
我的谷歌策略
passport.use(new GoogleStrategy({
clientID: GOOGLE_CLIENT_ID,
clientSecret: GOOGLE_CLIENT_SECRET,
callbackURL: "http://localhost:3000/login/google/callback",
passReqToCallback: true
},
function(request, accessToken, refreshToken, profile, done) {
User.findOrCreate({ googleId: profile.id }, function (err, user) {
return done(err, user);
});
}
));
我的索引文件頁腳
<footer>
<% if(!auth){ %>
<li class="nav-item">
<a href="/register" class="nav-link active">Register!</a>
<li class="nav-item">
<a href="/login" class="nav-link active">Log In</a>
</li>
</li>
<% } else { %>
<li class="nav-item">
<a href="#" class="nav-link disabled">Welcome, <%= auth.username %> </a>
</li>
<li class="nav-item">
<a href="/logout" class="nav-link active">Log Out</a>
</li>
<% } %>
<div class="d-flex justify-content-center mt-3">
<ul class="nav">
<li class="nav-item">
<div class="g-ytsubscribe" data-channelid="UCAjHeCmPJ5lDVWw6dL_jQng" data-layout="default" data-count="default"></div>
</li>
</ul>
</footer>
我的頁腳
我在我的谷歌策略中將用戶設置為配置文件,然后知道它是如何保存在 req.user 中的
編輯:
換句話說,我將配置文件變量保存在另一個變量(req.user)中。
聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.