## 創建命令
命令就是一個命令行程序,`Command` 類似于 HTTP 應用的 `Controller` 控制器,負責業務邏輯,不同的是命令行程序通常是處理復雜的數據處理邏輯,相比簡單的 `CRUD` 操作要復雜很多。
>[info] 初始代碼中命令行應用的命令在 `src/Commands` 目錄。
## 一個簡單的命令
首先在配置文件 `config/main.php` 中增加命令。
~~~
// 命令
'commands' => [
'hl' => [
'Hello',
'description' => "Demo.",
'options' => [
[['n', 'name'], 'description' => 'Your name.'],
['say', 'description' => "\tSay ..."],
],
],
],
~~~
詳解命令規則:
- 命令名稱: `hl`
- 命令類的類名,不包括 Command 后綴:`Hello`
- `description` 命令的描述,命令 `-h` 時顯示,(可不定義)
- `options` 命令的參數,參數 `-h` 時顯示,(可不定義)
- `['n', 'name']`、`'say'` 命令參數的名稱,可為字符或數組,**所有參數都必須在這里注冊方可使用**。
- `options.description` 參數的描述,參數 `COMMAND -h` 時顯示,(可不定義)
創建命令類,代碼如下:
~~~
<?php
namespace Console\Commands;
use Mix\Console\CommandLine\Flag;
/**
* Class HelloCommand
* @package Console\Commands
* @author liu,jian <coder.keda@gmail.com>
*/
class HelloCommand
{
/**
* 主函數
*/
public function main()
{
$name = Flag::string(['n', 'name'], 'Xiao Ming');
$say = Flag::string('say', 'Hello, World!');
println("{$name}: {$say}");
}
}
~~~
## 命名空間與文件位置的關系
控制器定義的命名空間為:
~~~
namespace Console\Commands;
~~~
因為根命名空間 `http://applications/console/src/` 在 `composer.json` 內定義的路徑為 :
~~~
"psr-4": {
"Console\\": "applications/console/src/",
},
~~~
所以控制器的完整路徑為:
~~~
applications/console/src/Commands/HelloCommand.php
~~~
## 命令行執行
執行上面寫的命令。
~~~shell
// 不帶參數
php mix-console hl
// 帶參數
php mix-console hl -n "Xiao Hua" --say=Hi
~~~
- 歡迎使用 MixPHP
- 安裝說明
- 全量安裝
- Phar 命令行
- 入門須知
- 增改應用
- 命名空間
- 自動加載
- 入口文件
- 配置文件
- 服務開發
- 核心基礎
- Bean
- Component
- Application
- 命令行
- 簡介
- 命令行開發常識
- 命令行開發
- 創建命令
- 命令參數
- 打印與顏色
- 控制臺程序
- 守護程序
- HTTP 服務
- 簡介
- 服務器
- 路由
- 請求
- 響應
- 控制器
- 視圖
- Auth
- Session
- 文件上傳
- 其他組件
- 分頁
- 驗證碼
- 圖片處理
- 客戶端
- GuzzleHttp
- 雜項
- Apache/PHP-FPM部署
- 調試與錯誤
- 安全建議
- WebSocket 服務
- 簡介
- 服務器
- 注冊器
- 連接
- 客戶端
- 測試
- 雜項
- nginx代理
- 60s無消息斷線
- TCP 服務
- 簡介
- 服務器
- 客戶端
- 測試
- UDP 服務
- 簡介
- 服務器
- 客戶端
- 測試
- 協程
- 簡介
- 開啟協程
- PHP Stream Hook
- xgo + Channel
- WaitGroup + xdefer
- 連接池
- 協程池
- 定時器
- 公共組件
- 中間件
- 驗證器
- 驗證器定義
- 驗證規則
- 靜態調用
- 模型
- 日志
- 緩存
- 數據庫
- Database
- QueryBuilder
- PDOConnection
- Persistent\PDOConnection
- Coroutine\PDOConnection
- MasterSlave\PDOConnection
- ExecuteListener
- Redis
- RedisConnection
- Persistent\RedisConnection
- Coroutine\RedisConnection
- ExecuteListener
- 常見問題
- 同一臺服務器部署多個服務
- 連接多個數據庫
- 如何設置跨域
- form-data 上傳文件失敗
- 開發工具
- 版本更新
- 不兼容改動
- 升級指南
- 文檔歷史