首页 > php框架 > Laravel > 正文

laravel如何创建自定义的Artisan命令_Laravel自定义Artisan命令教程

穿越時空
发布: 2025-10-27 11:33:01
原创
364人浏览过
答案:在 Laravel 中创建自定义 Artisan 命令可自动化常用任务,使用 make:command 生成命令类,配置 signature 和 description 属性定义调用方式与描述,于 handle() 方法编写逻辑,通过 argument() 和 option() 获取参数与选项,利用 info() 等方法输出信息,最后在 app/Console/Kernel.php 的 $commands 数组注册命令即可通过 php artisan 运行,结合计划任务可定时执行。

laravel如何创建自定义的artisan命令_laravel自定义artisan命令教程

在 Laravel 中创建自定义 Artisan 命令非常简单,能帮助你将常用任务自动化,比如清理数据、发送邮件、处理队列等。通过 Artisan 命令行工具,你可以像使用内置命令一样运行自己的逻辑。

生成自定义 Artisan 命令

Laravel 提供了 make:command 命令来快速生成一个命令类。打开终端,进入项目根目录,执行以下命令:

php artisan make:command SendDailyReport

这会在 app/Console/Commands 目录下生成一个名为 SendDailyReport.php 的文件。如果该目录不存在,Laravel 会在第一次创建命令时自动创建。

配置命令签名和描述

打开生成的命令文件,你会看到两个关键属性:signature 和 description。

signature 定义了你在终端调用命令时使用的名称和参数格式;description 是命令的简要说明,出现在 php artisan list 中。

示例:

protected $signature = 'report:send {user? : 用户邮箱} {--queue : 是否加入队列}';
protected $description = '发送每日报告';

上面的 signature 中:

  • report:send 是命令名称
  • {user?} 表示可选参数,名字是 user
  • {--queue} 表示可选选项(布尔值)

编写命令逻辑

handle() 方法中编写你的业务逻辑。你可以调用模型、门面、服务类等 Laravel 功能。

通义万相
通义万相

通义万相,一个不断进化的AI艺术创作大模型

通义万相596
查看详情 通义万相

示例:

public function handle()
{
    $user = $this->argument('user');
    if ($this->option('queue')) {
        dispatch(new SendReportJob($user));
        $this->info('任务已加入队列');
    } else {
        // 直接发送
        $this->info('报告已发送给 ' . ($user ?? '所有人'));
    }
}

你可以使用 $this->info()$this->error()$this->line() 等方法输出信息到控制台。

注册命令并运行

Laravel 会自动加载 app/Console/Kernel.php$commands 数组里列出的命令。

确保你的命令类被包含进去:

protected $commands = [
    \App\Console\Commands\SendDailyReport::class,
];

然后在终端运行:

php artisan report:send --queue

或带参数:

php artisan report:send john@example.com --queue

基本上就这些。Laravel 自定义 Artisan 命令让你轻松把重复任务脚本化,结合计划任务还能实现定时执行,非常实用。

以上就是laravel如何创建自定义的Artisan命令_Laravel自定义Artisan命令教程的详细内容,更多请关注php中文网其它相关文章!

最佳 Windows 性能的顶级免费优化软件
最佳 Windows 性能的顶级免费优化软件

每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。

下载
来源:php中文网
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
最新问题
开源免费商场系统广告
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 意见反馈 讲师合作 广告合作 最新更新 English
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送
PHP中文网APP
随时随地碎片化学习
PHP中文网抖音号
发现有趣的

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号