节点服务器

时间:2015-11-27 21:36:13

标签: javascript angularjs node.js express passport.js

我在客户端使用angular来使用用户对象向服务器执行发布。此用户对象只允许我将所有用户信息,用户名,密码,电子邮件,名称等传递到一个对象中。而不是必须将每一个作为单独的变量传递。

我在chrome的开发者工具中看到以下POST参数。

{"username":"adfasdfasdf","password":"12123123123"}

然而,在我的服务器端js中,数据作为单独的变量而来。而不是具有用户名和密码的对象。因此,console.log('userData ='+ userData)行记录用户名。而“done”变量包含密码。

为什么我没有在服务器端获取对象?

客户端HTML

<form class="form-signin", ng-submit="register()">
  <input type="text" class="form-control" placeholder="Username" ng-model="user.username">
  <input type="password" class="form-control" placeholder="Password" ng-model="user.password">
</form>

CLIENT JS

    var pollControllers = angular.module('pollControllers', []);
pollControllers.controller('RegisterCtrl', ['$scope', '$http', '$location',
    function($scope, $http, $location) {
            // This object is filled by the form
            $scope.user = {};

            $scope.register = function() {
                $http.post('http://xx.xx.xxx.xxx:3000/register', $scope.user);
            }
    }
]);

SERVER JS

module.exports = function(passport) {
  function(userData, done) {
    console.log('userData = ' + userData); // !this outputs the username!
    console.log('done = ' + done); // !this outputs the password!
  }
}

1 个答案:

答案 0 :(得分:1)

Passport local获取1st params作为用户名,第2个参数作为密码,第3个参数作为回调。

passport.use(new LocalStrategy(
  function(username, password, done) {
    User.findOne({ username: username }, function (err, user) {
      if (err) { return done(err); }
      if (!user) { return done(null, false); }
      if (!user.verifyPassword(password)) { return done(null, false); }
      return done(null, user);
    });
  }
));

Passport Local Github Page