nilsframework/nils-config 问题修复 & 功能扩展

解决BUG、新增功能、兼容多环境部署,快速响应你的开发需求

邮箱:yvsm@zunyunkeji.com | QQ:316430983 | 微信:yvsm316

nilsframework/nils-config

最新稳定版本:1.0.0

Composer 安装命令:

composer require nilsframework/nils-config

包简介

Package de gestion de configuration JSON pour NilsFramework

README 文档

README

Package de gestion de configuration JSON pour NilsFramework.
Charge et expose un fichier config.json via une API statique simple.

📋 Table des matières

Installation

composer require nilsframework/nils-config

Configuration

Créez un fichier Configuration/config.json à la racine de votre projet :

{
    "app_name": "Song-Taaba",
    "app_debug": true,
    "app_url": "http://localhost:8000",

    "mysql": {
        "driver": "mysql",
        "host": "127.0.0.1",
        "username": "root",
        "password": "secret",
        "database": "song_taaba"
    },
    "mariadb": {
        "driver": "mariadb",
        "host": "",
        "username": "",
        "password": "",
        "database": ""
    },
    "sqlite": {
        "driver": "sqlite",
        "database": ""
    },
    "postgresql": {
        "driver": "postgresql",
        "host": "",
        "username": "",
        "password": "",
        "database": ""
    }
}

⚠️ Ne commitez jamais config.json — ajoutez-le à votre .gitignore.
Utilisez config.example.json comme modèle versionné.

Méthodes

charger()

Charge le fichier de configuration JSON.
Appelée automatiquement par toutes les autres méthodes — rarement nécessaire de l'appeler manuellement.

use Configuration\Config;

// Chargement explicite avec chemin personnalisé
Config::charger('Configuration/config.json');

// Chargement automatique implicite
Config::get('app_name'); // charger() est appelé automatiquement

Si la configuration est déjà chargée, un second appel est ignoré.

get()

Retourne la valeur d'une clé de premier niveau.

// Sans valeur par défaut — lève une exception si la clé est absente
$appName = Config::get('app_name');
// "Song-Taaba"

// Avec valeur par défaut
$debug = Config::get('app_debug', false);
// true

$url = Config::get('app_url', 'http://localhost:8000');
// "http://localhost:8000"

// Lève RuntimeException si la clé est absente et pas de défaut
$jwt = Config::get('jwt_secret'); // ← RuntimeException

getSection()

Retourne une section entière du fichier de configuration sous forme de tableau.

$mysql = Config::getSection('mysql');
// [
//   'driver'   => 'mysql',
//   'host'     => '127.0.0.1',
//   'username' => 'root',
//   'password' => 'secret',
//   'database' => 'song_taaba',
// ]

$mailer = Config::getSection('mailer');
// [
//   'host' => 'smtp.example.com',
//   'port' => 587,
//   ...
// ]

getDatabaseConfig()

Retourne la configuration du driver de base de données actif.
Le driver actif est détecté automatiquement — c'est le premier bloc avec les champs obligatoires non vides.

$config = Config::getDatabaseConfig();
// [
//   'driver'   => 'mysql',
//   'host'     => '127.0.0.1',
//   'username' => 'root',
//   'password' => 'secret',
//   'database' => 'song_taaba',
// ]

Règles de détection :

DriverChamps requis
mysql / mariadb / postgresqlhost + database non vides
sqlitedatabase non vide

L'ordre de priorité est : mysqlmariadbsqlitepostgresql.

has()

Vérifie si une clé existe dans la configuration sans lever d'exception.

if (Config::has('mailer')) {
    $mailer = Config::getSection('mailer');
}

if (!Config::has('jwt_secret')) {
    throw new \RuntimeException("JWT non configuré.");
}

all()

Retourne toutes les données de configuration sous forme de tableau.

$config = Config::all();
// [
//   'app_name'  => 'Song-Taaba',
//   'app_debug' => true,
//   'mysql'     => [...],
//   ...
// ]

// Afficher toutes les clés disponibles
echo implode(', ', array_keys(Config::all()));
// app_name, app_debug, app_url, mysql, sqlite, ...

cheminFichier()

Retourne le chemin absolu du fichier de configuration chargé.

$chemin = Config::cheminFichier();
// "/var/www/html/Configuration/config.json"

// Utile pour le débogage
echo "Config chargée depuis : " . Config::cheminFichier();

reinitialiser()

Réinitialise la configuration chargée.
Utile pour les tests unitaires ou pour recharger un fichier différent.

// Charger la config de test
Config::reinitialiser();
Config::charger('Configuration/config.test.json');

$db = Config::getDatabaseConfig();
// Retourne la config de test (SQLite par exemple)

// Restaurer après le test
Config::reinitialiser();

Exceptions

Toutes les erreurs lèvent une \RuntimeException :

SituationMessage
Fichier introuvableFichier de configuration introuvable : /chemin/config.json
JSON invalideJSON invalide dans le fichier de configuration : ...
Clé absente (sans défaut)Clé de configuration introuvable : ma_cle
Section absenteSection de configuration introuvable : ma_section
Aucun driver DB valideAucune base de données valide trouvée dans la configuration.
use Configuration\Config;

try {
    $secret = Config::get('jwt_secret');
} catch (\RuntimeException $e) {
    echo $e->getMessage();
    // "Clé de configuration introuvable : jwt_secret"
}

Licence

MIT — © NilsFramework

统计信息

  • 总下载量: 11
  • 月度下载量: 0
  • 日度下载量: 0
  • 收藏数: 0
  • 点击次数: 4
  • 依赖项目数: 1
  • 推荐数: 0

GitHub 信息

  • Stars: 0
  • Watchers: 0
  • Forks: 0
  • 开发语言: PHP

其他信息

  • 授权协议: MIT
  • 更新时间: 2026-04-19

承接程序开发

PHP开发

VUE

Vue开发

前端开发

小程序开发

公众号开发

系统定制

数据库设计

云部署

网站建设

安全加固