我在护照的帮助下在nodejs中使用google outh2.js通过开发谷歌策略。但是当我使用控制台时,问题就在这里.log任何文件的代码中的任何位置,无论它在 Web 应用程序目录中工作。但是当我使用我的控制台时.log在这个函数中没有执行任何内容,我既无法获取用户数据,也无法执行控制台.log 在此代码中执行时,仅在控制台中显示一条消息
(accessToken, refreshToken, profile, done) => {
console.log('data');
})
完整代码在这里:文件:护照设置.js
var passport = require('passport');
var GoogleStrategy = require('passport-google-oauth').OAuth2Strategy;
passport.use(new GoogleStrategy({
clientID: "",
clientSecret: "",
callbackURL: "http://127.0.0.1:3000/auth/google/redirect"
},
function(accessToken, refreshToken, profile, done) {
console.log('logineed');
}
));
路由:索引.js
var express = require('express');
var passport = require('passport');
var router = express.Router();
router.get('/login', function(req, res, next) {
res.render('index', { title: 'Login' });
});
router.get('/google',passport.authenticate('google', { scope: ['profile'] }));
router.get('/google/redirect', function(req,res){
res.redirect('/app');
});
router.get('/app',function(req,res){
res.send('Your are in');
});
module.exports = router;
入口点:应用.js
var createError = require('http-errors');
var express = require('express');
var path = require('path');
var cookieParser = require('cookie-parser');
var logger = require('morgan');
var indexRouter = require('./routes/index');
var usersRouter = require('./routes/users');
var passportConfig = require('./config/passport-setup');
var app = express();
// view engine setup
app.set('views', path.join(__dirname, 'views'));
app.set('view engine', 'ejs');
app.use(logger('dev'));
app.use(express.json());
app.use(express.urlencoded({ extended: false }));
app.use(cookieParser());
app.use(express.static(path.join(__dirname, 'public')));
app.use('/auth', indexRouter);
app.use('/app', usersRouter);
// catch 404 and forward to error handler
app.use(function(req, res, next) {
next(createError(404));
});
// error handler
app.use(function(err, req, res, next) {
// set locals, only providing error in development
res.locals.message = err.message;
res.locals.error = req.app.get('env') === 'development' ? err : {};
// render the error page
res.status(err.status || 500);
res.render('error');
});
module.exports = app;
您似乎没有将护照初始化为快递的中间件。
尝试将其添加到应用程序.js
app.use(passport.initialize());
问题出在代码上
router.get('/google/redirect', function(req,res){
res.redirect('/app');
});
在路由器.js文件中
我们应该写成
router.get('/google/redirect', passport.authenticate('google'), function(req,res){
res.redirect('/app');
});
因为发生的事情是在登录时,在链接重定向发生之前,可以访问该人的谷歌数据。但是在重定向后,对Google帐户数据的所有数据访问都将丢失。要再次访问它,我们将使用谷歌策略调用护照的身份验证功能,这将加载谷歌用户数据。如上面的代码所示