插件模型中的 CakePHP 3 defaultConnectionName 不起作用
CakePHP 3 defaultConnectionName in plugin model doesn't work
我创建了一个基于框架 cakephp 的门户网站 php 3 和管理面板作为插件将文件与其他文件分开。 tables,它将仅覆盖我放入单独创建的数据库 'admin'.
中的管理面板
我在 config/app.php.
中正确配置了数据库连接
'Datasources' => [
'default' => [
'className' => 'Cake\Database\Connection',
'driver' => 'Cake\Database\Driver\Mysql',
'persistent' => false,
'host' => 'localhost',
'username' => 'user',
'password' => 'password',
'database' => 'portal',
'encoding' => 'utf8',
'timezone' => 'UTC',
'cacheMetadata' => true,
'log' => false,
],
'admin' => [
'className' => 'Cake\Database\Connection',
'driver' => 'Cake\Database\Driver\Mysql',
'persistent' => false,
'host' => 'localhost',
'username' => 'user',
'password' => 'password',
'database' => 'admin_portal',
'encoding' => 'utf8',
'timezone' => 'UTC',
'cacheMetadata' => true,
'quoteIdentifiers' => false,
'log' => false,
],
],
所以我有插件 Admin。
我在插件 2 控制器中创建了:
plugins/Admin/src/Controller/AdminController.php
<?php
namespace Admin\Controller;
use Cake\Controller\Controller;
use Cake\ORM\TableRegistry;
class AdminController extends Controller {
public function initialize() {
parent::initialize();
$this->loadComponent('RequestHandler');
$this->loadComponent('Flash');
}
}
plugins/Admin/src/Controller/MainController.php
<?php
namespace Admin\Controller;
use Admin\Controller\AdminController;
class MainController extends AdminController {
public function dashboard() {
$this->loadModel('Messages');
$results = $this->Messages->find('all');
pr($results);
}
}
并且我为 table 消息创建了模型
<?php
namespace Admin\Model\Table;
use Admin\Model\Entity\Message;
use Cake\ORM\Query;
use Cake\ORM\RulesChecker;
use Cake\ORM\Table;
use Cake\Validation\Validator;
class MessagesTable extends Table {
public function initialize(array $config)
{
parent::initialize($config);
$this->table('messages');
$this->displayField('name');
$this->primaryKey('id');
}
public static function defaultConnectionName()
{
return 'admin';
}
}
当我从 MainController 触发仪表板操作而不是消息结果时 table 我收到错误:
SQLSTATE[42S02]: Base table or view not found: 1146 Table 'portal.messages' doesn't exist
所以 CakePHP 正在默认数据库中而不是 "admin_portal" table.
中查找 table 消息
我做错了什么?蛋糕以某种方式不遵守插件模型中的 defaultConnectionName() 方法。
我尝试在 /src 中的某些模型中使用此方法(而不是在插件中)- 然后它工作正常。
你实际上没有使用你的插件模型,你的
$this->loadModel('Messages');
调用将(尝试)加载应用程序级别 Messages
模型。如果要加载插件模型,请使用 plugin/dot 符号语法,即
$this->loadModel('Admin.Messages');
我创建了一个基于框架 cakephp 的门户网站 php 3 和管理面板作为插件将文件与其他文件分开。 tables,它将仅覆盖我放入单独创建的数据库 'admin'.
中的管理面板我在 config/app.php.
中正确配置了数据库连接'Datasources' => [
'default' => [
'className' => 'Cake\Database\Connection',
'driver' => 'Cake\Database\Driver\Mysql',
'persistent' => false,
'host' => 'localhost',
'username' => 'user',
'password' => 'password',
'database' => 'portal',
'encoding' => 'utf8',
'timezone' => 'UTC',
'cacheMetadata' => true,
'log' => false,
],
'admin' => [
'className' => 'Cake\Database\Connection',
'driver' => 'Cake\Database\Driver\Mysql',
'persistent' => false,
'host' => 'localhost',
'username' => 'user',
'password' => 'password',
'database' => 'admin_portal',
'encoding' => 'utf8',
'timezone' => 'UTC',
'cacheMetadata' => true,
'quoteIdentifiers' => false,
'log' => false,
],
],
所以我有插件 Admin。
我在插件 2 控制器中创建了:
plugins/Admin/src/Controller/AdminController.php
<?php
namespace Admin\Controller;
use Cake\Controller\Controller;
use Cake\ORM\TableRegistry;
class AdminController extends Controller {
public function initialize() {
parent::initialize();
$this->loadComponent('RequestHandler');
$this->loadComponent('Flash');
}
}
plugins/Admin/src/Controller/MainController.php
<?php
namespace Admin\Controller;
use Admin\Controller\AdminController;
class MainController extends AdminController {
public function dashboard() {
$this->loadModel('Messages');
$results = $this->Messages->find('all');
pr($results);
}
}
并且我为 table 消息创建了模型
<?php
namespace Admin\Model\Table;
use Admin\Model\Entity\Message;
use Cake\ORM\Query;
use Cake\ORM\RulesChecker;
use Cake\ORM\Table;
use Cake\Validation\Validator;
class MessagesTable extends Table {
public function initialize(array $config)
{
parent::initialize($config);
$this->table('messages');
$this->displayField('name');
$this->primaryKey('id');
}
public static function defaultConnectionName()
{
return 'admin';
}
}
当我从 MainController 触发仪表板操作而不是消息结果时 table 我收到错误:
SQLSTATE[42S02]: Base table or view not found: 1146 Table 'portal.messages' doesn't exist
所以 CakePHP 正在默认数据库中而不是 "admin_portal" table.
中查找 table 消息我做错了什么?蛋糕以某种方式不遵守插件模型中的 defaultConnectionName() 方法。 我尝试在 /src 中的某些模型中使用此方法(而不是在插件中)- 然后它工作正常。
你实际上没有使用你的插件模型,你的
$this->loadModel('Messages');
调用将(尝试)加载应用程序级别 Messages
模型。如果要加载插件模型,请使用 plugin/dot 符号语法,即
$this->loadModel('Admin.Messages');