.env文件需位于项目根目录且命名正确;2. 检查入口文件是否加载.env;3. 清除runtime缓存;4. 确保KEY=VALUE格式无空格;5. 非系统环境变量,应通过Env::get()读取;6. 核对多环境文件匹配;7. 文件权限644,UTF-8无BOM编码。
ThinkPHP 的 .env 文件不生效,通常由以下几个常见原因导致。逐一排查可快速定位问题:
1. 环境文件命名或位置错误
.env 文件必须放在项目根目录(即入口文件 index.php 所在目录的上一级,ThinkPHP 6 的标准结构中),且文件名是 .env,注意开头的点不能遗漏。
常见错误:
- 把 .env 放在 public 目录下
- 文件名写成 env 或 .env.example
- Windows 下保存时自动隐藏扩展名,实际成了 .env.txt
2. 没有正确加载环境变量
ThinkPHP 6 需要手动引入并解析 .env 文件。检查入口文件(如 public/index.php)中是否有以下代码:
立即学习“PHP免费学习笔记(深入)”;
if (is_file(dirname(__DIR__) . '/.env')) { $env = new thinkfacadeEnv(); $env->load(dirname(__DIR__) . '/.env'); }
或者确认框架是否自动加载(TP6 默认会自动检测并加载,但某些部署环境可能被禁用)。
3. 缓存未清除
ThinkPHP 会缓存配置,修改 .env 后如果配置仍不生效,可能是缓存问题。
执行以下命令清除缓存:
php think clear
或手动删除 runtime/config 目录下的缓存文件。
4. 环境变量格式错误
.env 文件中的格式必须规范,否则无法解析:
- 使用 KEY=VALUE 格式
- 等号两边不要有空格(或使用引号包裹含空格的值)
- 支持引号:
app_DEBUG=true
或
APP_NAME="My App"
- 注释用 # 开头
错误示例:
APP_DEBUG = true # 错误:等号前后有空格且未处理
5. Web 服务器未传递环境变量
在 Nginx + PHP-FPM 环境下,PHP 可能无法读取系统环境变量,而 ThinkPHP 的 .env 是通过 PHP 解析的,这不影响。但如果误以为系统环境变量会自动加载,就容易混淆。
确保不是依赖系统级环境变量,而是依赖 ThinkPHP 自身的 Env::get() 方法读取 .env 中定义的内容。
6. 多环境配置冲突
如果使用了 .env.testing、.env.production 等多环境文件,需确保当前环境被正确识别。
查看
$_ENV['APP_ENV']
或
env('APP_ENV')
的值,确认当前加载的是哪个环境文件。
7. 权限或文件编码问题
服务器上 .env 文件权限太严格会导致读取失败。建议设置为 644。
同时,文件应保存为 UTF-8 无 BOM 编码,避免解析异常。
基本上就这些。检查文件位置、格式、缓存和加载逻辑,大多数情况下都能解决 .env 不生效的问题。
php thinkphp windows nginx cad 编码 app 环境变量 win 环境配置 php nginx thinkphp public bom