somephp / appconfig
加载并使用单个JSON配置文件的实例。
v1.0.0
2017-08-03 18:42 UTC
Requires
- php: >=5.4
This package is not auto-updated.
Last update: 2024-09-26 21:29:23 UTC
README
一个基本的从JSON文件加载并返回单个运行时实例的应用程序配置类。该实例是可写的。
- 可以从JSON文件创建一个对象。
- 可以从JSON文件的某一节创建一个对象,深度为一级。
- 可以在运行时构建一个对象。
- 只返回一个对象实例。
- 返回的对象是可写的。
许可证
MIT - MIT许可证文件: LICENSE
安装
Composer
composer require somephp/appconfig
使用示例
以下两个示例展示了如何加载JSON配置文件及其部分,它们使用config.json。最后一个示例展示了如何在运行时构建配置。
示例 #1 从JSON文件创建对象
<?php
require_once 'AppConfig.php';
try {
// Specify the path of a JSON file to load.
$config = AppConfig::load('config.json');
} catch (Exception $e) {
var_dump($e->getMessage());
exit;
}
echo "API: {$config->dev->api->example->url} \n";
echo "User: {$config->dev->db->mysql->user} \n";
echo "Passowrd: {$config->dev->db->mysql->pass} \n";
示例 #1 输出
API: https://example.com/dev/api
User: admin
Passowrd: love
示例 #2 从JSON文件的子部分创建对象
<?php
class ServerConfig {
public static $env = 'prod';
}
require_once 'AppConfig.php';
try {
// Create an object from the "prod" section of a JSON file.
$config = AppConfig::load('config.json', ServerConfig::$env);
} catch (Exception $e) {
var_dump($e->getMessage());
exit;
}
// Display a copy the entire runtime object.
echo print_r($config->get(), true);
示例 #2 输出
stdClass Object
(
[db] => stdClass Object
(
[mysql] => stdClass Object
(
[server] => https://example.com
[user] => admin
[pass] => secret
[db] => currency_prod
)
[mongo] => stdClass Object
(
[collection] => currency_prod
[doc] =>
[server] => mongodb://127.0.0.1:27017
)
)
[api] => stdClass Object
(
[example] => stdClass Object
(
[url] => https://example.com/api
[secret] => 74c42a009d7c0fcdb1aa4a853b37977f
[key] => 85bb2e1519dbb2c2421b5cad6039bfcd
[pass] => realsecret5realkey
)
)
)
示例 #3 在运行时构建对象
<?php
require_once 'AppConfig.php';
try {
// Create an empty config object.
$config = AppConfig::load();
} catch (Exception $e) {
var_dump($e->getMessage());
exit;
}
echo 'config->api: '. print_r($config->api, true). PHP_EOL;
echo 'config->db: '. print_r($config->db, true). PHP_EOL;
echo PHP_EOL;
// Add a property.
@$config->api->example->url = 'http://example.com/api';
// Add an object.
$config->db = (object) [
'mysql' => (object) [
'server' => 'localhost',
'user' => 'admin',
'pass' => 'love',
'db' => 'currency_dev'
]
];
// load() will return the same instance of the config object.
$configTwo = AppConfig::load();
echo 'configTwo->api: '. print_r($configTwo->api, true). PHP_EOL;
echo 'configTwo->db: '. print_r($configTwo->db, true). PHP_EOL;
示例 #3 输出
config->api:
config->db:
configTwo->api: stdClass Object
(
[example] => stdClass Object
(
[url] => http://example.com/api
)
)
configTwo->db: stdClass Object
(
[mysql] => stdClass Object
(
[server] => localhost
[user] => admin
[pass] => love
[db] => currency_dev
)
)
内容
资源 | 描述 |
---|---|
贡献
欢迎提出建议和代码修改。创建一个合并请求,并告诉我你的想法。