1

我正在尝试使用 Stormpath 自定义注册页面,但我无法弄清楚为什么配置选项不起作用。enableXXX 和 requireXXX 工作,但 web:{...} 内的任何信息都没有显示。我已经尝试重新排序选项,但这也不起作用。

具体来说,我想:

-- 在 /signup 而不是 /register 注册用户。现在只有 /register 正在工作。

-- 我想在注册后将他们重定向到另一个站点。我随机把google.com放在那里,但是注册完成后我仍然被重定向到“/”。

-- 我想重新排序注册字段。我希望电子邮件成为第一个字段,但用户名目前是第一个。

这是 app.js:

// Import required modules.
var express = require('express');
var stormpath = require('express-stormpath');
var path = require('path');
var engine = require('ejs-mate');
var app = express();

// use ejs-locals for all ejs templates: 
  app.engine('ejs', engine);

// Configure public views
  app.set('views','./views');

app.use(stormpath.init(app, {
  apiKeyFile: process.env[(process.platform == 'win32') ? 'USERPROFILE' : 'HOME'] + ~removed
  secretKey: '~removed',
  application: '~removed',
  enableRegistration: true,
  enableGivenName: false,
  requireGivenName: false,
  enableSurname: false,
  requireSurname: false,
  website: true,
  api: true,
  web: {
    register: {
      uri: '/signup',  // Use a different URL
      nextUri: 'http://google.com',    // Where to send the user to, if auto login is enabled
      fields: {
        passwordConfirm: {
          enabled: true,
          required: true
        }
      },
      fieldOrder: [ "email", "username", "password", "passwordConfirm" ],

    }
  },
  enableUsername: true,
  requireUsername: true,
  enableConfirmPassword: true,
  requireConfirmPassword: true

}
));

app.get('/', function(req, res) {
  res.render('home.ejs', {
    title: 'Welcome'
  });
});

app.get('/', function(req, res) {
  res.send('home page!');
});

app.listen(process.env.PORT || 3000);

其他可能相关的信息:

-- 该站点托管在 Heroku 上,但我没有使用 Stormpath 插件,因为我无法让它工作。

-- 我在 Mac 上。

我已经坚持了好几天了,我一直无法弄清楚我做错了什么。任何帮助将非常感激。

4

1 回答 1

0

问题可能是这样的:我们最近发布了这个库的一个新版本,它有新的配置选项,看起来你正在使用我们的旧文档作为参考。

以下是您要执行的操作:

更新到最新的 express-stormpath 版本。然后使用下面的代码:(我将您的示例转换为使用最新版本):

app.use(stormpath.init(app, {
  client: {
    apiKey: {
      file: process.env[(process.platform == 'win32') ? 'USERPROFILE' : 'HOME'] + '~removed'
    }
  },
  application: {
    href: '~removed',
  },
  web: {
    register: {
      enabled: true,
      uri: '/signup',
      nextUri: 'http://google.com',  // don't send them here =)
      fields: {
        username: {
          enabled: true,
          required: true
        },
        givenName: {
          enabled: false,
          required: false
        },
        surname: {
          enabled: false,
          required: false
        },
        passwordConfirm: {
          enabled: true,
          required: true
        }
      },
      fieldOrder: ['username', 'email', 'password', 'passwordConfirm']
    }
  },
  website: true,
  api: true
}));
于 2015-10-15T00:03:45.813 回答