命令行的使用

1.前言

ThinkPHP 支持 Console 应用,通过命令行的方式执行一些 URL 访问不方便或者安全性较高的操作。前面学习的接口封装,都是基于 HTTP 请求的,请求时间是会有超时时间的,若使用命令行可以在后台进程运行,而不是依赖于访问进程,ThinkPHP 命令行提供了一些方便的工具 ,下面介绍如何使用 ThinkPHP 命令行。

2.通过命令行查看版本

在框架的根目录下,有一个 think 脚本文件,可以使用 php 进程去调用它,查看 ThinkPHP 框架版本可以使用如下命令:

php think version
代码块
预览 复制
复制成功!
  • 1

输出如下图所示:

Tips:php 没有加入环境变量,可以使用绝对路径,如 E:\php\php7.3.4nts\php think version

3.快速生成控制器

若想要单应用 app\controller 目录下快速生成控制器和方法,可以使用如下命令:

php think make:controller test
代码块
预览 复制
复制成功!
  • 1

如下图所示:

生成的控制器文件内容如下:

<?php
declare (strict_types = 1);

namespace app\controller;

use think\Request;

class test
{
    /**
     * 显示资源列表
     *
     * @return \think\Response
     */
    public function index()
    {
        //
    }

    /**
     * 显示创建资源表单页.
     *
     * @return \think\Response
     */
    public function create()
    {
        //
    }

    /**
     * 保存新建的资源
     *
     * @param  \think\Request  $request
     * @return \think\Response
     */
    public function save(Request $request)
    {
        //
    }

    /**
     * 显示指定的资源
     *
     * @param  int  $id
     * @return \think\Response
     */
    public function read($id)
    {
        //
    }

    /**
     * 显示编辑资源表单页.
     *
     * @param  int  $id
     * @return \think\Response
     */
    public function edit($id)
    {
        //
    }

    /**
     * 保存更新的资源
     *
     * @param  \think\Request  $request
     * @param  int  $id
     * @return \think\Response
     */
    public function update(Request $request, $id)
    {
        //
    }

    /**
     * 删除指定资源
     *
     * @param  int  $id
     * @return \think\Response
     */
    public function delete($id)
    {
        //
    }
}

代码块
预览 复制
复制成功!
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
  • 14
  • 15
  • 16
  • 17
  • 18
  • 19
  • 20
  • 21
  • 22
  • 23
  • 24
  • 25
  • 26
  • 27
  • 28
  • 29
  • 30
  • 31
  • 32
  • 33
  • 34
  • 35
  • 36
  • 37
  • 38
  • 39
  • 40
  • 41
  • 42
  • 43
  • 44
  • 45
  • 46
  • 47
  • 48
  • 49
  • 50
  • 51
  • 52
  • 53
  • 54
  • 55
  • 56
  • 57
  • 58
  • 59
  • 60
  • 61
  • 62
  • 63
  • 64
  • 65
  • 66
  • 67
  • 68
  • 69
  • 70
  • 71
  • 72
  • 73
  • 74
  • 75
  • 76
  • 77
  • 78
  • 79
  • 80
  • 81
  • 82
  • 83
  • 84
  • 85
  • 86

Tips: 其中快速生成几种常见的方法名,如果只想生成控制器可以使用 php think make:controller test --plain

4.快速生成模型

若想要单应用 app\model 目录下快速生成模型,可以使用如下命令:

php think make:model TestModel
代码块
预览 复制
复制成功!
  • 1

如下图所示:

生成的模型文件内容如下:

<?php
declare (strict_types = 1);

namespace app\model;

use think\Model;

/**
 * @mixin \think\Model
 */
class TestModel extends Model
{
    //
}
代码块
预览 复制
复制成功!
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
  • 14

Tips: declare (strict_types = 1)表示开启严格模式。

5.快速生成中间件

若想要单应用 app\middleware 目录下快速生成模型,可以使用如下命令:

php think make:middleware Auth
代码块
预览 复制
复制成功!
  • 1

如下图所示:

生成的中间件文件内容如下:

<?php
declare (strict_types = 1);

namespace app\middleware;

class Auth
{
    /**
     * 处理请求
     *
     * @param \think\Request $request
     * @param \Closure       $next
     * @return Response
     */
    public function handle($request, \Closure $next)
    {
        //
    }
}
代码块
预览 复制
复制成功!
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
  • 14
  • 15
  • 16
  • 17
  • 18
  • 19

6.快速生成验证器

若想要单应用 app\Models 目录下快速生成模型,可以使用如下命令:

php think make:validate Test
代码块
预览 复制
复制成功!
  • 1

如下图所示:

生成的验证器文件内容如下:

<?php
declare (strict_types = 1);

namespace app\validate;

use think\Validate;

class Test extends Validate
{
    /**
     * 定义验证规则
     * 格式:'字段名' =>  ['规则1','规则2'...]
     *
     * @var array
     */
    protected $rule = [];

    /**
     * 定义错误信息
     * 格式:'字段名.规则名' =>  '错误信息'
     *
     * @var array
     */
    protected $message = [];
}
代码块
预览 复制
复制成功!
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
  • 14
  • 15
  • 16
  • 17
  • 18
  • 19
  • 20
  • 21
  • 22
  • 23
  • 24
  • 25

7.清除缓存文件

若想要清除 runtime 目录下的缓存文件,可以使用如下命令:

php think clear
代码块
预览 复制
复制成功!
  • 1

如下图所示是清除前的示意图:

清除之后如下图所示:

Tips: 若不需要保留空目录,可以使用 php think clear --dir

8.输出路由定义列表

若想要查看定义了哪些路由,可以使用如下命令:

php think route:list
代码块
预览 复制
复制成功!
  • 1

如下图所示:

9.小结

本小节介绍了如何简单的使用 ThinkPHP 提供的命令行,使用这些命令行可以快速的生成控制器、模型、中间件、验证器,也可以根据实际情况选择手动创建这些文件,另外还介绍了如何使用命令行清空缓存,使用命令行查看框架中定义了哪些路由的列表。熟练地掌握这些命令行将会使你的开发效率更高。