牛骨文教育服务平台(让学习变的简单)
博文笔记

yii cli模式 杂记

创建时间:2017-06-23 投稿人: 浏览次数:458

按照网络上一般的套路,就是在网站根目录下,新建一个php文件,例如index_cli.php,内容如下:

<?php
$yiic=dirname(__FILE__)."/../yii/framework/yiic.php";
$config=dirname(__FILE__)."/protected/config/console.php";

// remove the following line when in production mode
defined("YII_DEBUG") or define("YII_DEBUG",true);

require_once($yiic);
Yii::createConsoleApplication($config)->run();

config目录下的console.php或者main.php都是可以。关键的参数配置正确就可以,例如数据库连接。

然后,在protected/commands下建立一个类文件,例如TestCommand.php,内容如下:

<?php

class TestCommand extends CConsoleCommand
{
    public function actionIndex(){
        $DbConnection = Yii::app()->db;
        $sqlstr = "select * from test";
        $command = $DbConnection->createCommand($sqlstr);
        $viewdata = $command->queryAll();

        foreach ($viewdata as $key => $val){
            echo $val["leftmoney"];
        }
    }
}

然后,在命令行运行:

php index_cli.php test index

就可以看到sql语句的内容。

但发现踩了几个坑。

第一坑:
PHP Warning: PHP Startup: Invalid library (maybe not a PHP library) ‘mbstring.so’ in Unknown on line 0

这个是由于php编译时修改了php.ini导致,最后修改php.ini,把extension=mbstring.so屏蔽,即在最前面加;,然后重启php-fpm,如果用apache的,直接重启apache。就可以解决问题。(编译了新的 php模块进来后,不一定要增加extension的配置)

第二坑:
发现网上很多介绍在入口文件要加入:

Yii::createConsoleApplication($config)->run();

但发现加了后反而会出现

Yii application can only be created once.

的错误,去除后却能正常运行。

所以,最终修改成index_cli.php,内容如下:

<?php
$yiic=dirname(__FILE__)."/../yii/framework/yiic.php";
$config=dirname(__FILE__)."/protected/config/console.php";

// remove the following line when in production mode
defined("YII_DEBUG") or define("YII_DEBUG",true);

require_once($yiic);

command下的文件不变,然后在命令行运行:

php index_cli.php test index

index_cli.php为入口文件,test是protected/command文件夹下的类名,index是test类下的action方法。

声明:该文观点仅代表作者本人,牛骨文系教育信息发布平台,牛骨文仅提供信息存储空间服务。