我太环回了,但是我按照步骤安装和搭建我的文件夹(loopback-server),在server / boot / i中创建了一个文件script.js并包含以下代码:
module.exports = function(app) {
var MongoDB = app.dataSources.MongoDB;
MongoDB.automigrate('Customer', function(err) {
if (err) throw (err);
var Customer = app.models.Customer;
Customer.create([
{username: 'admin', email: 'admin@admin.com', password: 'abcdef'},
{username: 'user', email: 'muppala@ust.hk', password: 'abcdef'}
], function(err, users) {
if (err) throw (err);
var Role = app.models.Role;
var RoleMapping = app.models.RoleMapping;
//create the admin role
Role.create({
name: 'admin'
}, function(err, role) {
if (err) throw (err);
//make admin
role.principals.create({
principalType: RoleMapping.USER,
principalId: users[0].id
}, function(err, principal) {
if (err) throw (err);
});
});
});
});
};
如果您需要更多文件,请在下面的评论中告诉我,但我评论此文件并没有得到该错误。 顺便说一句,我试图更改{username:' admin',..}和Role.create({的键和值 名称:' admin'},.... 但要么不工作或它的工作,但我不能以管理员身份登录..这对我来说太混乱了。 有人可以帮忙吗?
谢谢。答案 0 :(得分:4)
如果您的Role
实体存储在数据库中,那么每次应用程序启动时,此代码都会尝试创建该Role实体(名称为"admin"
)。但是,在第一次之后,该角色已经存在,因此您会收到一个错误,即您有一个重复的名称"。您可能想要做的是检查角色是否已经存在,或者不将角色存储在您的数据库中。
您可以添加一些代码来检查当前数据库,只有在不存在的情况下才添加该角色。像这样:
Role.find({ name: 'admin' }, function(err, results) {
if (err) { /* handle this! */ }
if (results.length < 1) {
// now we know the DB doesn't have it already, so do the Role creation...
}
});
请注意,您还需要检查该角色表是否已包含您要添加的主体,并且只有在它们尚未添加时才添加它们。