我正在使用Yii2构建一个应用程序,我正在使用多租户架构。所以..。每个客户都有自己的数据库(相同的结构)。
到目前为止我所做的:
我做了什么,但我不确定:
我用以下代码创建了一个文件组件/ActiveRecord.php:
<?php
namespace app\components;
use Yii;
class ActiveRecord extends \yii\db\ActiveRecord {
public static function getDb() {
if (isset($_SESSION['userdb'])) {
$currentDB = $_SESSION['userdb'];
return Yii::$app->get($currentDB);
}
}
}?>所以..。登录时,我将数据库保存在会话和上述文件中,该文件扩展了默认的ActiveRecord,我重写了getDb函数,并选择了自己的函数。随后,我更改了所有模型,使它们扩展了我的ActiveRecord。
我不确定这个策略是否正确,但它几乎奏效。
问题在哪里:
一切都很好除了..。RBAC!对于RBAC,我使用yii2-rbac扩展。问题是,用户不是从数据库中获取角色,而是从config/web.php文件中的第一个声明数据库中获取角色。因此,无论登录用户是什么,都使用第一个db。
Question(s):
提前感谢您的时间和支持。
发布于 2016-12-23 18:35:29
问题1:如何解决这个问题?您是否知道将角色授予登录用户的文件在哪里?
我建议您为此目的使用yii2管理扩展(https://github.com/mdmsoft/yii2-admin),这将解决您的问题,并且是管理用户角色的最佳扩展。使用此链接以更好地理解(https://github.com/mdmsoft/yii2-admin/blob/master/docs/guide/configuration.md)
yii migrate --migrationPath=@yii/rbac/migrations'components' => [], 'as access' => [ 'class' => 'mdm\admin\components\AccessControl', 'allowActions' => [ 'site/login', // add or remove allowed actions to this list 'site/logout', 'site/error', 'site/index', ] ]问题2:奖金问题:你认为这个策略是错误的吗?如果是的话,你会有什么建议?
我认为您的方法是不可扩展的,我建议您创建一个主数据库,并将其用于您的应用程序租户及其数据库。
'db' => [ 'class' => 'yii\db\Connection', 'dsn' => 'mysql:host=127.0.0.1;dbname=master-db', 'username' => 'root', 'password' => 'root', 'charset' => 'utf8', ]//设置成功登录页面或上的会话值、读取用户域并从主数据库获取租户信息并添加到会话中。
``
$tenant = Tenant::findOne(Yii::$app->request->post('tenant_id'));
Yii::$app->session->set('DB_HOST', $tenant->DB_host);
Yii::$app->session->set('DB_USER', $tenant->DB_username);
Yii::$app->session->set('DB_PASS', $tenant->DB_password);
Yii::$app->session->set('DB_NAME', $tenant->DB_name);
``public static function getDb(){ if ( Yii::$app->session->get('DB_HOST') ){ $host = Yii::$app->session->get('DB_HOST'); $dbName = Yii::$app->session->get('DB_NAME'); $dsn = "mysql:host=$host;dbname=$dbName"; Yii::$app->db->dsn = $dsn; Yii::$app->db->username = Yii::$app->session->get('DB_USER'); Yii::$app->db->password = Yii::$app->session->get('DB_PASS'); return Yii::$app->db; } }
我相信这些信息对你有帮助。
干杯!
发布于 2016-12-22 16:20:06
这是关于数据库管理器的文档。
如果您想从不同的数据库获取rbac信息,这应该是可行的。
在您的配置文件夹中,创建一个名为rbacdb.php的文件。增加以下内容:
<?php
return [
'class' => 'yii\db\Connection',
'dsn' => 'mysql:host=<db host or ip>;dbname=<dbname>',
'username' => '<dbuser>',
'password' => '<dbPassword>',
'charset' => 'utf8',
];然后转到您的配置文件,并找到authmanger部分。它应该是这样的:
'authManager' => [
'class' => 'yii\rbac\DbManager',
'db'=> require(__DIR__ . '/rbacdb.php'),
'assignmentTable'=>'<tableName>',
'itemChildTable'=>'<tableName>',
'itemTable'=>'<tableName>',
'ruleTable'=>'<tableName>'
]编辑:重新阅读post...each之后,用户不需要自己的rbac表/模式。使用Yii现有的系统。
https://stackoverflow.com/questions/41285880
复制相似问题