datahihi1/tiny-env
最新稳定版本:1.0.15
Composer 安装命令:
composer require datahihi1/tiny-env
包简介
A simple environment variable loader for PHP applications
README 文档
README
A lightweight .env loader for PHP projects.
Fast, Safe, Simple — designed for small to medium projects.
Installation
composer require datahihi1/tiny-env:^1.0.15
Quick Start
require 'vendor/autoload.php'; use Datahihi1\TinyEnv\TinyEnv; $env = new TinyEnv(__DIR__); $env->load(); echo env('DB_HOST', 'localhost');
.env file:
DB_HOST=127.0.0.1 DB_PORT=3306
Features
1. load() – Standard load
$env->load(); // Load all $env->load(['DB_HOST']); // Load specific keys $env->load(forceReload: true); // Overwrite existing values $env->load(noFile:true); // Load but skip checking .env file existence
2. Fast load
$env = new TinyEnv(__DIR__, true); // Load immediately $env = new TinyEnv(__DIR__, true, true); // Load immediately and populate $_SERVER # $env->load(); // No need to call load() again
3. Multiple .env files
$env = new TinyEnv(__DIR__.'/to/path/env'); $env->envfiles(['.env', '.env.local', '.env.production']); $env->load(); // Load from multiple files but .env is always first
TinyEnv always loads .env first, then any additional files in the order specified.
Populate Superglobals
$env = new TinyEnv(__DIR__); $env->populateSuperglobals(); // Enable superglobals population $env->populateServerglobals(); // Enable $_SERVER population $env->load();
Or use fastLoad which will always populate superglobals - But not recommended for production.
- Getting Values
echo env('NAME'); // Get value echo env('NOT_FOUND', 'backup'); // With default print_r(env()); // Get all (in .env file) print_r(sysenv()); // Get all system variables
- Validation
Using tiny-env-validator
- Encryption
Using tiny-env-encryptor
Variable Interpolation
TinyEnv supports shell-style interpolation inside .env values:
DB_HOST=localhost DB_PORT=3306 DB_URL=${DB_HOST}:${DB_PORT} USER_NAME= USER=${USER_NAME:-guest} # default if unset or empty ALT_USER=${USER_NAME-guest} # default if unset only REQUIRED=${MISSING?Missing variable MISSING}
Result:
DB_URL = "localhost:3306" USER = "guest" (because USER_NAME is empty) ALT_USER = "" (because USER_NAME exists but empty) REQUIRED → throws Exception
Notes
- Comments start with
#.- Variable names:
A-Z,0-9,_.- Spaces around
=still valid but not recommended.- Values are auto-parsed into correct types:
"true", "yes", "on"→true"false", "no", "off"→false"123"→int"12.3"→floatordouble"null"or empty →null- TinyEnv considers yes/no, on/off to be boolean values.
- Use
"/value/"to force string type.
统计信息
- 总下载量: 286
- 月度下载量: 0
- 日度下载量: 0
- 收藏数: 2
- 点击次数: 1
- 依赖项目数: 2
- 推荐数: 0
其他信息
- 授权协议: MIT
- 更新时间: 2025-02-07