在 Laravel 中自定义 Stub

发布时间 作者

Customizing Stubs in Laravel image

这篇文章将向您展示如何自定义用于在您的应用程序中生成各种类的 Stub。虽然手动调整每个生成的类可能很繁琐,但 Laravel 为开发者提供了一种方法来发布和版本控制 Stub,如果您想让生成的类符合您的特定口味,可以使用这种方法。

如果您想跟着一起做,可以使用 Laravel 安装程序、使用 Sail 或者您喜欢的任何其他方法创建一个新的 Laravel 项目。

laravel new stub-demo --git

您可能已经注意到,Laravel 安装程序现在支持 Git 和 GitHub 集成,假设您拥有所需的最低 Git 版本,您应该有一个新的代码库和第一个提交。

版本控制我们的演示项目是可视化我们沿途进行的 Stub 更改以及查看 Laravel 将哪些文件发布到应用程序中的一个很好的方法。

发布 Stub

自定义 Stub 的第一步可能是将您想要单独自定义的 Stub 添加到 Laravel 项目根目录下的 /stubs 文件夹中,或者您可以使用 Artisan 发布所有 Stub。

$ php artisan stub:publish
$ git add stubs
$ git status
Changes to be committed:
(use "git reset HEAD <file>..." to unstage)
 
new file: stubs/cast.stub
new file: stubs/console.stub
new file: stubs/controller.api.stub
new file: stubs/controller.invokable.stub
new file: stubs/controller.model.api.stub
new file: stubs/controller.model.stub
new file: stubs/controller.nested.api.stub
new file: stubs/controller.nested.stub
new file: stubs/controller.plain.stub
new file: stubs/controller.stub
new file: stubs/factory.stub
new file: stubs/job.queued.stub
new file: stubs/job.stub
new file: stubs/middleware.stub
new file: stubs/migration.create.stub
new file: stubs/migration.stub
new file: stubs/migration.update.stub
new file: stubs/model.pivot.stub
new file: stubs/model.stub
new file: stubs/observer.plain.stub
new file: stubs/observer.stub
new file: stubs/policy.plain.stub
new file: stubs/policy.stub
new file: stubs/request.stub
new file: stubs/resource-collection.stub
new file: stubs/resource.stub
new file: stubs/rule.stub
new file: stubs/seeder.stub
new file: stubs/test.stub
new file: stubs/test.unit.stub

如您所见,我们在 app 文件夹中发布了相当多的 Stub!如果您想对它们进行版本控制,我建议您自行决定,您可以保留它们的副本,或者只保留您想要自定义的特定 Stub。

自定义控制器 Stub

Laravel 8.36 引入了在创建控制器时使用 --type 标志的想法,允许您编写自定义 Stub 文件以生成控制器。

<?php
// stubs/controller.custom.stub
namespace {{ namespace }};
 
use {{ rootNamespace }}Http\Controllers\Controller;
use Illuminate\Http\Request;
 
/**
* Hello from the custom controller stub
*/
class {{ class }}
{
//
}

添加了自定义 Stub 类之后,可以使用此模板生成控制器。

php artisan make:controller --type=custom MyController

这将生成以下控制器文件

<?php
 
namespace App\Http\Controllers;
 
use Illuminate\Http\Request;
 
/**
* Hello from the custom controller stub
*/
class MyController
{
//
}

虽然这种灵活性水平很不错,但我相信大多数开发者都可以满足框架提供的 Stub 的要求。使用新的 --type 标志是手动选择要生成哪个控制器模板的一种方式。

php artisan make:controller --type=plain PlainController

这将根据 Laravel 发布的 stubs/controller.plain.stub 文件生成一个文件。

<?php
 
namespace App\Http\Controllers;
 
use Illuminate\Http\Request;
 
class PlainController extends Controller
{
//
}

一个合理的方案

假设您想在 Laravel 应用程序中生成的每个文件开头添加一个版权注释。在这种情况下,您可以考虑对所有可用的 Stub 进行版本控制,并在您升级时运行 stub:publish 命令以获取新添加的 Stub。

但是,对于典型用例,您可能只对需要自定义的 Stub 进行版本控制。例如,假设您不希望任何控制器扩展基本 Controller 类;您可以对所有 controller.* Stub 进行版本控制,并在其中添加您的自定义内容,但删除所有其他 Stub。

如果上游 Stub 发生更改怎么办?

假设您对 stub:publish 中的所有 Stub 都进行了版本控制,但您担心 Laravel 框架对核心 Stub 文件进行更新时,您的应用程序将落后。如果您对所有 Stub 都进行了版本控制,您可以始终强制更新以获取最新版本。

以这个例子为例,我们修改一个 Stub 并将其提交到 Git

echo "/* test */" >> stubs/test.stub
git commit -am"Testing stub update"

您已更新测试 Stub 并将更新提交到 Git。假设稍后 Laravel 发布了一些 Stub 更新,您想验证是否有任何更新。

$ php artisan stub:publish --force
$ git diff
diff --git a/stubs/test.stub b/stubs/test.stub
index 834a53d..84c75cb 100644
--- a/stubs/test.stub
+++ b/stubs/test.stub
@@ -20,4 +20,3 @@ class {{ class }} extends TestCase
$response->assertStatus(200);
}
}
-/* test */

您有一个简单的方法可以查看您的 Stub 随着时间的推移与 Laravel 代码库的差异!由于 Stub 是版本控制的,因此您可以简单地撤消 --force 标志导致的更改,如果您需要将您的更改与最新的 Stub 更改合并。

Paul Redmond photo

Laravel 新闻的专栏作家。全栈 Web 开发人员和作家。

Cube

Laravel 新闻稿

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

Laravel Forge logo

Laravel Forge

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

Laravel Forge
Tinkerwell logo

Tinkerwell

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

Tinkerwell
No Compromises logo

没有妥协

Joel 和 Aaron,两位来自“没有妥协”播客的经验丰富的开发者,现在可以为您的 Laravel 项目雇用。⬧ 固定价格为每月 7,500 美元。⬧ 没有漫长的销售流程。⬧ 没有合同。⬧ 100% 退款保证。

没有妥协
Kirschbaum logo

Kirschbaum

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

Kirschbaum
Shift logo

Shift

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

Shift
Bacancy logo

Bacancy

使用经验丰富的 Laravel 开发人员(4-6 年经验)为您的项目充电,每月只需 2,500 美元。获得 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 应用程序中添加评论

阅读文章