目錄
1. 概覽
2. 創建命令
3. 控制台命令動作(action)
4. 退出代码
5. 自定义控制台应用
首頁 後端開發 php教程 Yii框架官方指南系列50—專題:控制台應用

Yii框架官方指南系列50—專題:控制台應用

Feb 16, 2017 am 09:53 AM



控制台應用主要用於實現在線Web應用所需的離線操作,例如代碼生成, 搜索索引編譯, 郵件發送等等. Yii框架以面向對象的方式提供了一個編寫控制台應用的框架. 它允許控制台應用存取線上網路應用程式所使用的資源(例如資料庫連線資訊) .

1. 概覽

Yii可以以命令列的方式運行每一個控制台任務,控制台命令是一個繼承自CConsoleCommand的類別。

當我們使用 yiic webapp 工具建立一個初始化的Yii應用骨架的時候, 我們可以在protected資料夾下看到如下兩個檔案:

  • yiic: 這是一個運行在Linux/Unix上的可執行腳本;

  • yiic.bat: 這是一個運行在Windows上的可執行批次腳本.

在控制台視窗中, 我們可以輸入如下命令:

cd protected
yiic help
登入後複製

這將會顯示一系列的控制台命令。預設情況下,這些有效的命令包括由Yii框架提供的(系統命令)和開發者自己為獨立應用程式編寫的(使用者命令)。

Yii框架官方指南系列50—專題:控制台應用

如果想要查看如何使用一個命令, 可以使用:

yiic help <command-name></command-name>
登入後複製

要執行一個命令, 可以使用如下的命令格式:

yiic <command-name> [parameters...]</command-name>
登入後複製

2. 創建命令

命令命令以類文件的控制台命令形如CConsoleApplication::command的路徑下. 預設情況下, 指向資料夾protected/commands.

一個控制台命令類別必須繼承自CConsoleCommand. 這個類別名稱必須是XyzCommand的格式, 其中 Xyz 名稱. 例如, 一個sitemap 指令必須使用類別名稱 SitemapCommand。控制台命令名稱是大小寫敏感的.

Tip: 透過設定CConsoleApplication::command匹配, 可以取得以不同形式命名、儲存在不同資料夾下的命令類別.

為了創建一個新的指令,需要經常重寫CConsoleCommand::run() 或發展一個或多個指令動作。

當執行一個控制台指令時,CConsoleCommand::run()方法將會被控制台套用呼叫。所有控制台參數也會以下列方法片段的形式傳入此方法:


public function run($args) { ... }
登入後複製

其中 $args 代表命令列給定的額外參數。

在控制台命令中, 我們可以使用 Yii::app()來訪問控制台應用實例, 不僅如此我們還可以訪問資源如數據庫連接(e.g. Yii::app()->db). 可以看到這種用法和在網路應用中的使用非常類似。

Info: 從版本1.1.1開始, 我們也可以建立被同一台機子上所有的Yii應用共享的全域指令:定義一個命名為YII_CONSOLE_COMMANDS的環境變數指向一個已存在的資料夾,然後將一個命名為YII_CONSOLE_COMMANDS的環境變數指向一個已存在的資料夾,然後將一個已存在的資料夾我們的全域命令類別放到這個資料夾下即可。

3. 控制台命令動作(action)

Note: 這個控制台命令動作特性從版本1.1.5後有效。

一個控制台命令經常需要處理不同的命令列參數, 有些是必須的,有些是可選的. 控制台命令還需要提供一些子命令來處理不同的子任務。這些工作可以簡化使用控制台命令動作。

一個控制台命令動作是一個控制台命令類別中的方法. 這個方法名稱必須是actionXyz的格式, 其中Xyz 代表首字母大寫的動作名稱. 例如, 一個actionIndex方法定義了一個命名為index的動作.

想要執行特定的動作, 我們可以使用如下的命令行格式:

yiic <command-name> <action-name> --option1=value1 --option2=value2 ...</action-name></command-name>
登入後複製

額外的option-value 對將為以命名參數的方式傳入動作方法中. 一個xyz 操作的值將會以$xyz參數的形式傳入到動作方法中。例如, 如果我們定義瞭如下的命令類:


class SitemapCommand extends CConsoleCommand
{
    public function actionIndex($type, $limit=5) { ... }
    public function actionInit() { ... }
}
登入後複製

然後,下面的控制台命令在調用actionIndex('News', 5)的時候都會有結果:

yiic sitemap index --type=News --limit=5

// $limit takes default value
yiic sitemap index --type=News

// $limit takes default value
// because 'index' is a default action, we can omit the action name
yiic sitemap --type=News

