当我使用 app.use 时,护照总是 returns 401

Passport Always returns 401 when I use app.use

我一直在尝试使用基于“passport-http”基本策略的自定义策略来验证我的路由。这是我的策略代码。

passport_auth.js

var BasicStrategy = require('passport-http').BasicStrategy;

module.exports.userBasic = (function(name){
  var userAuthBasic = new BasicStrategy(
    function(username, password, done) {

      //My strategy
    }
  );
  userAuthBasic.name = name;
  return userAuthBasic;
})('userBasic');

我使用 IIFE 注册了我的策略名称。然后在文件 app.js 中调用如下:

app.js

var express = require('express');
var bodyParser = require('body-parser');
var passport = require('passport');
var userRouter = require(__dirname+'/http/routers/user_router.js');
const cors = require('cors')();
var passportAuth = require(__dirname + '/http/passport_auth'); //My file with my strategy

//Adds to passport my strategy
passport.use(passportAuth.userBasic);

var app = express();
app.use(cors);
app.use(bodyParser.json());
app.use(bodyParser.urlencoded({ extended: true }));
app.use(passport.initialize());


app.use('/user', passport.authenticate('userBasic', { session: false }), userRouter);

userRouter包含多条路线。当我尝试 POST 到 /user/anything 总是 return 401 代码状态。

这个配置好吗?在其他模块中,相同的代码工作正常,但在这种情况下,我花了很多时间试图解决这个问题。

解决方案 问题是我没有发送 header 来获得由以下内容组成的授权:'Basic' 字符串 + 'username : password' 以 base 64 编码。

在 angular HTTP 响应中。

    $http({
              url: serverUrl,
              method: 'POST',
              headers: {'authorization': 'Basic ' +  new Buffer(username + ':' + password).toString('base64');},
              data: fields
            })

感谢 @Vadim 在这个 post http://goo.gl/xkpCfN

中的回答