使用额外环境文件配置 Laravel

最后更新于 作者:

Configuring Laravel With Additional Environment Files image

在 Laravel 中,您可以配置额外的环境文件,这些文件将在 .env 文件加载之前加载。此功能对于测试很有用,您可以在测试环境中加载 .env.testing 环境文件而不是默认文件。通常您不需要使用此功能,但值得知道的是,通过设置 APP_ENV 环境变量,Laravel 可以检测自定义配置。

CLI 示例

此功能最简单的例子是使用不同的环境文件在运行 Laravel Artisan 控制台或甚至 phpunit CLI 时。

使用 Artisan 命令,您也可以使用不同的 .env 文件,方法是使用 --env 标志或定义 APP_ENV。例如,运行以下命令,Laravel 将会查找 .env.demo

# Set up `.env.demo`
cp .env .env.demo
echo "\nEXAMPLE_SETTING=demo" >> .env.demo
 
# Use the `demo` env
 
php artisan tinker --env=demo
 
# Or set APP_ENV
APP_ENV=demo php artisan tinker

如果找到,Laravel 将不会加载 .env 文件,而是加载 .env.demo

Example using .env.demo instead of .env
使用 .env.demo 而不是 .env 的示例

在 PHPUnit 测试中使用 .env.testing

基于我们对 Laravel 框架在存在特定 ENV 文件时加载它的了解,在 PHPUnit 中运行 Laravel 功能测试默认情况下会使用 .env 文件。在测试和本地开发中使用 .env 会很快导致问题,例如为测试配置单独的数据库。您可以在 phpunit.xml 中定义数据库连接详细信息,但让我们也看一下在 .env.testing 中设置它们。

PHPUnit 在 phpunit.xml 中定义了一个 APP_ENV 环境变量,这意味着 Laravel 在引导功能测试时会查找 .env.testing 文件,因为 phpunit.xml 文件在 Laravel 框架在功能测试中启动之前定义了 APP_ENV

<env name="APP_ENV" value="testing"/>

这意味着我们可以将默认的 .env 文件复制到 .env.testing 并避免在测试过程中混合这两个文件。

cp .env .env.testing
 
echo "\nEXAMPLE_SETTING=testing" >> .env.testing

您可以在 phpunit.xml 中配置环境变量。但是,我喜欢使用 .env.testing 文件来确保专门用于测试的干净环境。您还可以选择是否将 .env.testing 版本控制或在 .gitignore 中忽略它。

复制 .env 文件后,您可以在 tests/Feature 文件夹中的测试中添加以下内容来验证是否加载了 .env.testingtests/Unit 文件夹中的测试不会引导 Laravel 框架。

/**
* A basic test example.
*/
public function test_the_application_returns_a_successful_response(): void
{
logger('Which environment file is Laravel using?', [
'file' => $this->app->environmentFile()
]);
 
$response = $this->get('/');
 
$response->assertStatus(200);
}

当我运行 phpunit 时,我得到了以下确认我正在使用 .env.testing 文件的日志。

[2024-05-24 00:22:42] testing.DEBUG: Which environment file is Laravel using? {"file":".env.testing"}

如果您在 VCS 中忽略了此文件,您可以在您的团队约定中添加一个示例文件 .env.testing.example 或让他们决定如何配置本地测试。我建议在 CI 中设置系统级环境变量来配置诸如测试数据库之类的东西。

查看 Laravel 文档 以获取有关环境配置的更多详细信息。如果您对如何在框架级别实现这一点感到好奇,请查看 setEnvironmentFilePath 方法和 checkForSpecificEnvironmentFile 在 Laravel 框架源代码中。

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

No Compromises

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

No Compromises
Kirschbaum logo

Kirschbaum

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

Kirschbaum
Shift logo

Shift

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

Shift
Bacancy logo

Bacancy

让您的项目充满活力,拥有经验丰富的 Laravel 开发人员,拥有 4-6 年的经验,每月仅需 2500 美元。获得 160 小时的专业知识和 15 天无风险试用。立即预约通话!

Bacancy
Lucky Media logo

Lucky Media

现在就来 Lucky - Laravel 开发的理想选择,拥有超过 10 年的经验!

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 应用程序添加评论

阅读文章