命令行的使用
1.前言
ThinkPHP 支持 Console 应用,通过命令行的方式执行一些 URL 访问不方便或者安全性较高的操作。前面学习的接口封装,都是基于 HTTP 请求的,请求时间是会有超时时间的,若使用命令行可以在后台进程运行,而不是依赖于访问进程,ThinkPHP 命令行提供了一些方便的工具 ,下面介绍如何使用 ThinkPHP 命令行。
2.通过命令行查看版本
在框架的根目录下,有一个 think 脚本文件,可以使用 php 进程去调用它,查看 ThinkPHP 框架版本可以使用如下命令:
php think version
输出如下图所示:

Tips: 若
php没有加入环境变量,可以使用绝对路径,如E:\php\php7.3.4nts\php think version。
3.快速生成控制器
若想要单应用 app\controller 目录下快速生成控制器和方法,可以使用如下命令:
php think make:controller test
如下图所示:

生成的控制器文件内容如下:
<?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)
    {
        //
    }
}
Tips: 其中快速生成几种常见的方法名,如果只想生成控制器可以使用
php think make:controller test --plain。
4.快速生成模型
若想要单应用 app\model 目录下快速生成模型,可以使用如下命令:
php think make:model TestModel
如下图所示:

生成的模型文件内容如下:
<?php
declare (strict_types = 1);
namespace app\model;
use think\Model;
/**
 * @mixin \think\Model
 */
class TestModel extends Model
{
    //
}
Tips:
declare (strict_types = 1)表示开启严格模式。
5.快速生成中间件
若想要单应用 app\middleware 目录下快速生成模型,可以使用如下命令:
php think make:middleware Auth
如下图所示:

生成的中间件文件内容如下:
<?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)
    {
        //
    }
}
6.快速生成验证器
若想要单应用 app\Models 目录下快速生成模型,可以使用如下命令:
php think make:validate Test
如下图所示:

生成的验证器文件内容如下:
<?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 = [];
}
7.清除缓存文件
若想要清除 runtime 目录下的缓存文件,可以使用如下命令:
php think clear
如下图所示是清除前的示意图:

清除之后如下图所示:

Tips: 若不需要保留空目录,可以使用
php think clear --dir。
8.输出路由定义列表
若想要查看定义了哪些路由,可以使用如下命令:
php think route:list
如下图所示:

9.小结
本小节介绍了如何简单的使用 ThinkPHP 提供的命令行,使用这些命令行可以快速的生成控制器、模型、中间件、验证器,也可以根据实际情况选择手动创建这些文件,另外还介绍了如何使用命令行清空缓存,使用命令行查看框架中定义了哪些路由的列表。熟练地掌握这些命令行将会使你的开发效率更高。
Tips: 代码仓库:[https://gitee.com/love-for-poetry/tp6]
Excel 导入学生信息
Excel 导出学生信息
后台处理数据
访问者可将本网站提供的内容或服务用于个人学习、研究或欣赏,以及其他非商业性或非盈利性用途,但同时应遵守著作权法及其他相关法律的规定,不得侵犯本网站及相关权利人的合法权利。
本网站内容原作者如不愿意在本网站刊登内容,请及时通知本站,邮箱:80764001@qq.com,予以删除。
