Поэтому я хочу, чтобы на странице индекса отображалось имя пользователя, который в данный момент вошел в систему, в нижнем колонтитуле страницы индекса.
Мои маршруты входа в Google
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")
})
Моя стратегия Google
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>
Мой нижний колонтитул
1 ответ
Я настроил пользователя на профиль в своей стратегии Google, а затем выяснил, как он был сохранен в req.user
РЕДАКТИРОВАТЬ:
Другими словами, я сохранил переменную профиля в другой переменной (req.user).
Похожие вопросы
Новые вопросы
javascript
По вопросам программирования на ECMAScript (JavaScript/JS) и его различных диалектах/реализациях (кроме ActionScript). Имейте в виду, что JavaScript — это НЕ то же самое, что Java! Включите все ярлыки, относящиеся к вашему вопросу; например, [node.js], [jQuery], [JSON], [ReactJS], [angular], [ember.js], [vue.js], [typescript], [svelte] и т. д.