5.1 命令行很适合编写一些自定义命令了,例如上节权限管理里面编写的发布文件的一些命令。你还可以编写脚本命令来实现业务上的一些东西。平常我们经常用到的一些 CURD 文件,所以为了后期方便的,这里快速就编写一个命令行,此后 curd 基础文件都使用该命令创建。
## 如何创建
首先要做一些基础工作,肯定需要的是一些 CURD 模板文件,然后在此基础利用命令行创建。
![](https://box.kancloud.cn/029f92f7be8f5719dcdeeaa4dd57aaf1_306x189.png)
依据文档需要在 application 创建 command目录,然后在创建一个命令文件 CurdMaker.php。然后还有 **stub** 目录, 这里存放的是模板文件,是之后创建 CURD 的基础。 Stub 三个文件如下, 具体根据自己的喜好定义。
### controller.stub
```
<?php
namespace app\$module\controller;
use think\Controller
class $controller extends Controller
{
public function index()
{
return $this->fetch();
}
public function create()
{
return $this->fetch();
}
public function edit()
{
return $this->fetch();
}
public function delete()
{}
}
```
### model.stub
```
<?php
namespace app\$module\model;
use think\Model;
class $model extends Model
{
public function getAll()
{}
public function findBy()
{}
public function updateBy()
{ }
public function deleteBy()
{}
}
```
view.stub 目前还没有任何内容,后期会补上,为什么会没有呢,因为后台管理的模板的样式肯定具有一定性共通特征。这里可以利用 view 继承的特性可以进行管理,所以这里此后添加。
最后在 application 目录下的 command.php 添加命令行
```
'make:curd' => app\command\CurdMaker::class,
```
### 编写命令
命令一共需要三个参数,[controller, model, module?], module是可选的,如果没有的话会自动获取 app.php 配的默认模块名称。下面直接上代码。在代码里面进行一定量的解释。可能有点枯燥,如果有不好的地方的也可以提供评论指出,我会进行修改
```
namespace app\command;
use think\console\Command;
use think\console\Input;
use think\console\input\Argument;
use think\console\input\Option;
use think\console\Output;
class CurdMaker extends Command
{
protected $appPath;
// view 默认的三个模板
protected $views = ['index', 'create', 'edit'];
public function __construct()
{
parent::__construct();
$this->appPath = env('app_path');
}
protected function configure()
{
$this->setName('make:curd')
->addArgument('controller', Argument::OPTIONAL, "controller name")
->addArgument('model', Argument::OPTIONAL, "model name")
->addOption('module', null, Option::VALUE_REQUIRED, 'module name')
->setDescription('Create curd option controller model --module?');
}
protected function execute(Input $input, Output $output)
{
// 首先获取默认模块
$moduleName = config('app.default_module');
$controllerName = trim($input->getArgument('controller'));
if (!$controllerName) {
$output->writeln('Controller Name Must Set');exit;
}
$modelName = trim($input->getArgument('model'));
if (!$modelName) {
$output->writeln('Model Name Must Set');exit;
}
if ($input->hasOption('module')) {
$moduleName = $input->getOption('module');
}
$this->makeController($controllerName, $moduleName);
$output->writeln($controllerName . ' controller create success');
$this->makeModel($modelName, $moduleName);
$output->writeln($modelName . ' model create success');
$this->makeView($controllerName, $moduleName);
$output->writeln($controllerName . 'view create success');
}
// 创建控制器文件
protected function makeController($controllerName, $moduleName)
{
$controllerStub = $this->appPath . 'command' . DIRECTORY_SEPARATOR . 'stub' .DIRECTORY_SEPARATOR. 'Controller.stub';
$controllerStub = str_replace(['$controller', '$module'], [ucfirst($controllerName), strtolower($moduleName)], file_get_contents($controllerStub));
$controllerPath = $this->appPath . $moduleName . DIRECTORY_SEPARATOR . 'controller' . DIRECTORY_SEPARATOR;
if (!is_dir($controllerPath)) {
mkdir($controllerPath, 0777, true);
}
return file_put_contents( $controllerPath . $controllerName . '.php', $controllerStub);
}
// 创建模型文件
public function makeModel($modelName, $moduleName)
{
$modelStub = $this->appPath . 'command' . DIRECTORY_SEPARATOR . 'stub' .DIRECTORY_SEPARATOR. 'Model.stub';
$modelPath = $this->appPath . $moduleName . DIRECTORY_SEPARATOR . 'model';
if (!is_dir($modelPath)) {
mkdir($modelPath, 0777, true);
}
$modelStub = str_replace(['$model', '$module'], [ucfirst($modelName), strtolower($moduleName)], file_get_contents($modelStub));
return file_put_contents($modelPath . DIRECTORY_SEPARATOR . $modelName . '.php', $modelStub);
}
// 创建模板
public function makeView($controllerName, $moduleName)
{
$viewStub = $this->appPath . 'command' . DIRECTORY_SEPARATOR . 'stub' .DIRECTORY_SEPARATOR. 'View.stub';
$viewPath = (config('template.view_path') ? config('template.view_path') . $moduleName . DIRECTORY_SEPARATOR : env('app_path') . $moduleName . DIRECTORY_SEPARATOR . 'view' . DIRECTORY_SEPARATOR) . strtolower($controllerName);
if (!is_dir($viewPath)) {
mkdir($viewPath, 0777, true);
}
foreach ($this->views as $view) {
file_put_contents($viewPath . DIRECTORY_SEPARATOR . $view .'.html', file_get_contents($viewStub));
}
}
}
```
这样一个 CURD 命令行就已经创建好了, 来使用了看看。
## 使用
```
php think 查看一下命令是够存在
```
![](https://box.kancloud.cn/c2a05c33c6c9315430b2179d6584cec1_599x192.png)
一已经有了,来尝试创建一下。首先使用默认的模块 index
```
php think make:curd Chat Chat
```
![](https://box.kancloud.cn/3e90ee5a99d2c48656ad2dba7bbdf4ac_499x142.png)
![](https://box.kancloud.cn/d165c57bd1c237ca79f3bd8fcc394684_272x195.png)
没问题,创建成功了。
一已经有了,再来创建使用新的模块 admin, 使用模块的话,就必须如下使用了
```
php think make:curd Chat Chat --module admin
```
![](https://box.kancloud.cn/632983ffe797a64cf852ed9b42808e25_573x135.png)
![](https://box.kancloud.cn/fc013d496eb4839d885e5f9e33978e3d_301x175.png)
嗯,已经没有问题了,可以正常使用了,以上就是编写 CURD 命令的过程。