dev-master
9999999-devThinkPHP3.2集成php-dotenv
Apache
The Requires
by 朱亚杰
Wallogit.com
2017 © Pedro Peláez
ThinkPHP3.2集成php-dotenv
ThinkPHP 3.2 集成 php-dotenv, (*1)
composer中文文档, (*2)
dotenv 解决一套代码在多处部署时各处代码所用的环境变量及配置的相互独立问题:, (*3)
团队协作时, 不同成员本地开发环境的系统,服务器类型,数据库用户密码都可能不同. 如果环境配置写死在项目中, 可能每次更新完代码都需要重新修改本地配置., (*4)
本地与线上环境配置肯定不同, 如果直接利用版本库部署代码到线上, 必须防止将本地配置推送到线上., (*5)
composer require snowair/think-dotenv:dev-master
return array(
'app_init'=>array(
'Snowair\Think\Behavior\HookAgent'
),
)
修改 .gitignore, 添加.env文件到排除列表, (*6)
现在你可以在项目根目录(即APP_PATH目录)下创建.env文件定义独立的环境配置了! 就是这么简单., (*7)
.env 文件的格式见文档: https://github.com/josegonzalez/php-dotenv
config.php
return array(
'DB_TYPE' => 'mysql', // 数据库类型
'DB_HOST' => 'localhost', // 服务器地址
'DB_NAME' => 'dbname', // 数据库名
'DB_USER' => 'root', // 用户名
'DB_PWD' => '123456', // 密码
'DB_PORT' => 3306, // 端口
'DB_PREFIX' => '', // 数据库表前缀
);
.env DB_TYPE=mysql DB_HOST=localhost DB_NAME=dbname DB_USER=root ....
应用启动后, .env 文件中的配置项将覆盖config.php中的这些同名的配置项., (*8)
因此, 不同的机器,通过创建自己的.env文件,就可以避免开发和部署时的配置冲突问题., (*9)
注: windows平台创建以.号开头的特殊文件可能需要从编辑器中创建., (*10)
现在你就可以去验证下是否OK了。, (*11)
TP中有些配置的值是数组, 使用 dotenv的配置格式为: KeyP1.KeyP2.Key...=value, (*12)
例如:, (*13)
"MODULE_ALLOW_LIST"=>array('Home','Admin','Api'),
如果想使用 .env 文件进行配置, 文件内容如下:, (*14)
MODULE_ALLOW_LIST.0=Home MODULE_ALLOW_LIST.1=Admin MODULE_ALLOW_LIST.2=Api
一般情况下, 以上默认行为已经足够应付绝大多数场景. 但也许你也需要dotenv提供的其他功能(见文档)., (*15)
think-dotenv 提供了以下配置对应dotenv提供的其他功能:, (*16)
"DOTENV" => array(
"toEnv"=>true, // 是否将 .env导入到 $_ENV 变量, 默认为false
"toServer"=>true, // 是否将 .env导入到 $_SERVER 变量, 默认为false
"toConst"=>true, // 是否将 .env导入到常量, 默认为false
"expect"=>'env1,env2,env3', // 强制要求定义的env配置列表, 如果.env文件中没有定义, 则抛出异常
),
注意: 这些配置必须定义在 Conf/config.php 等配置文件中., (*17)
ThinkPHP3.2集成php-dotenv
Apache