# 控制台命令
除了用于构建 Web 应用程序的丰富功能,Yii 中也有一个拥有丰富功能的控制台,它们主要用于创建网站后台处理的任务。
控制台应用程序的结构非常类似于 Yii 的一个 Web 应用程序。它由一个或多个 yii\console\Controller 类组成,它们在控制台环境下通常被称为“命令”。每个控制器还可以有一个或多个动作,就像 web 控制器。
两个项目模板(基础模版和高级模版)都有自己的控制台应用程序。你可以通过运行 `yii` 脚本,在位于仓库的基本目录中运行它。 当你不带任何参数来运行它时,会给你一些可用的命令列表:
![](https://box.kancloud.cn/2015-10-10_56189328b5e63.png)
正如你在截图中看到,Yii 中已经定义了一组默认情况下可用的命令:
* yii\console\controllers\AssetController - 允许合并和压缩你的 JavaScript 和 CSS 文件。在 [资源 - 使用 asset 命令](http://www.yiichina.com/doc/guide/2.0/structure-assets#using-the-asset-command) 一节可获取更多信息。
* yii\console\controllers\CacheController - 清除应用程序缓存。
* yii\console\controllers\FixtureController - 管理用于单元测试 fixture 的加载和卸载。 这个命令的更多细节在 [Testing Section about Fixtures](http://www.yiichina.com/doc/guide/2.0/test-fixtures#managing-fixtures).
* yii\console\controllers\HelpController - 提供有关控制台命令的帮助信息,这是默认的命令并会打印上面截图所示的输出。
* yii\console\controllers\MessageController - 从源文件提取翻译信息。 要了解更多关于这个命令的用法,请参阅 [I18N 章节](http://www.yiichina.com/doc/guide/2.0/tutorial-i18n#message-command).
* yii\console\controllers\MigrateController - 管理应用程序数据库迁移。 在 [数据库迁移章节](http://www.yiichina.com/doc/guide/2.0/db-migrations) 可获取更多信息。
## 用法
你可以使用以下语法来执行控制台控制器操作:
~~~
yii <route> [--option1=value1 --option2=value2 ... argument1 argument2 ...]
~~~
以上,`<route>` 指的是控制器动作的路由。选项将填充类属性,参数是动作方法的参数。
例如,将 yii\console\controllers\MigrateController::actionUp() 限制 5 个数据库迁移并将 yii\console\controllers\MigrateController::$migrationTable 设置为 `migrations` 应该这样调用:
~~~
yii migrate/up 5 --migrationTable=migrations
~~~
> **注意**: 当在控制台使用 `*` 时, 不要忘记像 `"*"` 一样用引号来引起来,为了防止在 shell 中执行命令时被当成当前目录下的所有文件名。
## 入口脚本
控制台应用程序的入口脚本相当于用于 Web 应用程序的 `index.php` 入口文件。 控制台入口脚本通常被称为 `yii`,位于应用程序的根目录。它包含了类似下面的代码:
~~~
#!/usr/bin/env php
<?php
/**
* Yii console bootstrap file.
*/
defined('YII_DEBUG') or define('YII_DEBUG', true);
require(__DIR__ . '/vendor/autoload.php');
require(__DIR__ . '/vendor/yiisoft/yii2/Yii.php');
$config = require(__DIR__ . '/config/console.php');
$application = new yii\console\Application($config);
$exitCode = $application->run();
exit($exitCode);
~~~
该脚本将被创建为你应用程序中的一部分;你可以根据你的需求来修改它。如果你不需要记录错误信息或者希望提高整体性能,`YII_DEBUG` 常数应定义为 `false`。 在基本的和高级的两个应用程序模板中,控制台应用程序的入口脚本在默认情况下会启用调试模式,以提供给开发者更好的环境。
## 配置
在上面的代码中可以看到,控制台应用程序使用它自己的配置文件,名为 `console.php` 。在该文件里你可以给控制台配置各种 [应用组件](http://www.yiichina.com/doc/guide/2.0/structure-application-components) 和属性。
如果你的 web 应用程序和控制台应用程序共享大量的配置参数和值,你可以考虑把这些值放在一个单独的文件中,该文件中包括( web 和控制台)应用程序配置。 你可以在“高级”项目模板中看到一个例子。
> 提示:有时,你可能需要使用一个与在入口脚本中指定的应用程序配置不同的控制台命令。例如,你可能想使用 `yii migrate`命令来升级你的测试数据库,它被配置在每个测试套件。要动态地更改配置,只需指定一个自定义应用程序的配置文件,通过`appconfig`选项来执行命令:
>
> ~~~
> yii <route> --appconfig=path/to/config.php ...
> ~~~
## 创建你自己的控制台命令
### 控制台的控制器和行为
一个控制台命令继承自 yii\console\Controller 控制器类。 在控制器类中,定义一个或多个与控制器的子命令相对应的动作。在每一个动作中,编写你的代码实现特定的子命令的适当的任务。
当你运行一个命令时,你需要指定一个控制器的路由。例如,路由 `migrate/create` 调用子命令对应的yii\console\controllers\MigrateController::actionCreate() 动作方法。 如果在执行过程中提供的路由不包含路由 ID ,将执行默认操作(如 web 控制器)。
### 选项
通过覆盖在 yii\console\Controller::options() 中的方法,你可以指定可用于控制台命令(controller/actionID)选项。这个方法应该返回控制器类的公共属性的列表。 当运行一个命令,你可以指定使用语法 `--OptionName=OptionValue` 选项的值。 这将分配`OptionValue` 到控制器类的 `OptionName` 属性。
If the default value of an option is of an array type and you set this option while running the command, the option value will be converted into an array by splitting the input string on any commas.
### 参数
除了选项,命令还可以接收参数。参数将传递给请求的子命令对应的操作方法。第一个参数对应第一个参数,第二个参数对应第二个参数,依次类推。 命令被调用时,如果没有足够的参数,如果有定义默认值的情况下,则相应的参数将采取默认声明的值;如果没有设置默认值,并且在运行时没有提供任何值,该命令将以一个错误退出。
你可以使用 `array` 类型提示来指示一个参数应该被视为一个数组。该数组通过拆分输入字符串的逗号来生成。
下面的示例演示如何声明参数:
~~~
class ExampleController extends \yii\console\Controller
{
// 命令 "yii example/create test" 会调用 "actionCreate('test')"
public function actionCreate($name) { ... }
// 命令 "yii example/index city" 会调用 "actionIndex('city', 'name')"
// 命令 "yii example/index city id" 会调用 "actionIndex('city', 'id')"
public function actionIndex($category, $order = 'name') { ... }
// 命令 "yii example/add test" 会调用 "actionAdd(['test'])"
// 命令 "yii example/add test1,test2" 会调用 "actionAdd(['test1', 'test2'])"
public function actionAdd(array $name) { ... }
}
~~~
### 退出代码
使用退出代码是控制台应用程序开发的最佳做法。通常,执行成功的命令会返回 `0`。如果命令返回一个非零数字,会认为出现错误。 该返回的数字作为出错代码,用以了解错误的详细信息。例如 `1` 可能代表一个未知的错误,所有的代码都将保留在特定的情况下:输入错误,丢失的文件等等。
要让控制台命令返回一个退出代码,只需在控制器操作方法中返回一个整数:
~~~
public function actionIndex()
{
if (/* some problem */) {
echo "A problem occured!\n";
return 1;
}
// do something
return 0;
}
~~~
你可以使用一些预定义的常数:
* `Controller::EXIT_CODE_NORMAL` 值为 `0`;
* `Controller::EXIT_CODE_ERROR` 值为 `1`.
为控制器定义有意义的常量,以防有更多的错误代码类型,这会是一个很好的实践。
### 格式和颜色
Yii 支持格式化输出,如果终端运行命令不支持的话则会自动退化为非格式化输出。
要输出格式的字符串很简单。以下展示了如何输出一些加粗的文字:
~~~
$this->stdout("Hello?\n", Console::BOLD);
~~~
如果你需要建立字符串动态结合的多种样式,最好使用 `ansiFormat` :
~~~
$name = $this->ansiFormat('Alex', Console::FG_YELLOW);
echo "Hello, my name is $name.";
~~~
- 介绍(Introduction)
- 关于 Yii(About Yii)
- 从 Yii 1.1 升级(Upgrading from Version 1.1)
- 入门(Getting Started)
- 安装 Yii(Installing Yii)
- 运行应用(Running Applications)
- 第一次问候(Saying Hello)
- 使用 Forms(Working with Forms)
- 玩转 Databases(Working with Databases)
- 用 Gii 生成代码(Generating Code with Gii)
- 更上一层楼(Looking Ahead)
- 应用结构(Application Structure)
- 结构概述(Overview)
- 入口脚本(Entry Scripts)
- 应用(Applications)
- 应用组件(Application Components)
- 控制器(Controllers)
- 模型(Models)
- 视图(Views)
- 模块(Modules)
- 过滤器(Filters)
- 小部件(Widgets)
- 前端资源(Assets)
- 扩展(Extensions)
- 请求处理(Handling Requests)
- 运行概述(Overview)
- 引导(Bootstrapping)
- 路由引导与创建 URL(Routing and URL Creation)
- 请求(Requests)
- 响应(Responses)
- Sessions and Cookies
- 错误处理(Handling Errors)
- 日志(Logging)
- 关键概念(Key Concepts)
- 组件(Components)
- 属性(Properties)
- 事件(Events)
- 行为(Behaviors)
- 配置(Configurations)
- 别名(Aliases)
- 类自动加载(Class Autoloading)
- 服务定位器(Service Locator)
- 依赖注入容器(Dependency Injection Container)
- 配合数据库工作(Working with Databases)
- 数据库访问(Data Access Objects): 数据库连接、基本查询、事务和模式操作
- 查询生成器(Query Builder): 使用简单抽象层查询数据库
- 活动记录(Active Record): 活动记录对象关系映射(ORM),检索和操作记录、定义关联关系
- 数据库迁移(Migrations): 在团体开发中对你的数据库使用版本控制
- Sphinx
- Redis
- MongoDB
- ElasticSearch
- 接收用户数据(Getting Data from Users)
- 创建表单(Creating Forms)
- 输入验证(Validating Input)
- 文件上传(Uploading Files)
- 收集列表输入(Collecting Tabular Input)
- 多模型同时输入(Getting Data for Multiple Models)
- 显示数据(Displaying Data)
- 格式化输出数据(Data Formatting)
- 分页(Pagination)
- 排序(Sorting)
- 数据提供器(Data Providers)
- 数据小部件(Data Widgets)
- 操作客户端脚本(Working with Client Scripts)
- 主题(Theming)
- 安全(Security)
- 认证(Authentication)
- 授权(Authorization)
- 处理密码(Working with Passwords)
- 客户端认证(Auth Clients)
- 安全领域的最佳实践(Best Practices)
- 缓存(Caching)
- 概述(Overview)
- 数据缓存(Data Caching)
- 片段缓存(Fragment Caching)
- 分页缓存(Page Caching)
- HTTP 缓存(HTTP Caching)
- RESTful Web 服务
- 快速入门(Quick Start)
- 资源(Resources)
- 控制器(Controllers)
- 路由(Routing)
- 格式化响应(Response Formatting)
- 授权验证(Authentication)
- 速率限制(Rate Limiting)
- 版本化(Versioning)
- 错误处理(Error Handling)
- 开发工具(Development Tools)
- 调试工具栏和调试器(Debug Toolbar and Debugger)
- 使用 Gii 生成代码(Generating Code using Gii)
- TBD 生成 API 文档(Generating API Documentation)
- 测试(Testing)
- 概述(Overview)
- 搭建测试环境(Testing environment setup)
- 单元测试(Unit Tests)
- 功能测试(Functional Tests)
- 验收测试(Acceptance Tests)
- 测试夹具(Fixtures)
- 高级专题(Special Topics)
- 高级应用模版(Advanced Project Template)
- 从头构建自定义模版(Building Application from Scratch)
- 控制台命令(Console Commands)
- 核心验证器(Core Validators)
- 国际化(Internationalization)
- 收发邮件(Mailing)
- 性能优化(Performance Tuning)
- 共享主机环境(Shared Hosting Environment)
- 模板引擎(Template Engines)
- 集成第三方代码(Working with Third-Party Code)
- 小部件(Widgets)
- Bootstrap 小部件(Bootstrap Widgets)
- jQuery UI 小部件(jQuery UI Widgets)
- 助手类(Helpers)
- 助手一览(Overview)
- Array 助手(ArrayHelper)
- Html 助手(Html)
- Url 助手(Url)