Yii - Как получить доступ к модели и вызвать действия в Yiic

У меня есть действие, которое печатает "Hello World":

public function actionStart()
{
    echo 'Hello World';
}

Я буду запускать задание cron, которое вызывает это действие каждую минуту.

Как я могу сделать это с YIC?


ОБНОВИТЬ:

Я создаю консольное приложение. У меня есть cron.php внутри index.php:

<?php
defined('YII_DEBUG') or define('YII_DEBUG',true);

// including Yii
require_once('framework/yii.php');

// we'll use a separate config file
$configFile='protected/config/c.php';

// creating and running console application
Yii::createConsoleApplication($configFile)->run();

и config/c.php:

<?php
return array(
    // This path may be different. You can probably get it from `config/main.php`.
    'basePath'=>dirname(__FILE__).DIRECTORY_SEPARATOR.'..',
    'name'=>'Cron',

    'preload'=>array('log'),

    'import'=>array(
        'application.models.*',
        'application.components.*',
    ),
    // We'll log cron messages to the separate files
    'components'=>array(
        'log'=>array(
            'class'=>'CLogRouter',
            'routes'=>array(
                array(
                    'class'=>'CFileLogRoute',
                    'logFile'=>'cron.log',
                    'levels'=>'error, warning',
                ),
                array(
                    'class'=>'CFileLogRoute',
                    'logFile'=>'cron_trace.log',
                    'levels'=>'trace',
                ),
            ),
        ),

        // Your DB connection
        'db'=>array(
            'class'=>'CDbConnection',
            // …
        ),
    ),
);

и защищены / команды /MyCommand.php:

<?php
class MyCommand extends CConsoleCommand
{
    public function run($args)
    {
        $logs = Log::model()->findAll();
        print_r($logs);
        die();
    }
}

когда я запускаю это:

$ ./protected/yiic my

Я получил эту ошибку:

PHP Error[2]: include(Log.php): failed to open stream: No such file or directory
    in file /path/to/app/folder/framework/YiiBase.php at line 427
#0 /path/to/app/folder/framework/YiiBase.php(427): autoload()
#1 unknown(0): autoload()
#2 /path/to/app/folder/protected/commands/MyCommand.php(6): spl_autoload_call()
#3 /path/to/app/folder/framework/console/CConsoleCommandRunner.php(71): MyCommand->run()
#4 /path/to/app/folder/framework/console/CConsoleApplication.php(92): CConsoleCommandRunner->run()
#5 /path/to/app/folder/framework/base/CApplication.php(180): CConsoleApplication->processRequest()
#6 /path/to/app/folder/framework/yiic.php(33): CConsoleApplication->run()
#7 /path/to/app/folder/protected/yiic.php(7): require_once()
#8 /path/to/app/folder/protected/yiic(3): require_once()

Как я могу это исправить?

4 ответа

Сначала вы должны создать команду: http://www.yiiframework.com/doc/guide/1.1/en/topics.console

Затем вы можете получить доступ к своей функции, выполнив следующую команду: yiic yourCommand start

Вы должны загрузить свои модели в консольном приложении.

открыто console.php файл конфигурации, и добавьте эту строку под строкой 'name'=>'My Console Application',

'import'=>array(
        'application.models.*'
    ),

Он должен работать.

Кажется, что у вас нет такого файла 'log.php', который вы включаете.

возможно попробуйте это из консоли:

touch /path/to/app/folder/protected/log.php

Тогда у вас должно появиться другое сообщение об ошибке (или оно будет работать гладко).

Просто откройте в нем свой путь проверки каркаса файла yiic.php.

Другие вопросы по тегам