插件模型中的CakePHP 3 defaultConnectionName不起作用

时间:2016-02-14 20:18:00

标签: php mysql cakephp cakephp-3.x

我基于框架cakephp 3和管理面板创建了一个门户网站,作为插件将文件与其余文件分开。这些表格仅包含我单独创建的数据库管理面板' 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,
        ],
    ],

所以我有插件管理员。

我创建了内部插件2控制器:

插件/管理/ SRC /控制器/ 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');
    }
}

插件/管理/ SRC /控制器/ 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);

    }

}

我为表消息

创建了模型
<?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触发仪表板操作而不是消息表的结果时,我收到错误:

SQLSTATE[42S02]: Base table or view not found: 1146 Table 'portal.messages' doesn't exist

所以CakePHP正在默认数据库中寻找表消息,而不是在&#34; admin_portal&#34;表

我做错了什么?不知何故,蛋糕并不尊重插件模型中的defaultConnectionName()方法。 我尝试在/ src中的某个模型中使用此方法(不在插件中) - 然后它正常工作。

1 个答案:

答案 0 :(得分:1)

您实际上没有使用插件模型,

$this->loadModel('Messages');

调用将(尝试)加载应用程序级Messages模型。如果要加载插件模型,请使用插件/点表示法语法,即

$this->loadModel('Admin.Messages');

另请参阅 Cookbook > Plugins > Plugin Models