护照Facebook验证回叫未被调用

Ste*_*der 10 facebook callback verify node.js passport.js

我正在创建一个节点应用程序,当我尝试使用Facebook的护照时,验证回调不会运行(没有记录任何内容).任何帮助,将不胜感激.

var express = require('express');
var routes = require('./routes/routes.js');
var layout = require('./routes/layout.js');
var facebook = require('./routes/facebook.js');
var editprof = require('./routes/editprof.js');
var app = express();
var vogels = require('vogels');
var passport = require('passport');
var FacebookStrategy = require('passport-facebook').Strategy;
var configAuth = require('./config/auth');


app.use(passport.initialize());
app.use(passport.session());
Run Code Online (Sandbox Code Playgroud)

...

passport.use(new FacebookStrategy({

    // pull in our app id and secret from our auth.js file
    clientID        : configAuth.facebookAuth.clientID,
    clientSecret    : configAuth.facebookAuth.clientSecret,
    callbackURL     : 'http://localhost:8080/auth/facebook/callback'

},

// facebook will send back the token and profile
function(token, refreshToken, profile, done) {
    console.log("TOKEN",token);
    // asynchronous
    process.nextTick(function() {
        console.log("TOKEN",token);
        console.log("ID", profile.id);
        return done(null, profile);

    });

}));
Run Code Online (Sandbox Code Playgroud)

...

app.get('/auth/facebook', passport.authenticate('facebook'));
app.get('/auth/facebook/callback', facebook.callback);
Run Code Online (Sandbox Code Playgroud)

Nic*_*Dao 1

我也遇到过同样的问题,那是 DNS 问题graph.facebook.com。这可以防止passport-oauth2后面的模块passport-facebook获取 FB 令牌。verify然后回调将被跳过。

您可以测试一下您的问题是否与这里的js片段相同:

const dns = require('dns')
dns.lookup('graph.facebook.com', console.log)
Run Code Online (Sandbox Code Playgroud)

如果此代码返回类似以下内容:

{ Error: getaddrinfo ENOTFOUND graph.facebook.com
    at errnoException (dns.js:28:10)
    at GetAddrInfoReqWrap.onlookup [as oncomplete] (dns.js:73:26)
  code: 'ENOTFOUND',
  errno: 'ENOTFOUND',
  syscall: 'getaddrinfo',
  hostname: 'graph.facebook.com' }
Run Code Online (Sandbox Code Playgroud)

那么你的问题确实是由DNS问题引起的。

有多种方法可以解决 DNS 问题,但对我来说最简单的方法是/private/etc/hosts在 Mac 上手动编辑文件:

第一步:获取graph.facebook.comIP:

nslookup graph.facebook.com
Run Code Online (Sandbox Code Playgroud)

第 2 步:更新您的/private/etc/hosts

sudo vim /private/etc/hosts
Run Code Online (Sandbox Code Playgroud)

只需在文件底部添加一个新行(例如 graph.facebook.com)

第 3 步:再次测试dns.lookup('graph.facebook.com', console.log):如果现在已解决此问题,则该命令应返回类似以下内容的内容:

null '157.240.8.18' 4
Run Code Online (Sandbox Code Playgroud)

希望这能解决您的问题。

干杯,

尼克