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