// the order of options does not matter
yiic sitemap index --limit=5 --type=News
登入後複製

沒有指定值(e.g. --type instead of --type=News), 對應的動作參數值將會假定為true。

Note: 不支援選購的參數格式 --type News, -t News.

一個參數值可以是陣列(必須要有陣列型態提示):

在命令列參數中想要使用數組值, 只需簡單重複同一個選項:

public function actionIndex(array $types) { ... }
登入後複製

上面的命令最終將會調用actionIndex(array('News', 'Article')).

從版本1.1. 6開始, Yii 也支援使用匿名動作參數和全域選項.

匿名参数表示这些命令行参数不是以选项的形式呈现. 例如, 在命令 yiic sitemap index --limit=5 News中, 我们有一个值为News的匿名参数和命名参数 limit,其值为5。

为了使用匿名参数, 一个命令动作必须声明参数为 $args的形式. 例如,


public function actionIndex($limit=10, $args=array()) {...}
登入後複製

$args数组将会装入所有的匿名参数值.

全局选项代表那些命令行选项可以被一个命令中所有动作共享的选项. 例如, 在一个命令中提供了多个选项, 我们可能想要每一个动作识别一个名为verbose的动作. 当然我们可以在每一个动作方法中声明 $verbose 参数, 一个更好的方式是将其声明为这个命令类的公有成员变量, 将 verbose 转换为全局参数:


class SitemapCommand extends CConsoleCommand
{
    public $verbose=false;
    public function actionIndex($type) {...}
}
登入後複製

上面的代码允许我们执行一个带 verbose 选项的命令:

yiic sitemap index --verbose=1 --type=News
登入後複製

4. 退出代码

Note: 在控制台命令中退出代码的特性从版本 1.1.11起有效.

通过cronjob或者使用一个持续集成的服务器自动运行控制台命令的时候, 要么命令运行运行成功,要么命令运行失败. 这可以通过检查进程返回的退出代码来查看。

这些退出码是从0-254的整型值(this is the range in php world), 其中 0 表示退出成功其他的所有非0值表示出现了错误.

在一个动作方法或者控制台命令的 run() 方法中你可以在退出时返回整型值退出码 ,例如:


if (/* error */) {
    return 1; // exit with error code 1
}
// ... do something ...
return 0; // exit successfully
登入後複製

如果没有返回值, 应用将会退出返回 0.

5. 自定义控制台应用

默认情况下, 如果一个应用是使用yiic webapp工具创建的, 命令行应用的配置将会放在 protected/config/console.php文件中. 和一个Web应用配置文件一样, 这个文件是一个返回控制台应用实例的初始化配置值的数组的PHP脚本。所以CConsoleApplication的任何公有属性都可以在该文件中配置.

因为控制台命令经常被创建来服务于Web应用, 所以需要访问资源(如数据库连接)。我们可以在控制台配置文件中以如下方式来实现 :


return array(
    ......
    'components'=>array(
        'db'=>array(
            ......
        ),
    ),
);
登入後複製

正如我们所看到的那样, 配置的格式和我们在Web应用中的配置类似.这是因为CConsoleApplication和 CWebApplication 的基类相同。

 以上就是Yii框架官方指南系列50——专题:控制台应用的内容,更多相关内容请关注PHP中文网(www.php.cn)!


本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn

熱AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover

AI Clothes Remover

用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool

Undress AI Tool

免費脫衣圖片

Clothoff.io

Clothoff.io

AI脫衣器

Video Face Swap

Video Face Swap

使用我們完全免費的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱工具

記事本++7.3.1

記事本++7.3.1

好用且免費的程式碼編輯器

SublimeText3漢化版

SublimeText3漢化版

中文版,非常好用

禪工作室 13.0.1

禪工作室 13.0.1

強大的PHP整合開發環境

Dreamweaver CS6

Dreamweaver CS6

視覺化網頁開發工具

SublimeText3 Mac版

SublimeText3 Mac版

神級程式碼編輯軟體(SublimeText3)

Yii框架中的RESTful API開發 Yii框架中的RESTful API開發 Jun 21, 2023 pm 12:34 PM

Yii是一款基於PHP的高效能MVC框架,它提供了非常豐富的工具和功能,支援快速、有效率地開發Web應用程式。其中,Yii框架的RESTfulAPI功能得到了越來越多開發者的關注和喜愛,因為使用Yii框架可以非常方便地構建出高性能、易擴展的RESTful接口,為Web應用的開發提供了強有力的支持。 RESTfulAPI簡介RESTfulAPI是一種基於

