Yii2构建的多租户SaaS

4
我是在使用基于高级模板构建的多租户软件(SaaS)中工作,但是我没有获得关于租户数据库连接的期望结果。
我正在尝试在前端的配置文件中设置数据库连接如下:
$defaultAdminDB = [
  'class' => 'yii\db\Connection',
  'dsn' => 'pgsql:host=localhost;dbname=untitled',
  'username' => 'postgres',
  'password' => 'myPass',
  'charset' => 'utf8',
];

$config = [
  'components' => [
    'db' => function(){
      if (Yii::$app->session->get('login', false)){
        return [
          'class' => 'yii\db\Connection',
          'dsn' => Yii::$app->session->get('client_connection.dns'),
          'username' => Yii::$app->session->get('client_connection.username'),
          'password' => Yii::$app->session->get('client_connection.password'),
          'charset' => 'utf8',
        ];
      }

      return [
        'class' => 'yii\db\Connection',
        'dsn' => 'pgsql:host=localhost;dbname=untitled',
        'username' => 'postgres',
        'password' => 'myPass',
        'charset' => 'utf8',
      ];
    },
    'dbAdmin' => $defaultAdminDB
  ]
];

我有一个两步登录的流程,第一步需要输入登录名(租户ID),第二步需要提供用户名和密码。在第一个控制器中,我使用以下代码:

$account = \frontend\models\AdminAccounts::findOne(['login'=>$this->login]);

if (!$account){
  $this->addError('login', Yii::t('app', 'Account data not found.'));
  return false;
}

$dns = sprintf('pgsql:host=%s;dbname=%s', $account->getAttribute('db_host'), $account->getAttribute('db'));

Yii::$app->session->set('login', $this->login);
Yii::$app->session->set('client_connection.dns', $dns);
Yii::$app->session->set('client_connection.username', $account->getAttribute('db_user'));
Yii::$app->session->set('client_connection.password', $account->getAttribute('db_pass'));

我成功地获取了账户(租户)数据并将其存储在会话中,但我想我的错误在于在模型的 getDb() 方法中实例化 yii\db\Connection

希望能帮到我。 谢谢!

2个回答

0

你可以尝试

Yii::$app->db = new \yii\db\Connection([
'dsn' => Yii::$app->session->get('client_connection.dsn'),
'username' => Yii::$app->session->get('client_connection.username'),
'password' => Yii::$app->session->get('client_connection.password'),
]);

你能解释一下你做了什么以及为什么它回答了这个问题吗? - depperm

0
如果您正在更改现有数据库连接的数据库连接信息,则应关闭现有连接(Yii::$app->db->close()),更改连接信息,然后打开新连接(Yii::$app->db->open())。

网页内容由stack overflow 提供, 点击上面的
可以查看英文原文,
原文链接