【问题标题】:Passport-facebook-token keeps returning 401Passport-facebook-token 不断返回 401
【发布时间】:2015-03-06 03:32:44
【问题描述】:

目前,我正在为我的 iOS 应用程序使用带有 Express 和 Passport-facebook-token 模块的 NodeJS。我遇到了麻烦,因为即使我们通过了 OAuth 逻辑,服务总是返回 401 响应。关于此代码的任何想法,为什么即使它成功通过身份验证并使用我们的 handleAuthentiation 方法但没有达到我调用的 console.log("THIS IS NOT BEING CALLED") 方法,它为什么仍然返回 401?

var http = require("http");
var express = require("express");
var bodyParser = require('body-parser');
var database = require('./database.js');
var passport = require('passport'),
    FacebookTokenStrategy = require('passport-facebook-token').Strategy;

var User = require('./User.js');
var app = express();

//setup json parsing
app.use(bodyParser.json());
app.use(bodyParser.urlencoded({extended: true}));

//setup facebook authentication
passport.use(new FacebookTokenStrategy({
        clientID: "2454efafd33r",
        clientSecret: "323245343"
    },
    function(accessToken, refreshToken, profile, done) {
        User.handleAuthentication(accessToken, refreshToken, profile, done, function(err, user) {
            console.log("handleAuthentication user is " + JSON.stringify(user));
            console.log("handleAuthentication error is " + JSON.stringify(err));
            done(err, user);
        });
    }
));

app.post('/auth/facebook/token',
    passport.authenticate('facebook-token'),
    function(req, res) {

        console.log("THIS IS NOT BEING CALLED");

        // do something with req.user
        res.status(200);
        res.send(user);
    }
);

http.createServer(app).listen(3000);

我正在尝试通过其他库跟踪调用,但我似乎找不到任何定义了 success 的方法。我注意到done 方法被映射到验证,然后调用success

【问题讨论】:

    标签: ios node.js facebook passport.js passport-facebook


    【解决方案1】:

    想通了。原来我没有正确初始化 Oauth。我需要设置以下内容:

    // Configure Express
    app.use(logger('combined'));
    app.use(cookieParser());
    app.use(bodyParser.urlencoded({ extended: false }));
    app.use(bodyParser.json());
    app.use(methodOverride('X-HTTP-Method-Override'));
    app.use(session({secret: 'supernova', saveUninitialized: true, resave: true}));
    app.use(passport.initialize());
    app.use(passport.session());
    

    【讨论】:

    • 我遇到了同样的问题,但我使用的是sails.js 框架,这些配置中的哪一个起到了神奇的作用?
    【解决方案2】:

    对我来说,我使用了文档中的示例:https://www.npmjs.com/package/passport-facebook-token,所以我没有添加“.Strategy”

    对于问题中的“POST”方法,我从前端发送了正文:

    const tokenBlob = new Blob([JSON.stringify({access_token: response.accessToken}, null, 2)], {type : 'application/json'}); 
    

    如解释:https://medium.com/@alexanderleon/implement-social-authentication-with-react-restful-api-9b44f4714fa

    祝你好运!

    【讨论】:

      猜你喜欢
      • 2016-05-06
      • 2018-04-26
      • 1970-01-01
      • 2017-09-07
      • 2021-10-11
      • 1970-01-01
      • 1970-01-01
      • 2023-02-04
      • 2017-07-13
      相关资源
      最近更新 更多