繁体   English   中英

Passport.js模块,未定义的callbackURL

[英]Passport.js Module, undefined callbackURL

按照本指南所述设置Drupal之后: Drupal-passport我创建了一个简单的简单节点应用程序以测试其工作方式。

否,我收到InternalOAuthError: Failed to obtain request token错误。

通过strategy.js ,我看到我的callbackURL正在注销undefined不确定原因。 callbackURL在我的Drupal应用中设置

还可以执行curl -i -XPOST http://extranet.local/rest/system/connect/给我确切的需求

这是我的node.js代码(请记住,这只是为了测试drupal设置)。

var express = require('express');
var passport = require('passport');
var dStrategy = require('passport-drupal').DrupalStrategy;
var passportDrupal = require('passport-drupal');
var cookieParser = require('cookie-parser');
var bodyParser = require('body-parser')
var session = require('express-session');
var http = require('http');

var app = express();
var server = http.createServer(app);

app.use(cookieParser());
app.use(bodyParser());
app.use(session({ secret: 'SECRET' }));
app.use(passport.initialize());
app.use(passport.session());

passport.use(new dStrategy({
    consumerKey: "emDVp7P2LZFLPcN3cNCjLmrjrhQLnNv6",
    consumerSecret: "mkbc3UYEuUQLNQRwLWo3B8zEk4ZrErKa",
    providerURL: "http://extranet.local",
    resourceEndpoint: "rest/system/connect", // <---- optional. Defaults to `rest/system/connect`
    callbackURL: 'http://33.33.33.40:8888/auth/drupal/callback'
  },
  function(token, tokenSecret, profile, done) {
    profile.oauth = { token: token, token_secret: tokenSecret };
    done(null, profile);
  }
));
app.get('/', function(req, res) {
  res.writeHead(200);
  res.end("This is root");
});
app.get('/auth/drupal',
  passport.authenticate('drupal'),
  function(req, res) {
    // The request will be redirected to the Drupal website for
    // authentication, so this function will not be called.
});
app.get('/auth/drupal/callback',
  passport.authenticate('drupal', { failureRedirect: '/error' }),
  function(req, res) {
    // Successful authentication, redirect home.
    res.redirect('/signedin');
});

app.get('/error', function(req, res) {
  res.writeHead(200);
  res.end("Could not sign in");
});
app.get('/signedin', function(req, res) {
  res.writeHead(200);
  res.end("signed in");
});

server.listen(8888, '33.33.33.40');

任何关于为什么或想法受到赞赏的线索

如果查看passport-drupalDrupalStrategy库的strategy.js代码,您将看到DrupalStrategy构造函数不希望options参数对象中具有callbackURL属性,也不会将其进一步传递给OAuthStrategy

这是为oauth策略创建参数的代码片段:

  // Determine all necessary OAuth options
  var oauthOptions = {
    requestTokenURL: this._providerURL + '/oauth/request_token',
    accessTokenURL: this._providerURL + '/oauth/access_token',
    userAuthorizationURL: this._providerURL + '/oauth/authorize',
    consumerKey: options.consumerKey,
    consumerSecret: options.consumerSecret
  };

  OAuthStrategy.call(this, oauthOptions, verify);

应该对其进行修改以传递callbackURL,例如:

  // Determine all necessary OAuth options
  var oauthOptions = {
    requestTokenURL: this._providerURL + '/oauth/request_token',
    accessTokenURL: this._providerURL + '/oauth/access_token',
    userAuthorizationURL: this._providerURL + '/oauth/authorize',
    consumerKey: options.consumerKey,
    consumerSecret: options.consumerSecret,
    callbackURL: options.callbackURL// <==== THIS LINE WAS ADDED
  };

  OAuthStrategy.call(this, oauthOptions, verify);

我不确定这是否可以解决您的问题。 但是我提出了要求

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM