小型但功能强大的 CLI 应用程序使用 Minicli

发布时间 作者

Small but powerful CLI apps with Minicli image

构建 CLI 应用程序非常有趣。我们无需担心 UI,可以编写不需要任何构建步骤的漂亮 PHP 代码。

在 PHP 中构建 CLI 应用程序时,我们没有像构建 Web 应用程序那样多的选择 - 但有一些可靠的竞争者。从使用事实上的标准 Symfony Console 组件或额外的辣味 Laravel Zero。但是,在构建 CLI 应用程序时,您可能希望尽可能地不依赖,这就是 Minicli 出现的地方。Minicli 一段时间前由 Erika Heidi 发布,作为构建一个不依赖的 CLI 框架的实验,该框架仅依赖于 PHPs readline 扩展。

我一直在花很多时间研究我正在从事的项目中的 CLI 选项。起初,我从我通常的选择开始:Laravel Zero。它对我和任何其他了解 Laravel 的开发人员来说都很熟悉。然后我开始质疑可移植性方面,并要求那些想要使用它的人拥有 PHP。这是为了工作,并不是所有用户都安装了 PHP。因此,我深入研究了编译语言的世界,研究了 GoLang 和 Rust。虽然没有太多可用的选项,但现有的选项非常出色。

最近关于原生 PHP 的讨论很多,这将我的注意力重新吸引到 PHP 空间。如果我能够构建一个轻量级、易于维护且可移植的 PHP CLI 应用程序呢?正是在这个时候,我再次查看了 Minicli。在它刚出来的时候玩过它,我对它在不依赖的情况下使用起来有多好印象深刻 - 但它也易于上手!

构建 Minicli 应用程序的推荐方法是使用应用程序骨架和作曲家来设置所有内容,并为您准备好。

composer create-project --prefer-dist minicli/application my-awesome-idea

对于您来说,这些目录应该足够熟悉,因为 Laravel 开发人员有一个 app 目录和命名空间。您创建的命令建议构建为 命令控制器,它们是基于类的命令。

我们在 app/Commands 下创建一个命令命名空间,您将命令保存在其中。

mkdir app/Commands/LaravelNews

在每个命名空间下,您可以为不同的变体添加多个命令。如果未传递任何参数,则推断您将想要使用 DefaultController。让我们看看如何创建一个命令。

declare(strict_types=1);
 
namespace App\Command\LaravelNews;
 
use Minicli\Command\CommandController;
 
final class DefaultController extends CommandController
{
public function handle(): void
{
$this->getPrinter()->display("Laravel News rocks");
}
}

每个命令控制器都必须 处理,并且不需要返回任何内容 - 与 Symfony 或 Laravel Zero 不同,后者需要一个退出代码。要与输出交互,您获得打印机 - 并要求它输出内容。

所以,如果我们想添加一个替代版本 - 我们可以为我们的命名空间创建一个其他命令控制器。

declare(strict_types=1);
 
namespace App\Command\LaravelNews;
 
use Minicli\Command\CommandController;
 
final class InfoController extends CommandController
{
public function handle(): void
{
$this->getPrinter()->info("Laravel News rocks");
}
}

现在我们可以调用我们的命令

./minicli laravel-news info

这将为默认命令提供一个不同的视图,我们可以使用以下其他选项

display():一个简单的文本输出。info():一个信息性的文本输出。error():一个错误格式化的文本输出。success():一个成功格式化的文本输出。

每个选项都接受第二个参数作为 alt 用于替代输出,它将使用写入而不是彩色写入进行块颜色输出。

它不像 Laravel Zero 使用 Termwind 那样漂亮 - 但有时你不需要漂亮!

通常,在构建 CLI 应用程序时,我们希望与第三方 API 或其他服务交互以执行操作或逻辑。在 Minicli 中,这是通过创建服务来完成的。

// minicli
$app = new App();
$app->registerService(
'email',
new MyEmailImplementation(),
);

然后,在我们的命令中,我们可以获取应用程序实例并直接调用我们的服务

public function handle(): void
{
$service = $this->getApp()->email;
 
try {
$service->send(new EmailTemplate());
} catch (Throwable $exception) {
$this->getPrinter()->error($exception->getMessage());
}
}

