配置
简介
Laravel 框架的所有配置文件都存储在 config 目录中。每个选项都有文档说明,因此你可以随意浏览这些文件,并熟悉可供你使用的选项。
这些配置文件允许你配置诸如数据库连接信息、邮件服务器信息以及其他各种核心配置值,例如应用程序 URL 和加密密钥。
about 命令
Laravel 可以通过 about Artisan 命令显示应用程序配置、驱动程序和环境的概览。
php artisan about如果你只对应用程序概览输出的特定部分感兴趣,可以使用 --only 选项筛选该部分:
php artisan about --only=environment或者,要详细探索特定配置文件的值,你可以使用 config:show Artisan 命令:
php artisan config:show database环境配置
根据应用程序运行的环境拥有不同的配置值通常很有帮助。例如,你可能希望在本地使用与生产服务器上不同的缓存驱动程序。
为了让这变得轻而易举,Laravel 利用了 DotEnv PHP 库。在新的 Laravel 安装中,应用程序的根目录会包含一个 .env.example 文件,该文件定义了许多常见的环境变量。在 Laravel 安装过程中,此文件会自动复制到 .env。
Laravel 默认的 .env 文件包含一些常见的配置值,这些值可能会根据你的应用程序是在本地运行还是在生产 Web 服务器上运行而有所不同。然后,config 目录中的配置文件使用 Laravel 的 env 函数读取这些值。
如果你与团队一起开发,你可能希望继续在你的应用程序中包含并更新 .env.example 文件。通过在示例配置文件中放置占位值,你团队中的其他开发人员可以清楚地看到运行你的应用程序所需的环境变量。
NOTE
你 .env 文件中的任何变量都可以被外部环境变量(例如服务器级或系统级环境变量)覆盖。
环境文件安全
你的 .env 文件不应提交到应用程序的源代码控制中,因为每个使用你应用程序的开发者/服务器可能需要不同的环境配置。此外,如果入侵者访问了你的源代码仓库,这将会带来安全风险,因为任何敏感凭据都会暴露。
但是,你可以使用 Laravel 内置的环境加密功能加密你的环境文件。加密的环境文件可以安全地放入源代码控制中。
额外的环境文件
在加载应用程序的环境变量之前,Laravel 会确定是否已从外部提供了 APP_ENV 环境变量,或者是否已指定了 --env CLI 参数。如果是,Laravel 将尝试加载 .env.[APP_ENV] 文件(如果存在)。如果不存在,则将加载默认的 .env 文件。
环境变量类型
.env 文件中的所有变量通常被解析为字符串,因此创建了一些保留值,允许你从 env() 函数返回更广泛的类型:
.env 值 | env() 值 |
|---|---|
| true | (bool) true |
| (true) | (bool) true |
| false | (bool) false |
| (false) | (bool) false |
| empty | (string) '' |
| (empty) | (string) '' |
| null | (null) null |
| (null) | (null) null |
如果你需要定义一个包含空格值的环境变量,可以通过将值括在双引号中来实现:
APP_NAME="我的应用程序"获取环境配置
当你的应用程序收到请求时,.env 文件中列出的所有变量都将加载到 $_ENV PHP 超全局变量中。但是,你可以在配置文件中使用 env 函数从这些变量中检索值。事实上,如果你查看 Laravel 的配置文件,你会注意到许多选项已经在使用这个函数:
'debug' => (bool) env('APP_DEBUG', false),传递给 env 函数的第二个值是“默认值”。如果给定键不存在环境变量,则将返回此值。
确定当前环境
当前的应用程序环境由 .env 文件中的 APP_ENV 变量确定。你可以通过 App 门面上的 environment 方法访问此值:
use Illuminate\Support\Facades\App;
$environment = App::environment();你也可以向 environment 方法传递参数以确定环境是否与给定值匹配。如果环境与任何给定值匹配,该方法将返回 true:
if (App::environment('local')) {
// 环境是 local
}
if (App::environment(['local', 'staging'])) {
// 环境是 local 或 staging...
}NOTE
当前的应用程序环境检测可以通过定义服务器级的 APP_ENV 环境变量来覆盖。
加密环境文件
未加密的环境文件绝不应存储在源代码控制中。但是,Laravel 允许你加密你的环境文件,以便它们可以与你的应用程序的其余部分一起安全地添加到源代码控制中。
加密
要加密环境文件,你可以使用 env:encrypt 命令:
php artisan env:encrypt运行 env:encrypt 命令将加密你的 .env 文件,并将加密后的内容放入 .env.encrypted 文件中。解密密钥在命令的输出中显示,应存储在安全的密码管理器中。如果你想提供自己的加密密钥,可以在调用命令时使用 --key 选项:
php artisan env:encrypt --key=3UVsEgGVK36XN82KKeyLFMhvosbZN1aFNOTE
提供的密钥长度应与所使用的加密密码所需的密钥长度相匹配。默认情况下,Laravel 将使用 AES-256-CBC 密码,该密码需要 32 个字符的密钥。你可以在调用命令时传递 --cipher 选项,自由使用 Laravel 的加密器支持的任何密码。
如果你的应用程序有多个环境文件,例如 .env 和 .env.staging,你可以通过 --env 选项提供环境名称来指定应加密的环境文件:
php artisan env:encrypt --env=staging可读变量名
在加密你的环境文件时,你可以使用 --readable 选项来保留可见的变量名,同时加密它们的值:
php artisan env:encrypt --readable这将生成一个具有以下格式的加密文件:
APP_NAME=eyJpdiI6...
APP_ENV=eyJpdiI6...
APP_KEY=eyJpdiI6...
APP_DEBUG=eyJpdiI6...
APP_URL=eyJpdiI6...使用可读格式,你可以在不暴露敏感数据的情况下查看存在哪些环境变量。它也使审查拉取请求变得更加容易,因为你无需解密文件就可以看到添加、删除或重命名了哪些变量。
在解密环境文件时,Laravel 会自动检测使用了哪种格式,因此 env:decrypt 命令不需要额外的选项。
NOTE
使用 --readable 选项时,原始环境文件中的注释和空行不会包含在加密输出中。
解密
要解密环境文件,你可以使用 env:decrypt 命令。此命令需要一个解密密钥,Laravel 将从 LARAVEL_ENV_ENCRYPTION_KEY 环境变量中检索该密钥:
php artisan env:decrypt或者,可以通过 --key 选项将密钥直接提供给命令:
php artisan env:decrypt --key=3UVsEgGVK36XN82KKeyLFMhvosbZN1aF当调用 env:decrypt 命令时,Laravel 将解密 .env.encrypted 文件的内容,并将解密后的内容放入 .env 文件中。
可以向 env:decrypt 命令提供 --cipher 选项以使用自定义加密密码:
php artisan env:decrypt --key=qUWuNRdfuImXcKxZ --cipher=AES-128-CBC如果你的应用程序有多个环境文件,例如 .env 和 .env.staging,你可以通过 --env 选项提供环境名称来指定应解密的环境文件:
php artisan env:decrypt --env=staging为了覆盖现有的环境文件,你可以向 env:decrypt 命令提供 --force 选项:
php artisan env:decrypt --force访问配置值
你可以从应用程序的任何位置轻松地使用 Config 门面或全局的 config 函数访问你的配置值。配置值可以使用“点”语法访问,该语法包含你要访问的文件名和选项。也可以指定默认值,如果配置选项不存在,将返回该默认值:
use Illuminate\Support\Facades\Config;
$value = Config::get('app.timezone');
$value = config('app.timezone');
// 如果配置值不存在,则检索默认值...
$value = config('app.timezone', 'Asia/Seoul');要在运行时设置配置值,你可以调用 Config 门面的 set 方法或将数组传递给 config 函数:
Config::set('app.timezone', 'America/Chicago');
config(['app.timezone' => 'America/Chicago']);为了辅助静态分析,Config 门面还提供了类型化的配置检索方法。如果检索到的配置值与预期类型不匹配,将抛出异常:
Config::string('config-key');
Config::integer('config-key');
Config::float('config-key');
Config::boolean('config-key');
Config::array('config-key');
Config::collection('config-key');配置缓存
为了给应用程序提速,你应该使用 config:cache Artisan 命令将所有配置文件缓存到单个文件中。这会将你应用程序的所有配置选项组合到一个文件中,框架可以快速加载该文件。
你通常应该在生产部署过程中运行 php artisan config:cache 命令。在本地开发期间不应运行该命令,因为在应用程序开发过程中配置选项需要经常更改。
一旦配置被缓存,你的应用程序的 .env 文件将不会在请求或 Artisan 命令期间被框架加载;因此,env 函数将仅返回外部的、系统级的环境变量。
因此,你应该确保只从应用程序的配置(config)文件中调用 env 函数。通过检查 Laravel 的默认配置文件,你可以看到许多这样的示例。你可以使用上述 config 函数从应用程序的任何位置访问配置值。
config:clear 命令可用于清除缓存的配置:
php artisan config:clearWARNING
如果你在部署过程中执行了 config:cache 命令,你应该确保只在你的配置文件中调用 env 函数。配置被缓存后,.env 文件将不会被加载;因此,env 函数将仅返回外部的、系统级的环境变量。
配置发布
Laravel 的大多数配置文件已经发布在你的应用程序的 config 目录中;但是,某些配置文件(如 cors.php 和 view.php)默认不会发布,因为大多数应用程序永远不需要修改它们。
但是,你可以使用 config:publish Artisan 命令来发布默认未发布的任何配置文件:
php artisan config:publish
php artisan config:publish --all调试模式
你 config/app.php 配置文件中的 debug 选项决定了实际向用户显示多少关于错误的信息。默认情况下,此选项设置为遵循存储在 .env 文件中的 APP_DEBUG 环境变量的值。
WARNING
对于本地开发,你应该将 APP_DEBUG 环境变量设置为 true。在你的生产环境中,此值应始终为 false。如果在生产环境中将该变量设置为 true,你可能会将敏感的配置值暴露给你的应用程序的最终用户。
维护模式
当你的应用程序处于维护模式时,针对你应用程序的所有请求都会显示一个自定义视图。这使得在应用程序更新或执行维护时很容易“禁用”你的应用程序。维护模式检查已包含在你应用程序的默认中间件堆栈中。如果应用程序处于维护模式,则会抛出一个状态码为 503 的 Symfony\Component\HttpKernel\Exception\HttpException 实例。
要启用维护模式,请执行 down Artisan 命令:
php artisan down如果你希望将 Refresh HTTP 标头与所有维护模式响应一起发送,可以在调用 down 命令时提供 refresh 选项。Refresh 标头将指示浏览器在指定的秒数后自动刷新页面:
php artisan down --refresh=15你还可以向 down 命令提供 retry 选项,该选项将设置为 Retry-After HTTP 标头的值,尽管浏览器通常会忽略此标头:
php artisan down --retry=60绕过维护模式
要允许使用密钥令牌绕过维护模式,你可以使用 secret 选项指定一个维护模式绕过令牌:
php artisan down --secret="1630542a-246b-4b66-afa1-dd72a4c43515"将应用程序置于维护模式后,你可以导航到与此令牌匹配的应用程序 URL,Laravel 将向你的浏览器颁发一个维护模式绕过 cookie:
https://example.com/1630542a-246b-4b66-afa1-dd72a4c43515如果你希望 Laravel 为你生成密钥令牌,你可以使用 with-secret 选项。一旦应用程序处于维护模式,密钥将显示给你:
php artisan down --with-secret访问此隐藏路由时,你将被重定向到应用程序的 / 路由。一旦 cookie 被颁发给你的浏览器,你将能够正常浏览应用程序,就像它不处于维护模式一样。
NOTE
你的维护模式密钥通常应由字母数字字符组成,并且可选地包含短划线。你应该避免使用在 URL 中具有特殊含义的字符,例如 ? 或 &。
在多个服务器上使用维护模式
默认情况下,Laravel 使用基于文件的系统来确定你的应用程序是否处于维护模式。这意味着要激活维护模式,必须在托管你应用程序的每个服务器上执行 php artisan down 命令。
或者,Laravel 提供了一种基于缓存的方法来处理维护模式。这种方法只需要在一台服务器上运行 php artisan down 命令。要使用此方法,请修改应用程序 .env 文件中的维护模式变量。你应该选择一个所有服务器都可以访问的缓存 store。这确保了维护模式状态在所有服务器上保持一致:
APP_MAINTENANCE_DRIVER=cache
APP_MAINTENANCE_STORE=database预渲染维护模式视图
如果你在部署期间使用 php artisan down 命令,当你的 Composer 依赖项或其他基础架构组件正在更新时,如果用户访问应用程序,他们可能仍然偶尔会遇到错误。这是因为 Laravel 框架的很大一部分必须启动,以确定你的应用程序处于维护模式,并使用模板引擎渲染维护模式视图。
因此,Laravel 允许你预渲染一个维护模式视图,该视图将在请求周期的最开始返回。此视图在你应用程序的任何依赖项加载之前渲染。你可以使用 down 命令的 render 选项预渲染你选择的模板:
php artisan down --render="errors::503"重定向维护模式请求
在维护模式下,Laravel 将为用户尝试访问的所有应用程序 URL 显示维护模式视图。如果你愿意,你可以指示 Laravel 将所有请求重定向到特定的 URL。这可以使用 redirect 选项完成。例如,你可能希望将所有请求重定向到 / URI:
php artisan down --redirect=/禁用维护模式
要禁用维护模式,请使用 up 命令:
php artisan upNOTE
你可以通过在 resources/views/errors/503.blade.php 定义自己的模板来自定义默认的维护模式模板。
维护模式和队列
当你的应用程序处于维护模式时,不会处理任何队列任务。一旦应用程序退出维护模式,这些任务将继续被正常处理。
维护模式的替代方案
由于维护模式需要你的应用程序有几秒钟的停机时间,请考虑在像 Laravel Cloud 这样的完全托管平台上运行你的应用程序,以使用 Laravel 实现零停机部署。