Yii框架中間件:為應用程式提供多重資料儲存支持 Yii框架中間件:為應用程式提供多重資料儲存支持 Jul 28, 2023 pm 12:43 PM

Yii框架中間件:為應用程式提供多重資料儲存支援介紹中間件(middleware)是Yii框架中的重要概念,它為應用程式提供了多重資料儲存支援。中間件的作用類似於一個過濾器,它能夠在應用程式的請求和回應之間插入自訂程式碼。透過中間件,我們可以對請求進行處理、驗證、過濾,然後將處理後的結果傳遞給下一個中間件或最終的處理程序。 Yii框架中的中間件使用起來非常

PHP中如何使用Yii框架 PHP中如何使用Yii框架 Jun 27, 2023 pm 07:00 PM

隨著Web應用程式的快速發展,現代Web開發已成為一項重要技能。許多框架和工具可用於開發高效的Web應用程序,其中Yii框架就是一個非常流行的框架。 Yii是一個高效能、基於元件的PHP框架,它採用了最新的設計模式和技術,提供了強大的工具和元件,是建立複雜Web應用程式的理想選擇。在本文中,我們將討論如何使用Yii框架來建立Web應用程式。安裝Yii框架首先,

使用Yii框架實現網頁快取和頁面分塊的步驟 使用Yii框架實現網頁快取和頁面分塊的步驟 Jul 30, 2023 am 09:22 AM

使用Yii框架實現網頁快取和頁面分塊的步驟引言:在Web開發過程中,為了提升網站的效能和使用者體驗,常常需要對頁面進行快取和分塊處理。 Yii框架提供了強大的快取和佈局功能,可以幫助開發者快速實現網頁快取和頁面分塊,本文將介紹如何使用Yii框架進行網頁快取和頁面分塊的實作。一、網頁快取開啟網頁快取在Yii框架中,可以透過設定檔來開啟網頁快取。開啟主設定檔co

使用Yii框架創建遊戲攻略網站 使用Yii框架創建遊戲攻略網站 Jun 21, 2023 pm 01:45 PM

近年來,隨著遊戲產業的快速發展,越來越多的玩家開始尋找遊戲攻略來幫助遊戲過關。因此,創建遊戲攻略網站可以讓玩家更方便取得遊戲攻略,同時也能為玩家提供更好的遊戲體驗。在創建這樣一個網站時,我們可以使用Yii框架來進行開發。 Yii框架是一個基於PHP程式語言的Web應用開發框架。它具有高效、安全、擴展性強等特點,可以為我們更快速、高效地創建一個遊戲攻略

Yii框架中間件:為應用程式新增日誌記錄和偵錯功能 Yii框架中間件:為應用程式新增日誌記錄和偵錯功能 Jul 28, 2023 pm 08:49 PM

Yii框架中間件:為應用程式新增日誌記錄和偵錯功能【引言】在開發Web應用程式時,我們通常需要添加一些附加功能以提高應用程式的效能和穩定性。 Yii框架提供了中間件的概念,使我們能夠在應用程式處理請求之前和之後執行一些額外的任務。本文將介紹如何使用Yii框架的中間件功能來實作日誌記錄和除錯功能。 【什麼是中間件】中間件是指在應用程式處理請求之前和之後,對請求和回應做

在Yii框架中使用控制器(Controllers)處理Ajax請求的方法 在Yii框架中使用控制器(Controllers)處理Ajax請求的方法 Jul 28, 2023 pm 07:37 PM

在Yii框架中,控制器(Controllers)扮演著處理請求的重要角色。除了處理常規的頁面請求之外,控制器還可以用於處理Ajax請求。本文將介紹在Yii框架中處理Ajax請求的方法,並提供程式碼範例。在Yii框架中,處理Ajax請求可以透過以下步驟進行:第一步,建立一個控制器(Controller)類別。可以透過繼承Yii框架提供的基礎控制器類別yiiwebCo

Yii框架中的調試工具:分析和調試應用程式 Yii框架中的調試工具:分析和調試應用程式 Jun 21, 2023 pm 06:18 PM

在現代的Web應用程式開發中,調試工具是不可或缺的。它們可以幫助開發者找到和解決應用程式的各種問題。 Yii框架作為一款流行的Web應用程式框架,自然也提供了一些除錯工具。本文將重點介紹Yii框架中的調試工具,並討論它們如何幫助我們分析和調試應用程式。 GiiGii是Yii框架的程式碼產生器。它可以自動產生Yii應用程式的程式碼,如模型、控制器和視圖等。使用Gii,

See all articles