Warning: file_get_contents(/data/phpspider/zhask/data//catemap/9/opencv/3.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
什么';这是在PHP应用程序中获取配置变量的最佳方法(按编码方式)_Php_Class_Config_Configuration Files - Fatal编程技术网

什么';这是在PHP应用程序中获取配置变量的最佳方法(按编码方式)

什么';这是在PHP应用程序中获取配置变量的最佳方法(按编码方式),php,class,config,configuration-files,Php,Class,Config,Configuration Files,我一直在搜索和阅读很多关于如何在PHP环境中获取应用程序配置变量的最佳方法(代码方面)。在此之后,我总结了两种更常用的管理配置文件和变量的方法 但是我对它有点困惑,其中一个,方法1,使用的是一个静态类。另一个,方法2使用的是一个实例化类 第一种方法比第二种方法对单元测试更糟糕。它类似于一个全局变量。不是吗 第二个需要一个全局变量才能使用实例化的对象 我会尽力解释我自己 事实: -应用程序的设置保存在INI文件中。 -此INI文件有多个部分,用于维护配置变量。 -我只有一个INI文件。 -类对配置

我一直在搜索和阅读很多关于如何在PHP环境中获取应用程序配置变量的最佳方法(代码方面)。在此之后,我总结了两种更常用的管理配置文件和变量的方法

但是我对它有点困惑,其中一个,方法1,使用的是一个静态类。另一个,方法2使用的是一个实例化类

第一种方法比第二种方法对单元测试更糟糕。它类似于一个全局变量。不是吗

第二个需要一个全局变量才能使用实例化的对象

我会尽力解释我自己

事实: -应用程序的设置保存在INI文件中。 -此INI文件有多个部分,用于维护配置变量。 -我只有一个INI文件。 -类对配置文件进行一些验证。 -下面的代码示例并不完整,只是一个示例来说明我的问题

方法1:使用静态类 此方法使用一个Config静态类,它使用静态类,因为在所有应用程序中只使用一个Config对象

代码示例:

class Config
{
    static private $data;

    static public function load($configFile) {
        self::$data = parse_ini_file($configFile, true, INI_SCANNER_RAW)
    }

    static public get($key) {
         // code stuff to deal with sections and keys, but basically
         return self::$data[$key];
    }
}
class Config {
    private $data = array();

    public function __construct($configFile) {
        $this->data = parse_ini_file($configFile, true, INI_SCANNER_RAW)
    }

    public function get($key) {
        // code stuff to deal with sections and keys, but basically
        return $this->data[$key];
    }

    public function __get($key) {
        return $this->get($key);
    }
}
在我的应用程序上,我使用以下代码创建静态对象一次:

\Config::load('/where/is/my/ini/file.ini');
在这种情况下,每次我想要获得一个值时,我都会使用:

$host = \Config::get('database.host');

function example() 
{
    echo \Config::get('another.value');
}
方法2:使用不稳定对象 在这个场景中,我使用一个配置类对象

代码示例:

class Config
{
    static private $data;

    static public function load($configFile) {
        self::$data = parse_ini_file($configFile, true, INI_SCANNER_RAW)
    }

    static public get($key) {
         // code stuff to deal with sections and keys, but basically
         return self::$data[$key];
    }
}
class Config {
    private $data = array();

    public function __construct($configFile) {
        $this->data = parse_ini_file($configFile, true, INI_SCANNER_RAW)
    }

    public function get($key) {
        // code stuff to deal with sections and keys, but basically
        return $this->data[$key];
    }

    public function __get($key) {
        return $this->get($key);
    }
}
要使用它,首先需要实例化一个对象,然后获取值:

$settings = new \Config('/where/is/my/ini/file.ini');

$host = $settings->get('database.host');
echo $settings->database->host;
但是当我在函数中需要这个值时,我需要使用一个全局变量,我认为它根本不正确

global $settings;

$settings = new \Config('/where/is/my/ini/file.ini');

function example() 
{
    global $settings;
    echo $settings->get('another.value');
}    
我怀念什么样的领导?


提前感谢您阅读并回答我的问题。

您也可以使用
php
文件保存您的配置,例如,
config.php
,然后您可以从任何地方使用
require
来获取:

// config.php
<?php
    return array(
        'database' => 'mysql',
        'pagination' => array(
            'per_page' => 10
    )
);
您也可以将其与函数一起使用,例如:

function someFunc()
{
    $config = require "path/to/config.php";
    // Now use it
}
class Config {

    static function get()
    {
        $config = require "path/to/config.php";
        return $config;
    }
}
您可以使用以下方法创建一个类来获取配置,例如:

function someFunc()
{
    $config = require "path/to/config.php";
    // Now use it
}
class Config {

    static function get()
    {
        $config = require "path/to/config.php";
        return $config;
    }
}
因此,您可以使用:

$config = Config::get();
这只是另一个简单的想法,您可以将其扩展为如下方式使用:

$perPage = Config::get('pagination.per_page');
只需要添加一些代码,让它像这样工作,试试看

更新:
顺便说一句,早在2013年,我就为自己的
MVC框架
构建了一个名为的包,它也在上提供。您可以使用它或检查它的源代码,也许您会得到更好的想法,并可以建立一个更好的。但是,网络上可能也有很多更好的配置。

您也可以使用
php
文件来保存您的配置,例如,
config.php
,然后您可以从任何地方使用
require
来获取它:

// config.php
<?php
    return array(
        'database' => 'mysql',
        'pagination' => array(
            'per_page' => 10
    )
);
您也可以将其与函数一起使用,例如:

function someFunc()
{
    $config = require "path/to/config.php";
    // Now use it
}
class Config {

    static function get()
    {
        $config = require "path/to/config.php";
        return $config;
    }
}
您可以使用以下方法创建一个类来获取配置,例如:

function someFunc()
{
    $config = require "path/to/config.php";
    // Now use it
}
class Config {

    static function get()
    {
        $config = require "path/to/config.php";
        return $config;
    }
}
因此,您可以使用:

$config = Config::get();
这只是另一个简单的想法,您可以将其扩展为如下方式使用:

$perPage = Config::get('pagination.per_page');
只需要添加一些代码,让它像这样工作,试试看

更新:
顺便说一句,早在2013年,我就为自己的
MVC框架
构建了一个名为的包,它也在上提供。您可以使用它或检查它的源代码,也许您会得到更好的想法,并可以建立一个更好的。但是,网络上可能也有很多更好的方法。

我认为您试图解决的问题并不是PHP特有的,您描述的两种技术中的任何一种都可能是处理全局配置的可行方法

话虽如此,我同意Rangad的观点,解决办法是使用。最简单的情况是,这种模式只意味着将依赖项作为参数传递给类/对象/函数。比如说,

class Thing () {

    private $host = '';

    function __contructor($host) {
        $this->host = $host;
    }

    function getHost() 
    {
        echo $this->host;
    }
}

$thing = new Thing( Config::get('database.host') );
$thing->getHost();

$thing2 = new Thing (Config::get('someOtherDatabase.host') );
$thing2.getHost();
这封装了您的类。现在,只要能够提供所需的依赖关系,它们就可以用于测试甚至其他应用程序


这样做的好处是,您可以将它与您建议的任何配置选项以及其他配置选项一起使用。例如,如果您正在寻找一些简单的东西,那就是Pimple,一个由Symphoy PHP框架的创建者编写的PHP依赖项注入容器,在我看来,它非常适合于较小的PHP项目

我认为您试图解决的问题并不是PHP特有的,您描述的两种技术中的任何一种都可能是处理全局配置的可行方法

话虽如此,我同意Rangad的观点,解决办法是使用。最简单的情况是,这种模式只意味着将依赖项作为参数传递给类/对象/函数。比如说,

class Thing () {

    private $host = '';

    function __contructor($host) {
        $this->host = $host;
    }

    function getHost() 
    {
        echo $this->host;
    }
}

$thing = new Thing( Config::get('database.host') );
$thing->getHost();

$thing2 = new Thing (Config::get('someOtherDatabase.host') );
$thing2.getHost();
这封装了您的类。现在,只要能够提供所需的依赖关系,它们就可以用于测试甚至其他应用程序


这样做的好处是,您可以将它与您建议的任何配置选项以及其他配置选项一起使用。例如,如果您正在寻找一些简单的东西,那就是Pimple,一个由Symphoy PHP框架的创建者编写的PHP依赖项注入容器,在我看来,它非常适合于较小的PHP项目

如果您正在构建一个新的应用程序,为什么不去掉任何不必要的全局代码并依靠适当的depdency注入(即使这意味着手动将配置对象传递到函数中)?使用配置对象并使用依赖项注入使其可用。如果您在某种框架中,您可能已经有了DI解决方案。您始终可以自己滚动,如全局容器、发布/订阅或反射注入。如果您不在框架中,请使用另一个框架中的组件,而不是编写自己的组件,如。感谢@Rangad的评论。我是一个OOP新手,所以我的大部分代码都不是OO。为了采用面向对象的方法,我正在尝试转换它的某些部分。谢谢@bishop的评论。如果我不理解错了,你就是我