因此,我们有一个轻量级、功能强大的 CLI 框架,我们可以利用它来帮助我们的开发工作流程 - 它没有依赖项,允许我们编写漂亮的 PHP。

您尝试过 Minicli 吗?您使用过类似的东西吗?在推特上告诉我们!

Steve McDougall photo

Laravel 新闻 的技术作家,Treblle 的开发者倡导者。API 专家,经验丰富的 PHP/Laravel 工程师。YouTube 直播主.

Cube

Laravel 新闻通讯

加入 40,000 多名其他开发者,绝不错过新的技巧、教程等。

Laravel Forge logo

Laravel Forge

轻松创建和管理您的服务器,并在几秒钟内部署您的 Laravel 应用程序。

Laravel Forge
Tinkerwell logo

Tinkerwell

Laravel 开发人员必备的代码运行器。使用 AI、自动完成功能和本地和生产环境的即时反馈进行 Tinker 操作。

Tinkerwell
No Compromises logo

没有妥协

Joel 和 Aaron,两位来自 No Compromises 播客的经验丰富的开发者,现在可以为您的 Laravel 项目雇佣。⬧ 固定费率 7500 美元/月。⬧ 没有漫长的销售流程。⬧ 没有合同。⬧ 100% 退款保证。

没有妥协
Kirschbaum logo

Kirschbaum

提供创新和稳定性,确保您的 Web 应用程序取得成功。

Kirschbaum
Shift logo

Shift

运行旧版本的 Laravel 吗?即时、自动化的 Laravel 升级和代码现代化,使您的应用程序保持新鲜感。

Shift
Bacancy logo

Bacancy

只需 2500 美元/月,即可为您的项目配备经验丰富的 Laravel 开发人员(拥有 4-6 年的经验)。获得 160 小时的专业知识和无风险的 15 天试用。立即安排电话!

Bacancy
Lucky Media logo

Lucky Media

立即获得幸运 - Laravel 开发的理想选择,拥有十多年的经验!

Lucky Media
Lunar: Laravel E-Commerce logo

Lunar:Laravel 电子商务

Laravel 的电子商务。一个开源软件包,将现代无头电子商务功能的力量带入 Laravel。

Lunar:Laravel 电子商务
LaraJobs logo

LaraJobs

官方 Laravel 工作板

LaraJobs
SaaSykit: Laravel SaaS Starter Kit logo

SaaSykit:Laravel SaaS 启动工具包

SaaSykit 是一个 Laravel SaaS 启动工具包,包含运行现代 SaaS 所需的所有功能。支付、漂亮的结账、管理面板、用户仪表盘、身份验证、准备好的组件、统计信息、博客、文档等。

SaaSykit:Laravel SaaS 启动工具包
Rector logo

Rector

您无缝升级 Laravel、降低成本和加速创新的合作伙伴,为成功公司提供支持

Rector
MongoDB logo

MongoDB

通过 MongoDB 和 Laravel 的强大集成增强您的 PHP 应用程序,使开发人员能够轻松高效地构建应用程序。支持事务、搜索、分析和移动用例,同时使用熟悉的 Eloquent API。了解 MongoDB 的灵活、现代数据库如何改变您的 Laravel 应用程序。

MongoDB
Maska is a Simple Zero-dependency Input Mask Library image

Maska 是一个简单的零依赖输入掩码库

阅读文章
Add Swagger UI to Your Laravel Application image

将 Swagger UI 添加到您的 Laravel 应用程序

阅读文章
Assert the Exact JSON Structure of a Response in Laravel 11.19 image

在 Laravel 11.19 中断言响应的精确 JSON 结构

阅读文章
Build SSH Apps with PHP and Laravel Prompts image

使用 PHP 和 Laravel 提示构建 SSH 应用程序

阅读文章
Building fast, fuzzy site search with Laravel and Typesense image

使用 Laravel 和 Typesense 构建快速、模糊的网站搜索

阅读文章
Add Comments to your Laravel Application with the Commenter Package image

使用 Commenter 软件包为您的 Laravel 应用程序添加评论

阅读文章